[PATCH] iio - bmp085 most issues done

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

 



This patch handles with most of the issues mentioned.

Hope I did it right, with patch submission like this.

Signed-off-by: Matthias Brugger <m_brugger@xxxxxx>
---
 drivers/staging/iio/barometer/baro.h   |    2 +-
 drivers/staging/iio/barometer/bmp085.c |   56
++++++++++---------------------
 drivers/staging/iio/barometer/bmp085.h |   37 ++++++++++++++++++++-
 3 files changed, 55 insertions(+), 40 deletions(-)

diff --git a/drivers/staging/iio/barometer/baro.h
b/drivers/staging/iio/barometer/baro.h
index e3b73a1..a25e4cd 100644
--- a/drivers/staging/iio/barometer/baro.h
+++ b/drivers/staging/iio/barometer/baro.h
@@ -4,5 +4,5 @@
 /* Barometer types of attribute */

 #define IIO_DEV_ATTR_BARO_PRESSURE(_mode, _show, _store, _addr)	\
-	IIO_DEVICE_ATTR(baro_pressure, _mode, _show, NULL, _addr)
+	IIO_DEVICE_ATTR(baro_pressure_input, _mode, _show, NULL, _addr)

diff --git a/drivers/staging/iio/barometer/bmp085.c
b/drivers/staging/iio/barometer/bmp085.c
index 67dac39..580bd57 100644
--- a/drivers/staging/iio/barometer/bmp085.c
+++ b/drivers/staging/iio/barometer/bmp085.c
@@ -37,7 +37,7 @@ module_param(oss, int , S_IRUSR);
 MODULE_PARM_DESC(oss, "Oversampling setting [0-3]");

 /**************************************************************************
- * Calcualtion of temperature and pressure
+ * Calculation of temperature and pressure

**************************************************************************/
 static short bmp085_calc_temperature(struct i2c_client *client,
 	       unsigned long ut)
@@ -90,17 +90,6 @@ static long bmp085_calc_pressure(struct
i2c_client *client, unsigned long up)
  * Digital interface to sensor

**************************************************************************/

-static ssize_t bmp085_read(struct i2c_client *client, u8 reg,
size_t count,
-	       unsigned char *buffer)
-{
-	int rc;
-	rc = i2c_smbus_read_i2c_block_data(client, reg, count, buffer);
-	if (rc < 0)
-			return -EIO;
-
-	return count;
-}
-
 static short bmp085_read_temp(struct i2c_client *client)
 {
 	s32 ret;
@@ -117,8 +106,9 @@ static short bmp085_read_temp(struct i2c_client
*client)
 		return ret;
 	}

-	mdelay(5);
-	ret = bmp085_read(client, BMP085_REG_CONV, 2, data->data);
+	msleep(5);
+	ret = i2c_smbus_read_i2c_block_data(client, BMP085_REG_CONV, 2,
+			data->data);
 	if (ret < 0) {
 		dev_warn(&client->dev, "reading ut failed, value is %#x\n"
 				, ret);
@@ -139,7 +129,6 @@ static long bmp085_read_pressure(struct
i2c_client *client)
 	u8 xlsb, ret1, ret2;
 	long pressure;
 	u8 reg;
-	/* TODO should be 4.5, 7.5, 13.5, 25.5 ms */
 	int time_delay[4] = {5, 8, 14, 26};
 	struct bmp085_data *data = i2c_get_clientdata(client);

@@ -163,7 +152,7 @@ static long bmp085_read_pressure(struct
i2c_client *client)
 	if (ret < 0)
 		return ret;

-	mdelay(time_delay[data->oss]);
+	msleep(time_delay[data->oss]);

 	mutex_lock(&data->bmp085_lock);
 	ret1 = i2c_smbus_read_byte_data(client, 0xf6);
@@ -176,7 +165,6 @@ static long bmp085_read_pressure(struct
i2c_client *client)
 	data->up = up;

 	pressure = bmp085_calc_pressure(client, up);
-	data->pressure = pressure;

 	return pressure;
 }
@@ -199,13 +187,13 @@ static ssize_t barometer_show_temp(struct
device *dev,

 	data->temp = status;

-	return sprintf(buf, "%ld\n", data->temp);
+	return sprintf(buf, "%d\n", data->temp);
 }
 static IIO_DEV_ATTR_TEMP_RAW(barometer_show_temp);

 /**
- * In standard mode, the temperature has to be reat every second
before the
- * pressure can be reat. We leave this semantics to the userspace,
if later
+ * In standard mode, the temperature has to be read every second
before the
+ * pressure can be read. We leave this semantics to the userspace,
if later
  * on a trigger based reading will be implemented, this should be
taken into
  * account.
  */
@@ -213,7 +201,7 @@ static ssize_t barometer_show_pressure(struct
device *dev,
 		struct device_attribute *da, char *buf)
 {
 	struct iio_dev *indio_dev = dev_get_drvdata(dev);
-	struct bmp085_data *data = indio_dev->dev_data;
+	struct bmp085_data *data = iio_dev_get_devdata(indio_dev);
 	struct i2c_client *client = data->client;
 	long status;

@@ -231,7 +219,7 @@ static ssize_t barometer_show_id_version(struct
device *dev,
 		struct device_attribute *da, char *buf)
 {
 	struct iio_dev *indio_dev = dev_get_drvdata(dev);
-	struct bmp085_data *data = indio_dev->dev_data;
+	struct bmp085_data *data = iio_dev_get_devdata(indio_dev);

 	return sprintf(buf, "%x_%x\n", data->chip_id, data->chip_version);
 }
@@ -241,7 +229,7 @@ static ssize_t barometer_show_oss(struct device
*dev,
 		struct device_attribute *da, char *buf)
 {
 	struct iio_dev *indio_dev = dev_get_drvdata(dev);
-	struct bmp085_data *data = indio_dev->dev_data;
+	struct bmp085_data *data = iio_dev_get_devdata(indio_dev);

 	return sprintf(buf, "%d\n", data->oss);
 }
@@ -251,7 +239,7 @@ static IIO_CONST_ATTR_TEMP_SCALE("0.1");

 static struct attribute *bmp085_attributes[] = {
 	&iio_dev_attr_temp_raw.dev_attr.attr,
-	&iio_dev_attr_baro_pressure.dev_attr.attr,
+	&iio_dev_attr_baro_pressure_input.dev_attr.attr,
 	&iio_dev_attr_revision.dev_attr.attr,
 	&iio_dev_attr_sampling_frequency.dev_attr.attr,
 	&iio_const_attr_temp_scale.dev_attr.attr,
@@ -271,15 +259,17 @@ static int bmp085_init_client(struct
i2c_client *client)
 	struct bmp085_data *data = i2c_get_clientdata(client);
 	int i;

-	i = bmp085_read(client, BMP085_REG_CHIP_ID, 1, &data->chip_id);
+	i = i2c_smbus_read_i2c_block_data(client, BMP085_REG_CHIP_ID, 1,
+			&data->chip_id);
 	if (i < 0)
 		dev_warn(&client->dev, "Chip ID not read\n");

-	i = bmp085_read(client, BMP085_REG_VERSION, 1, &data->chip_version);
+	i = i2c_smbus_read_i2c_block_data(client, BMP085_REG_VERSION, 1,
+			&data->chip_version);
 	if (i < 0)
 		dev_warn(&client->dev, "Version not read\n");

-	i = bmp085_read(client, BMP085_REG_PROM, BMP085_PROM_LENGTH,
+	i = i2c_smbus_read_i2c_block_data(client, BMP085_REG_PROM,
BMP085_PROM_LENGTH,
 			data->data);
 	if (i < 0)
 		dev_warn(&client->dev, "Unable to read %d bytes from address "
@@ -300,13 +290,11 @@ static int bmp085_init_client(struct
i2c_client *client)
 	return 0;
 }

-static struct i2c_driver bmp085_drv;
 static int bmp085_probe(struct i2c_client *client,
 		const struct i2c_device_id *id)
 {
 	struct i2c_adapter *adapter = to_i2c_adapter(client->dev.parent);
 	struct bmp085_data *data;
-	struct bmp085_data *data2;
 	int status = 0;

 	if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_BYTE_DATA |
@@ -326,12 +314,11 @@ static int bmp085_probe(struct i2c_client *client,

 	data->client = client;
 	i2c_set_clientdata(client, data);
-	data2 = i2c_get_clientdata(client);

 	/* Initialize the BMP085 chip */
 	bmp085_init_client(client);

-	__mutex_init(&data->bmp085_lock, "bmp085_lock", NULL);
+	mutex_init(&data->bmp085_lock);

 	/* Register with IIO */
 	data->indio_dev = iio_allocate_device();
@@ -350,8 +337,6 @@ static int bmp085_probe(struct i2c_client *client,
 	if (status < 0)
 		goto err_iio;

-	dev_info(&client->dev, "driver enabled\n");
-
 	return 0;

 err_iio:
@@ -365,16 +350,11 @@ static int __devexit bmp085_remove(struct
i2c_client *client)
 {
 	struct bmp085_data *data = i2c_get_clientdata(client);

-	if (mutex_is_locked(&data->bmp085_lock))
-		mutex_unlock(&data->bmp085_lock);
-
 	iio_device_unregister(data->indio_dev);
 	iio_free_device(data->indio_dev);

 	kfree(data);

-	dev_info(&client->dev, "driver removed\n");
-
 	return 0;
 }

diff --git a/drivers/staging/iio/barometer/bmp085.h
b/drivers/staging/iio/barometer/bmp085.h
index 5ed2fb1..aec2ee4 100644
--- a/drivers/staging/iio/barometer/bmp085.h
+++ b/drivers/staging/iio/barometer/bmp085.h
@@ -35,6 +35,41 @@
 #define BMP085_REG_VERSION	0xD1
 #define BMP085_CHIP_ID		0x55

+/*
+ * data structure for every sensor
+ *
+ * @client		i2c client
+ * @ indio_dev		iio device representation
+ *
+ * @bmp085_lock		mutex to synchronize parallel reads and writes
+ *
+ * @oss			oversampling setting, determines how accurate the chip works
+ * @temp		holding actual temperature in 0.1°C
+ * @pressure		holding actual pressure in pascal
+ *
+ * @ac1			calibration value read at start-up
+ * @ac2			calibration value read at start-up
+ * @ac3			calibration value read at start-up
+ * @ac4			calibration value read at start-up
+ * @ac5			calibration value read at start-up
+ * @ac6			calibration value read at start-up
+ *
+ * @b1			calibration value read at start-up
+ * @b2			calibration value read at start-up
+ * @b3			calibration value read at start-up
+ *
+ * @mb			calibration value read at start-up
+ * @mc			calibration value read at start-up
+ * @md			calibration value read at start-up
+ *
+ * @ut			raw data to compute temperature
+ * @up			raw data to compute pressure
+ *
+ * @chip_id		id of the chip
+ * @chip_version	version of the chip
+ *
+ * @data		array to read initial calib data as a bulk
+ */
 struct bmp085_data {
 	struct i2c_client *client;
 	struct iio_dev *indio_dev;
@@ -42,7 +77,7 @@ struct bmp085_data {
 	struct mutex bmp085_lock;

 	int oss;
-	long temp;
+	s16 temp;
 	long pressure;

 	short ac1;
-- 
1.5.6.5
--
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