Re: [PATCH 5/5] iio:magnetometer:mag3110: Enable user offset calibration

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 





On 10/01/14 21:59, Peter Meerwald wrote:
add IIO_CHAN_INFO_CALIBBIAS

Signed-off-by: Peter Meerwald <pmeerw@xxxxxxxxxx>
Looks good, but held until the fixes have made it into staging-next.
---
  drivers/iio/magnetometer/mag3110.c | 17 +++++++++++++++--
  1 file changed, 15 insertions(+), 2 deletions(-)

diff --git a/drivers/iio/magnetometer/mag3110.c b/drivers/iio/magnetometer/mag3110.c
index 9e774de..9f260a5 100644
--- a/drivers/iio/magnetometer/mag3110.c
+++ b/drivers/iio/magnetometer/mag3110.c
@@ -200,6 +200,13 @@ static int mag3110_read_raw(struct iio_dev *indio_dev,
  		*val = mag3110_samp_freq[i][0];
  		*val2 = mag3110_samp_freq[i][1];
  		return IIO_VAL_INT_PLUS_MICRO;
+	case IIO_CHAN_INFO_CALIBBIAS:
+		ret = i2c_smbus_read_word_swapped(data->client,
+			MAG3110_OFF_X +	2 * chan->scan_index);
+		if (ret < 0)
+			return ret;
+		*val = sign_extend32(ret >> 1, 14);
+		return IIO_VAL_INT;
  	}
  	return -EINVAL;
  }
@@ -224,6 +231,11 @@ static int mag3110_write_raw(struct iio_dev *indio_dev,
  		data->ctrl_reg1 |= rate << MAG3110_CTRL_DR_SHIFT;
  		return i2c_smbus_write_byte_data(data->client,
  			MAG3110_CTRL_REG1, data->ctrl_reg1);
+	case IIO_CHAN_INFO_CALIBBIAS:
+		if (val < -10000 || val > 10000)
+			return -EINVAL;
+		return i2c_smbus_write_word_swapped(data->client,
+			MAG3110_OFF_X + 2 * chan->scan_index, val << 1);
  	default:
  		return -EINVAL;
  	}
@@ -261,7 +273,8 @@ done:
  	.type = IIO_MAGN, \
  	.modified = 1, \
  	.channel2 = IIO_MOD_##axis, \
-	.info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
+	.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | \
+		BIT(IIO_CHAN_INFO_CALIBBIAS), \
  	.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SAMP_FREQ) | \
  		BIT(IIO_CHAN_INFO_SCALE), \
  	.scan_index = idx, \
@@ -346,7 +359,7 @@ static int mag3110_probe(struct i2c_client *client,
  		return ret;

  	ret = i2c_smbus_write_byte_data(client, MAG3110_CTRL_REG2,
-		MAG3110_CTRL_AUTO_MRST_EN | MAG3110_CTRL_RAW);
+		MAG3110_CTRL_AUTO_MRST_EN);
  	if (ret < 0)
  		return ret;


--
To unsubscribe from this list: send the line "unsubscribe linux-iio" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Input]     [Linux Kernel]     [Linux SCSI]     [X.org]

  Powered by Linux