diff options
Diffstat (limited to 'drivers/iio')
103 files changed, 4478 insertions, 1011 deletions
diff --git a/drivers/iio/Kconfig b/drivers/iio/Kconfig index 9af763a90d93..cbea3271c1b1 100644 --- a/drivers/iio/Kconfig +++ b/drivers/iio/Kconfig | |||
@@ -23,15 +23,14 @@ if IIO_BUFFER | |||
23 | config IIO_BUFFER_CB | 23 | config IIO_BUFFER_CB |
24 | boolean "IIO callback buffer used for push in-kernel interfaces" | 24 | boolean "IIO callback buffer used for push in-kernel interfaces" |
25 | help | 25 | help |
26 | Should be selected by any drivers that do-inkernel push | 26 | Should be selected by any drivers that do in-kernel push |
27 | usage. That is, those where the data is pushed to the consumer. | 27 | usage. That is, those where the data is pushed to the consumer. |
28 | 28 | ||
29 | config IIO_KFIFO_BUF | 29 | config IIO_KFIFO_BUF |
30 | select IIO_TRIGGER | 30 | select IIO_TRIGGER |
31 | tristate "Industrial I/O buffering based on kfifo" | 31 | tristate "Industrial I/O buffering based on kfifo" |
32 | help | 32 | help |
33 | A simple fifo based on kfifo. Use this if you want a fifo | 33 | A simple fifo based on kfifo. Note that this currently provides |
34 | rather than a ring buffer. Note that this currently provides | ||
35 | no buffer events so it is up to userspace to work out how | 34 | no buffer events so it is up to userspace to work out how |
36 | often to read from the buffer. | 35 | often to read from the buffer. |
37 | 36 | ||
@@ -49,7 +48,7 @@ config IIO_TRIGGER | |||
49 | help | 48 | help |
50 | Provides IIO core support for triggers. Currently these | 49 | Provides IIO core support for triggers. Currently these |
51 | are used to initialize capture of samples to push into | 50 | are used to initialize capture of samples to push into |
52 | ring buffers. The triggers are effectively a 'capture | 51 | buffers. The triggers are effectively a 'capture |
53 | data now' interrupt. | 52 | data now' interrupt. |
54 | 53 | ||
55 | config IIO_CONSUMERS_PER_TRIGGER | 54 | config IIO_CONSUMERS_PER_TRIGGER |
@@ -74,5 +73,6 @@ if IIO_TRIGGER | |||
74 | source "drivers/iio/trigger/Kconfig" | 73 | source "drivers/iio/trigger/Kconfig" |
75 | endif #IIO_TRIGGER | 74 | endif #IIO_TRIGGER |
76 | source "drivers/iio/pressure/Kconfig" | 75 | source "drivers/iio/pressure/Kconfig" |
76 | source "drivers/iio/temperature/Kconfig" | ||
77 | 77 | ||
78 | endif # IIO | 78 | endif # IIO |
diff --git a/drivers/iio/Makefile b/drivers/iio/Makefile index 7a3866c2d2a1..bcf7e9e3b053 100644 --- a/drivers/iio/Makefile +++ b/drivers/iio/Makefile | |||
@@ -21,5 +21,6 @@ obj-y += frequency/ | |||
21 | obj-y += imu/ | 21 | obj-y += imu/ |
22 | obj-y += light/ | 22 | obj-y += light/ |
23 | obj-y += magnetometer/ | 23 | obj-y += magnetometer/ |
24 | obj-y += trigger/ | ||
25 | obj-y += pressure/ | 24 | obj-y += pressure/ |
25 | obj-y += temperature/ | ||
26 | obj-y += trigger/ | ||
diff --git a/drivers/iio/accel/Kconfig b/drivers/iio/accel/Kconfig index 719d83fe51dd..e23e50850655 100644 --- a/drivers/iio/accel/Kconfig +++ b/drivers/iio/accel/Kconfig | |||
@@ -1,8 +1,22 @@ | |||
1 | # | 1 | # |
2 | # Accelerometer drivers | 2 | # Accelerometer drivers |
3 | # | 3 | # |
4 | # When adding new entries keep the list in alphabetical order | ||
5 | |||
4 | menu "Accelerometers" | 6 | menu "Accelerometers" |
5 | 7 | ||
8 | config BMA180 | ||
9 | tristate "Bosch BMA180 3-Axis Accelerometer Driver" | ||
10 | depends on I2C | ||
11 | select IIO_BUFFER | ||
12 | select IIO_TRIGGERED_BUFFER | ||
13 | help | ||
14 | Say Y here if you want to build a driver for the Bosch BMA180 | ||
15 | triaxial acceleration sensor. | ||
16 | |||
17 | To compile this driver as a module, choose M here: the | ||
18 | module will be called bma180. | ||
19 | |||
6 | config HID_SENSOR_ACCEL_3D | 20 | config HID_SENSOR_ACCEL_3D |
7 | depends on HID_SENSOR_HUB | 21 | depends on HID_SENSOR_HUB |
8 | select IIO_BUFFER | 22 | select IIO_BUFFER |
@@ -14,13 +28,6 @@ config HID_SENSOR_ACCEL_3D | |||
14 | Say yes here to build support for the HID SENSOR | 28 | Say yes here to build support for the HID SENSOR |
15 | accelerometers 3D. | 29 | accelerometers 3D. |
16 | 30 | ||
17 | config KXSD9 | ||
18 | tristate "Kionix KXSD9 Accelerometer Driver" | ||
19 | depends on SPI | ||
20 | help | ||
21 | Say yes here to build support for the Kionix KXSD9 accelerometer. | ||
22 | Currently this only supports the device via an SPI interface. | ||
23 | |||
24 | config IIO_ST_ACCEL_3AXIS | 31 | config IIO_ST_ACCEL_3AXIS |
25 | tristate "STMicroelectronics accelerometers 3-Axis Driver" | 32 | tristate "STMicroelectronics accelerometers 3-Axis Driver" |
26 | depends on (I2C || SPI_MASTER) && SYSFS | 33 | depends on (I2C || SPI_MASTER) && SYSFS |
@@ -33,8 +40,8 @@ config IIO_ST_ACCEL_3AXIS | |||
33 | LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC, | 40 | LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC, |
34 | LIS331DLH, LSM303DL, LSM303DLM, LSM330. | 41 | LIS331DLH, LSM303DL, LSM303DLM, LSM330. |
35 | 42 | ||
36 | This driver can also be built as a module. If so, will be created | 43 | This driver can also be built as a module. If so, these modules |
37 | these modules: | 44 | will be created: |
38 | - st_accel (core functions for the driver [it is mandatory]); | 45 | - st_accel (core functions for the driver [it is mandatory]); |
39 | - st_accel_i2c (necessary for the I2C devices [optional*]); | 46 | - st_accel_i2c (necessary for the I2C devices [optional*]); |
40 | - st_accel_spi (necessary for the SPI devices [optional*]); | 47 | - st_accel_spi (necessary for the SPI devices [optional*]); |
@@ -51,4 +58,11 @@ config IIO_ST_ACCEL_SPI_3AXIS | |||
51 | depends on IIO_ST_ACCEL_3AXIS | 58 | depends on IIO_ST_ACCEL_3AXIS |
52 | depends on IIO_ST_SENSORS_SPI | 59 | depends on IIO_ST_SENSORS_SPI |
53 | 60 | ||
61 | config KXSD9 | ||
62 | tristate "Kionix KXSD9 Accelerometer Driver" | ||
63 | depends on SPI | ||
64 | help | ||
65 | Say yes here to build support for the Kionix KXSD9 accelerometer. | ||
66 | Currently this only supports the device via an SPI interface. | ||
67 | |||
54 | endmenu | 68 | endmenu |
diff --git a/drivers/iio/accel/Makefile b/drivers/iio/accel/Makefile index 87d8fa264894..c48d15f25616 100644 --- a/drivers/iio/accel/Makefile +++ b/drivers/iio/accel/Makefile | |||
@@ -2,7 +2,10 @@ | |||
2 | # Makefile for industrial I/O accelerometer drivers | 2 | # Makefile for industrial I/O accelerometer drivers |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
6 | obj-$(CONFIG_BMA180) += bma180.o | ||
5 | obj-$(CONFIG_HID_SENSOR_ACCEL_3D) += hid-sensor-accel-3d.o | 7 | obj-$(CONFIG_HID_SENSOR_ACCEL_3D) += hid-sensor-accel-3d.o |
8 | obj-$(CONFIG_KXSD9) += kxsd9.o | ||
6 | 9 | ||
7 | obj-$(CONFIG_IIO_ST_ACCEL_3AXIS) += st_accel.o | 10 | obj-$(CONFIG_IIO_ST_ACCEL_3AXIS) += st_accel.o |
8 | st_accel-y := st_accel_core.o | 11 | st_accel-y := st_accel_core.o |
@@ -10,5 +13,3 @@ st_accel-$(CONFIG_IIO_BUFFER) += st_accel_buffer.o | |||
10 | 13 | ||
11 | obj-$(CONFIG_IIO_ST_ACCEL_I2C_3AXIS) += st_accel_i2c.o | 14 | obj-$(CONFIG_IIO_ST_ACCEL_I2C_3AXIS) += st_accel_i2c.o |
12 | obj-$(CONFIG_IIO_ST_ACCEL_SPI_3AXIS) += st_accel_spi.o | 15 | obj-$(CONFIG_IIO_ST_ACCEL_SPI_3AXIS) += st_accel_spi.o |
13 | |||
14 | obj-$(CONFIG_KXSD9) += kxsd9.o | ||
diff --git a/drivers/iio/accel/bma180.c b/drivers/iio/accel/bma180.c new file mode 100644 index 000000000000..12e32e6b4103 --- /dev/null +++ b/drivers/iio/accel/bma180.c | |||
@@ -0,0 +1,676 @@ | |||
1 | /* | ||
2 | * bma180.c - IIO driver for Bosch BMA180 triaxial acceleration sensor | ||
3 | * | ||
4 | * Copyright 2013 Oleksandr Kravchenko <x0199363@ti.com> | ||
5 | * | ||
6 | * This file is subject to the terms and conditions of version 2 of | ||
7 | * the GNU General Public License. See the file COPYING in the main | ||
8 | * directory of this archive for more details. | ||
9 | */ | ||
10 | |||
11 | #include <linux/module.h> | ||
12 | #include <linux/i2c.h> | ||
13 | #include <linux/interrupt.h> | ||
14 | #include <linux/delay.h> | ||
15 | #include <linux/of.h> | ||
16 | #include <linux/bitops.h> | ||
17 | #include <linux/slab.h> | ||
18 | #include <linux/string.h> | ||
19 | #include <linux/iio/iio.h> | ||
20 | #include <linux/iio/sysfs.h> | ||
21 | #include <linux/iio/buffer.h> | ||
22 | #include <linux/iio/trigger.h> | ||
23 | #include <linux/iio/trigger_consumer.h> | ||
24 | #include <linux/iio/triggered_buffer.h> | ||
25 | |||
26 | #define BMA180_DRV_NAME "bma180" | ||
27 | #define BMA180_IRQ_NAME "bma180_event" | ||
28 | |||
29 | /* Register set */ | ||
30 | #define BMA180_CHIP_ID 0x00 /* Need to distinguish BMA180 from other */ | ||
31 | #define BMA180_ACC_X_LSB 0x02 /* First of 6 registers of accel data */ | ||
32 | #define BMA180_CTRL_REG0 0x0d | ||
33 | #define BMA180_RESET 0x10 | ||
34 | #define BMA180_BW_TCS 0x20 | ||
35 | #define BMA180_CTRL_REG3 0x21 | ||
36 | #define BMA180_TCO_Z 0x30 | ||
37 | #define BMA180_OFFSET_LSB1 0x35 | ||
38 | |||
39 | /* BMA180_CTRL_REG0 bits */ | ||
40 | #define BMA180_DIS_WAKE_UP BIT(0) /* Disable wake up mode */ | ||
41 | #define BMA180_SLEEP BIT(1) /* 1 - chip will sleep */ | ||
42 | #define BMA180_EE_W BIT(4) /* Unlock writing to addr from 0x20 */ | ||
43 | #define BMA180_RESET_INT BIT(6) /* Reset pending interrupts */ | ||
44 | |||
45 | /* BMA180_CTRL_REG3 bits */ | ||
46 | #define BMA180_NEW_DATA_INT BIT(1) /* Intr every new accel data is ready */ | ||
47 | |||
48 | /* BMA180_OFFSET_LSB1 skipping mode bit */ | ||
49 | #define BMA180_SMP_SKIP BIT(0) | ||
50 | |||
51 | /* Bit masks for registers bit fields */ | ||
52 | #define BMA180_RANGE 0x0e /* Range of measured accel values*/ | ||
53 | #define BMA180_BW 0xf0 /* Accel bandwidth */ | ||
54 | #define BMA180_MODE_CONFIG 0x03 /* Config operation modes */ | ||
55 | |||
56 | /* We have to write this value in reset register to do soft reset */ | ||
57 | #define BMA180_RESET_VAL 0xb6 | ||
58 | |||
59 | #define BMA_180_ID_REG_VAL 0x03 | ||
60 | |||
61 | /* Chip power modes */ | ||
62 | #define BMA180_LOW_NOISE 0x00 | ||
63 | #define BMA180_LOW_POWER 0x03 | ||
64 | |||
65 | #define BMA180_LOW_NOISE_STR "low_noise" | ||
66 | #define BMA180_LOW_POWER_STR "low_power" | ||
67 | |||
68 | /* Defaults values */ | ||
69 | #define BMA180_DEF_PMODE 0 | ||
70 | #define BMA180_DEF_BW 20 | ||
71 | #define BMA180_DEF_SCALE 250 | ||
72 | |||
73 | /* Available values for sysfs */ | ||
74 | #define BMA180_FLP_FREQ_AVAILABLE \ | ||
75 | "10 20 40 75 150 300" | ||
76 | #define BMA180_SCALE_AVAILABLE \ | ||
77 | "0.000130 0.000190 0.000250 0.000380 0.000500 0.000990 0.001980" | ||
78 | |||
79 | struct bma180_data { | ||
80 | struct i2c_client *client; | ||
81 | struct iio_trigger *trig; | ||
82 | struct mutex mutex; | ||
83 | int sleep_state; | ||
84 | int scale; | ||
85 | int bw; | ||
86 | int pmode; | ||
87 | char *buff; | ||
88 | }; | ||
89 | |||
90 | enum bma180_axis { | ||
91 | AXIS_X, | ||
92 | AXIS_Y, | ||
93 | AXIS_Z, | ||
94 | }; | ||
95 | |||
96 | static int bw_table[] = { 10, 20, 40, 75, 150, 300 }; /* Hz */ | ||
97 | static int scale_table[] = { 130, 190, 250, 380, 500, 990, 1980 }; | ||
98 | |||
99 | static int bma180_get_acc_reg(struct bma180_data *data, enum bma180_axis axis) | ||
100 | { | ||
101 | u8 reg = BMA180_ACC_X_LSB + axis * 2; | ||
102 | int ret; | ||
103 | |||
104 | if (data->sleep_state) | ||
105 | return -EBUSY; | ||
106 | |||
107 | ret = i2c_smbus_read_word_data(data->client, reg); | ||
108 | if (ret < 0) | ||
109 | dev_err(&data->client->dev, | ||
110 | "failed to read accel_%c registers\n", 'x' + axis); | ||
111 | |||
112 | return ret; | ||
113 | } | ||
114 | |||
115 | static int bma180_set_bits(struct bma180_data *data, u8 reg, u8 mask, u8 val) | ||
116 | { | ||
117 | int ret = i2c_smbus_read_byte_data(data->client, reg); | ||
118 | u8 reg_val = (ret & ~mask) | (val << (ffs(mask) - 1)); | ||
119 | |||
120 | if (ret < 0) | ||
121 | return ret; | ||
122 | |||
123 | return i2c_smbus_write_byte_data(data->client, reg, reg_val); | ||
124 | } | ||
125 | |||
126 | static int bma180_reset_intr(struct bma180_data *data) | ||
127 | { | ||
128 | int ret = bma180_set_bits(data, BMA180_CTRL_REG0, BMA180_RESET_INT, 1); | ||
129 | |||
130 | if (ret) | ||
131 | dev_err(&data->client->dev, "failed to reset interrupt\n"); | ||
132 | |||
133 | return ret; | ||
134 | } | ||
135 | |||
136 | static int bma180_set_new_data_intr_state(struct bma180_data *data, int state) | ||
137 | { | ||
138 | u8 reg_val = state ? BMA180_NEW_DATA_INT : 0x00; | ||
139 | int ret = i2c_smbus_write_byte_data(data->client, BMA180_CTRL_REG3, | ||
140 | reg_val); | ||
141 | |||
142 | if (ret) | ||
143 | goto err; | ||
144 | ret = bma180_reset_intr(data); | ||
145 | if (ret) | ||
146 | goto err; | ||
147 | |||
148 | return 0; | ||
149 | |||
150 | err: | ||
151 | dev_err(&data->client->dev, | ||
152 | "failed to set new data interrupt state %d\n", state); | ||
153 | return ret; | ||
154 | } | ||
155 | |||
156 | static int bma180_set_sleep_state(struct bma180_data *data, int state) | ||
157 | { | ||
158 | int ret = bma180_set_bits(data, BMA180_CTRL_REG0, BMA180_SLEEP, state); | ||
159 | |||
160 | if (ret) { | ||
161 | dev_err(&data->client->dev, | ||
162 | "failed to set sleep state %d\n", state); | ||
163 | return ret; | ||
164 | } | ||
165 | data->sleep_state = state; | ||
166 | |||
167 | return 0; | ||
168 | } | ||
169 | |||
170 | static int bma180_set_ee_writing_state(struct bma180_data *data, int state) | ||
171 | { | ||
172 | int ret = bma180_set_bits(data, BMA180_CTRL_REG0, BMA180_EE_W, state); | ||
173 | |||
174 | if (ret) | ||
175 | dev_err(&data->client->dev, | ||
176 | "failed to set ee writing state %d\n", state); | ||
177 | |||
178 | return ret; | ||
179 | } | ||
180 | |||
181 | static int bma180_set_bw(struct bma180_data *data, int val) | ||
182 | { | ||
183 | int ret, i; | ||
184 | |||
185 | if (data->sleep_state) | ||
186 | return -EBUSY; | ||
187 | |||
188 | for (i = 0; i < ARRAY_SIZE(bw_table); ++i) { | ||
189 | if (bw_table[i] == val) { | ||
190 | ret = bma180_set_bits(data, | ||
191 | BMA180_BW_TCS, BMA180_BW, i); | ||
192 | if (ret) { | ||
193 | dev_err(&data->client->dev, | ||
194 | "failed to set bandwidth\n"); | ||
195 | return ret; | ||
196 | } | ||
197 | data->bw = val; | ||
198 | return 0; | ||
199 | } | ||
200 | } | ||
201 | |||
202 | return -EINVAL; | ||
203 | } | ||
204 | |||
205 | static int bma180_set_scale(struct bma180_data *data, int val) | ||
206 | { | ||
207 | int ret, i; | ||
208 | |||
209 | if (data->sleep_state) | ||
210 | return -EBUSY; | ||
211 | |||
212 | for (i = 0; i < ARRAY_SIZE(scale_table); ++i) | ||
213 | if (scale_table[i] == val) { | ||
214 | ret = bma180_set_bits(data, | ||
215 | BMA180_OFFSET_LSB1, BMA180_RANGE, i); | ||
216 | if (ret) { | ||
217 | dev_err(&data->client->dev, | ||
218 | "failed to set scale\n"); | ||
219 | return ret; | ||
220 | } | ||
221 | data->scale = val; | ||
222 | return 0; | ||
223 | } | ||
224 | |||
225 | return -EINVAL; | ||
226 | } | ||
227 | |||
228 | static int bma180_set_pmode(struct bma180_data *data, int mode) | ||
229 | { | ||
230 | u8 reg_val = mode ? BMA180_LOW_POWER : BMA180_LOW_NOISE; | ||
231 | int ret = bma180_set_bits(data, BMA180_TCO_Z, BMA180_MODE_CONFIG, | ||
232 | reg_val); | ||
233 | |||
234 | if (ret) { | ||
235 | dev_err(&data->client->dev, "failed to set power mode\n"); | ||
236 | return ret; | ||
237 | } | ||
238 | data->pmode = mode; | ||
239 | |||
240 | return 0; | ||
241 | } | ||
242 | |||
243 | static int bma180_soft_reset(struct bma180_data *data) | ||
244 | { | ||
245 | int ret = i2c_smbus_write_byte_data(data->client, | ||
246 | BMA180_RESET, BMA180_RESET_VAL); | ||
247 | |||
248 | if (ret) | ||
249 | dev_err(&data->client->dev, "failed to reset the chip\n"); | ||
250 | |||
251 | return ret; | ||
252 | } | ||
253 | |||
254 | static int bma180_chip_init(struct bma180_data *data) | ||
255 | { | ||
256 | /* Try to read chip_id register. It must return 0x03. */ | ||
257 | int ret = i2c_smbus_read_byte_data(data->client, BMA180_CHIP_ID); | ||
258 | |||
259 | if (ret < 0) | ||
260 | goto err; | ||
261 | if (ret != BMA_180_ID_REG_VAL) { | ||
262 | ret = -ENODEV; | ||
263 | goto err; | ||
264 | } | ||
265 | |||
266 | ret = bma180_soft_reset(data); | ||
267 | if (ret) | ||
268 | goto err; | ||
269 | /* | ||
270 | * No serial transaction should occur within minimum 10 us | ||
271 | * after soft_reset command | ||
272 | */ | ||
273 | msleep(20); | ||
274 | |||
275 | ret = bma180_set_bits(data, BMA180_CTRL_REG0, BMA180_DIS_WAKE_UP, 1); | ||
276 | if (ret) | ||
277 | goto err; | ||
278 | ret = bma180_set_ee_writing_state(data, 1); | ||
279 | if (ret) | ||
280 | goto err; | ||
281 | ret = bma180_set_new_data_intr_state(data, 0); | ||
282 | if (ret) | ||
283 | goto err; | ||
284 | ret = bma180_set_bits(data, BMA180_OFFSET_LSB1, BMA180_SMP_SKIP, 1); | ||
285 | if (ret) | ||
286 | goto err; | ||
287 | ret = bma180_set_pmode(data, BMA180_DEF_PMODE); | ||
288 | if (ret) | ||
289 | goto err; | ||
290 | ret = bma180_set_bw(data, BMA180_DEF_BW); | ||
291 | if (ret) | ||
292 | goto err; | ||
293 | ret = bma180_set_scale(data, BMA180_DEF_SCALE); | ||
294 | if (ret) | ||
295 | goto err; | ||
296 | |||
297 | return 0; | ||
298 | |||
299 | err: | ||
300 | dev_err(&data->client->dev, "failed to init the chip\n"); | ||
301 | return ret; | ||
302 | } | ||
303 | |||
304 | static void bma180_chip_disable(struct bma180_data *data) | ||
305 | { | ||
306 | if (bma180_set_new_data_intr_state(data, 0)) | ||
307 | goto err; | ||
308 | if (bma180_set_ee_writing_state(data, 0)) | ||
309 | goto err; | ||
310 | if (bma180_set_sleep_state(data, 1)) | ||
311 | goto err; | ||
312 | |||
313 | return; | ||
314 | |||
315 | err: | ||
316 | dev_err(&data->client->dev, "failed to disable the chip\n"); | ||
317 | } | ||
318 | |||
319 | static IIO_CONST_ATTR(in_accel_filter_low_pass_3db_frequency_available, | ||
320 | BMA180_FLP_FREQ_AVAILABLE); | ||
321 | static IIO_CONST_ATTR(in_accel_scale_available, BMA180_SCALE_AVAILABLE); | ||
322 | |||
323 | static struct attribute *bma180_attributes[] = { | ||
324 | &iio_const_attr_in_accel_filter_low_pass_3db_frequency_available.dev_attr.attr, | ||
325 | &iio_const_attr_in_accel_scale_available.dev_attr.attr, | ||
326 | NULL, | ||
327 | }; | ||
328 | |||
329 | static const struct attribute_group bma180_attrs_group = { | ||
330 | .attrs = bma180_attributes, | ||
331 | }; | ||
332 | |||
333 | static int bma180_read_raw(struct iio_dev *indio_dev, | ||
334 | struct iio_chan_spec const *chan, int *val, int *val2, | ||
335 | long mask) | ||
336 | { | ||
337 | struct bma180_data *data = iio_priv(indio_dev); | ||
338 | int ret; | ||
339 | |||
340 | switch (mask) { | ||
341 | case IIO_CHAN_INFO_RAW: | ||
342 | mutex_lock(&data->mutex); | ||
343 | if (iio_buffer_enabled(indio_dev)) | ||
344 | ret = -EBUSY; | ||
345 | else | ||
346 | ret = bma180_get_acc_reg(data, chan->scan_index); | ||
347 | mutex_unlock(&data->mutex); | ||
348 | if (ret < 0) | ||
349 | return ret; | ||
350 | *val = (s16)ret >> chan->scan_type.shift; | ||
351 | return IIO_VAL_INT; | ||
352 | case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY: | ||
353 | *val = data->bw; | ||
354 | return IIO_VAL_INT; | ||
355 | case IIO_CHAN_INFO_SCALE: | ||
356 | *val = 0; | ||
357 | *val2 = data->scale; | ||
358 | return IIO_VAL_INT_PLUS_MICRO; | ||
359 | default: | ||
360 | return -EINVAL; | ||
361 | } | ||
362 | } | ||
363 | |||
364 | static int bma180_write_raw(struct iio_dev *indio_dev, | ||
365 | struct iio_chan_spec const *chan, int val, int val2, long mask) | ||
366 | { | ||
367 | struct bma180_data *data = iio_priv(indio_dev); | ||
368 | int ret; | ||
369 | |||
370 | switch (mask) { | ||
371 | case IIO_CHAN_INFO_SCALE: | ||
372 | if (val) | ||
373 | return -EINVAL; | ||
374 | mutex_lock(&data->mutex); | ||
375 | ret = bma180_set_scale(data, val2); | ||
376 | mutex_unlock(&data->mutex); | ||
377 | return ret; | ||
378 | case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY: | ||
379 | mutex_lock(&data->mutex); | ||
380 | ret = bma180_set_bw(data, val); | ||
381 | mutex_unlock(&data->mutex); | ||
382 | return ret; | ||
383 | default: | ||
384 | return -EINVAL; | ||
385 | } | ||
386 | } | ||
387 | |||
388 | static int bma180_update_scan_mode(struct iio_dev *indio_dev, | ||
389 | const unsigned long *scan_mask) | ||
390 | { | ||
391 | struct bma180_data *data = iio_priv(indio_dev); | ||
392 | |||
393 | if (data->buff) | ||
394 | devm_kfree(&indio_dev->dev, data->buff); | ||
395 | data->buff = devm_kzalloc(&indio_dev->dev, | ||
396 | indio_dev->scan_bytes, GFP_KERNEL); | ||
397 | if (!data->buff) | ||
398 | return -ENOMEM; | ||
399 | |||
400 | return 0; | ||
401 | } | ||
402 | |||
403 | static const struct iio_info bma180_info = { | ||
404 | .attrs = &bma180_attrs_group, | ||
405 | .read_raw = bma180_read_raw, | ||
406 | .write_raw = bma180_write_raw, | ||
407 | .update_scan_mode = bma180_update_scan_mode, | ||
408 | .driver_module = THIS_MODULE, | ||
409 | }; | ||
410 | |||
411 | static const char * const bma180_power_modes[] = { | ||
412 | BMA180_LOW_NOISE_STR, | ||
413 | BMA180_LOW_POWER_STR, | ||
414 | }; | ||
415 | |||
416 | static int bma180_get_power_mode(struct iio_dev *indio_dev, | ||
417 | const struct iio_chan_spec *chan) | ||
418 | { | ||
419 | struct bma180_data *data = iio_priv(indio_dev); | ||
420 | |||
421 | return data->pmode; | ||
422 | } | ||
423 | |||
424 | static int bma180_set_power_mode(struct iio_dev *indio_dev, | ||
425 | const struct iio_chan_spec *chan, unsigned int mode) | ||
426 | { | ||
427 | struct bma180_data *data = iio_priv(indio_dev); | ||
428 | int ret; | ||
429 | |||
430 | mutex_lock(&data->mutex); | ||
431 | ret = bma180_set_pmode(data, mode); | ||
432 | mutex_unlock(&data->mutex); | ||
433 | |||
434 | return ret; | ||
435 | } | ||
436 | |||
437 | static const struct iio_enum bma180_power_mode_enum = { | ||
438 | .items = bma180_power_modes, | ||
439 | .num_items = ARRAY_SIZE(bma180_power_modes), | ||
440 | .get = bma180_get_power_mode, | ||
441 | .set = bma180_set_power_mode, | ||
442 | }; | ||
443 | |||
444 | static const struct iio_chan_spec_ext_info bma180_ext_info[] = { | ||
445 | IIO_ENUM("power_mode", true, &bma180_power_mode_enum), | ||
446 | IIO_ENUM_AVAILABLE("power_mode", &bma180_power_mode_enum), | ||
447 | { }, | ||
448 | }; | ||
449 | |||
450 | #define BMA180_CHANNEL(_index) { \ | ||
451 | .type = IIO_ACCEL, \ | ||
452 | .indexed = 1, \ | ||
453 | .channel = (_index), \ | ||
454 | .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | \ | ||
455 | BIT(IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY), \ | ||
456 | .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE), \ | ||
457 | .scan_index = (_index), \ | ||
458 | .scan_type = IIO_ST('s', 14, 16, 2), \ | ||
459 | .ext_info = bma180_ext_info, \ | ||
460 | } | ||
461 | |||
462 | static const struct iio_chan_spec bma180_channels[] = { | ||
463 | BMA180_CHANNEL(AXIS_X), | ||
464 | BMA180_CHANNEL(AXIS_Y), | ||
465 | BMA180_CHANNEL(AXIS_Z), | ||
466 | IIO_CHAN_SOFT_TIMESTAMP(4), | ||
467 | }; | ||
468 | |||
469 | static irqreturn_t bma180_trigger_handler(int irq, void *p) | ||
470 | { | ||
471 | struct iio_poll_func *pf = p; | ||
472 | struct iio_dev *indio_dev = pf->indio_dev; | ||
473 | struct bma180_data *data = iio_priv(indio_dev); | ||
474 | int bit, ret, i = 0; | ||
475 | |||
476 | mutex_lock(&data->mutex); | ||
477 | if (indio_dev->scan_timestamp) { | ||
478 | ret = indio_dev->scan_bytes / sizeof(s64) - 1; | ||
479 | ((s64 *)data->buff)[ret] = iio_get_time_ns(); | ||
480 | } | ||
481 | |||
482 | for_each_set_bit(bit, indio_dev->buffer->scan_mask, | ||
483 | indio_dev->masklength) { | ||
484 | ret = bma180_get_acc_reg(data, bit); | ||
485 | if (ret < 0) { | ||
486 | mutex_unlock(&data->mutex); | ||
487 | goto err; | ||
488 | } | ||
489 | ((s16 *)data->buff)[i++] = ret; | ||
490 | } | ||
491 | mutex_unlock(&data->mutex); | ||
492 | |||
493 | iio_push_to_buffers(indio_dev, (u8 *)data->buff); | ||
494 | err: | ||
495 | iio_trigger_notify_done(indio_dev->trig); | ||
496 | |||
497 | return IRQ_HANDLED; | ||
498 | } | ||
499 | |||
500 | static int bma180_data_rdy_trigger_set_state(struct iio_trigger *trig, | ||
501 | bool state) | ||
502 | { | ||
503 | struct iio_dev *indio_dev = iio_trigger_get_drvdata(trig); | ||
504 | struct bma180_data *data = iio_priv(indio_dev); | ||
505 | |||
506 | return bma180_set_new_data_intr_state(data, state); | ||
507 | } | ||
508 | |||
509 | static int bma180_trig_try_reen(struct iio_trigger *trig) | ||
510 | { | ||
511 | struct iio_dev *indio_dev = iio_trigger_get_drvdata(trig); | ||
512 | struct bma180_data *data = iio_priv(indio_dev); | ||
513 | |||
514 | return bma180_reset_intr(data); | ||
515 | } | ||
516 | |||
517 | static const struct iio_trigger_ops bma180_trigger_ops = { | ||
518 | .set_trigger_state = bma180_data_rdy_trigger_set_state, | ||
519 | .try_reenable = bma180_trig_try_reen, | ||
520 | .owner = THIS_MODULE, | ||
521 | }; | ||
522 | |||
523 | static int bma180_probe(struct i2c_client *client, | ||
524 | const struct i2c_device_id *id) | ||
525 | { | ||
526 | struct bma180_data *data; | ||
527 | struct iio_dev *indio_dev; | ||
528 | struct iio_trigger *trig; | ||
529 | int ret; | ||
530 | |||
531 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*data)); | ||
532 | if (!indio_dev) | ||
533 | return -ENOMEM; | ||
534 | |||
535 | data = iio_priv(indio_dev); | ||
536 | i2c_set_clientdata(client, indio_dev); | ||
537 | data->client = client; | ||
538 | |||
539 | ret = bma180_chip_init(data); | ||
540 | if (ret < 0) | ||
541 | goto err_chip_disable; | ||
542 | |||
543 | mutex_init(&data->mutex); | ||
544 | |||
545 | indio_dev->dev.parent = &client->dev; | ||
546 | indio_dev->channels = bma180_channels; | ||
547 | indio_dev->num_channels = ARRAY_SIZE(bma180_channels); | ||
548 | indio_dev->name = BMA180_DRV_NAME; | ||
549 | indio_dev->modes = INDIO_DIRECT_MODE; | ||
550 | indio_dev->info = &bma180_info; | ||
551 | |||
552 | trig = iio_trigger_alloc("%s-dev%d", indio_dev->name, indio_dev->id); | ||
553 | if (!trig) { | ||
554 | ret = -ENOMEM; | ||
555 | goto err_chip_disable; | ||
556 | } | ||
557 | |||
558 | ret = devm_request_irq(&client->dev, client->irq, | ||
559 | iio_trigger_generic_data_rdy_poll, | ||
560 | IRQF_TRIGGER_RISING, BMA180_IRQ_NAME, trig); | ||
561 | if (ret) { | ||
562 | dev_err(&client->dev, "unable to request IRQ\n"); | ||
563 | goto err_trigger_free; | ||
564 | } | ||
565 | |||
566 | trig->dev.parent = &client->dev; | ||
567 | trig->ops = &bma180_trigger_ops; | ||
568 | iio_trigger_set_drvdata(trig, indio_dev); | ||
569 | data->trig = trig; | ||
570 | indio_dev->trig = trig; | ||
571 | |||
572 | ret = iio_trigger_register(trig); | ||
573 | if (ret) | ||
574 | goto err_trigger_free; | ||
575 | |||
576 | ret = iio_triggered_buffer_setup(indio_dev, NULL, | ||
577 | bma180_trigger_handler, NULL); | ||
578 | if (ret < 0) { | ||
579 | dev_err(&client->dev, "unable to setup iio triggered buffer\n"); | ||
580 | goto err_trigger_unregister; | ||
581 | } | ||
582 | |||
583 | ret = iio_device_register(indio_dev); | ||
584 | if (ret < 0) { | ||
585 | dev_err(&client->dev, "unable to register iio device\n"); | ||
586 | goto err_buffer_cleanup; | ||
587 | } | ||
588 | |||
589 | return 0; | ||
590 | |||
591 | err_buffer_cleanup: | ||
592 | iio_triggered_buffer_cleanup(indio_dev); | ||
593 | err_trigger_unregister: | ||
594 | iio_trigger_unregister(trig); | ||
595 | err_trigger_free: | ||
596 | iio_trigger_free(trig); | ||
597 | err_chip_disable: | ||
598 | bma180_chip_disable(data); | ||
599 | |||
600 | return ret; | ||
601 | } | ||
602 | |||
603 | static int bma180_remove(struct i2c_client *client) | ||
604 | { | ||
605 | struct iio_dev *indio_dev = i2c_get_clientdata(client); | ||
606 | struct bma180_data *data = iio_priv(indio_dev); | ||
607 | |||
608 | iio_device_unregister(indio_dev); | ||
609 | iio_triggered_buffer_cleanup(indio_dev); | ||
610 | iio_trigger_unregister(data->trig); | ||
611 | iio_trigger_free(data->trig); | ||
612 | |||
613 | mutex_lock(&data->mutex); | ||
614 | bma180_chip_disable(data); | ||
615 | mutex_unlock(&data->mutex); | ||
616 | |||
617 | return 0; | ||
618 | } | ||
619 | |||
620 | #ifdef CONFIG_PM_SLEEP | ||
621 | static int bma180_suspend(struct device *dev) | ||
622 | { | ||
623 | struct iio_dev *indio_dev = dev_to_iio_dev(dev); | ||
624 | struct bma180_data *data = iio_priv(indio_dev); | ||
625 | int ret; | ||
626 | |||
627 | mutex_lock(&data->mutex); | ||
628 | ret = bma180_set_sleep_state(data, 1); | ||
629 | mutex_unlock(&data->mutex); | ||
630 | |||
631 | return ret; | ||
632 | } | ||
633 | |||
634 | static int bma180_resume(struct device *dev) | ||
635 | { | ||
636 | struct iio_dev *indio_dev = dev_to_iio_dev(dev); | ||
637 | struct bma180_data *data = iio_priv(indio_dev); | ||
638 | int ret; | ||
639 | |||
640 | mutex_lock(&data->mutex); | ||
641 | ret = bma180_set_sleep_state(data, 0); | ||
642 | mutex_unlock(&data->mutex); | ||
643 | |||
644 | return ret; | ||
645 | } | ||
646 | |||
647 | static SIMPLE_DEV_PM_OPS(bma180_pm_ops, bma180_suspend, bma180_resume); | ||
648 | #define BMA180_PM_OPS (&bma180_pm_ops) | ||
649 | #else | ||
650 | #define BMA180_PM_OPS NULL | ||
651 | #endif | ||
652 | |||
653 | static struct i2c_device_id bma180_id[] = { | ||
654 | { BMA180_DRV_NAME, 0 }, | ||
655 | { } | ||
656 | }; | ||
657 | |||
658 | MODULE_DEVICE_TABLE(i2c, bma180_id); | ||
659 | |||
660 | static struct i2c_driver bma180_driver = { | ||
661 | .driver = { | ||
662 | .name = BMA180_DRV_NAME, | ||
663 | .owner = THIS_MODULE, | ||
664 | .pm = BMA180_PM_OPS, | ||
665 | }, | ||
666 | .probe = bma180_probe, | ||
667 | .remove = bma180_remove, | ||
668 | .id_table = bma180_id, | ||
669 | }; | ||
670 | |||
671 | module_i2c_driver(bma180_driver); | ||
672 | |||
673 | MODULE_AUTHOR("Kravchenko Oleksandr <x0199363@ti.com>"); | ||
674 | MODULE_AUTHOR("Texas Instruments, Inc."); | ||
675 | MODULE_DESCRIPTION("Bosch BMA180 triaxial acceleration sensor"); | ||
676 | MODULE_LICENSE("GPL"); | ||
diff --git a/drivers/iio/accel/hid-sensor-accel-3d.c b/drivers/iio/accel/hid-sensor-accel-3d.c index bbcbd7101f33..46d22f3fb1a9 100644 --- a/drivers/iio/accel/hid-sensor-accel-3d.c +++ b/drivers/iio/accel/hid-sensor-accel-3d.c | |||
@@ -30,10 +30,6 @@ | |||
30 | #include <linux/iio/triggered_buffer.h> | 30 | #include <linux/iio/triggered_buffer.h> |
31 | #include "../common/hid-sensors/hid-sensor-trigger.h" | 31 | #include "../common/hid-sensors/hid-sensor-trigger.h" |
32 | 32 | ||
33 | /*Format: HID-SENSOR-usage_id_in_hex*/ | ||
34 | /*Usage ID from spec for Accelerometer-3D: 0x200073*/ | ||
35 | #define DRIVER_NAME "HID-SENSOR-200073" | ||
36 | |||
37 | enum accel_3d_channel { | 33 | enum accel_3d_channel { |
38 | CHANNEL_SCAN_INDEX_X, | 34 | CHANNEL_SCAN_INDEX_X, |
39 | CHANNEL_SCAN_INDEX_Y, | 35 | CHANNEL_SCAN_INDEX_Y, |
@@ -179,18 +175,10 @@ static int accel_3d_write_raw(struct iio_dev *indio_dev, | |||
179 | return ret; | 175 | return ret; |
180 | } | 176 | } |
181 | 177 | ||
182 | static int accel_3d_write_raw_get_fmt(struct iio_dev *indio_dev, | ||
183 | struct iio_chan_spec const *chan, | ||
184 | long mask) | ||
185 | { | ||
186 | return IIO_VAL_INT_PLUS_MICRO; | ||
187 | } | ||
188 | |||
189 | static const struct iio_info accel_3d_info = { | 178 | static const struct iio_info accel_3d_info = { |
190 | .driver_module = THIS_MODULE, | 179 | .driver_module = THIS_MODULE, |
191 | .read_raw = &accel_3d_read_raw, | 180 | .read_raw = &accel_3d_read_raw, |
192 | .write_raw = &accel_3d_write_raw, | 181 | .write_raw = &accel_3d_write_raw, |
193 | .write_raw_get_fmt = &accel_3d_write_raw_get_fmt, | ||
194 | }; | 182 | }; |
195 | 183 | ||
196 | /* Function to push data to buffer */ | 184 | /* Function to push data to buffer */ |
@@ -286,11 +274,11 @@ static int hid_accel_3d_probe(struct platform_device *pdev) | |||
286 | struct hid_sensor_hub_device *hsdev = pdev->dev.platform_data; | 274 | struct hid_sensor_hub_device *hsdev = pdev->dev.platform_data; |
287 | struct iio_chan_spec *channels; | 275 | struct iio_chan_spec *channels; |
288 | 276 | ||
289 | indio_dev = iio_device_alloc(sizeof(struct accel_3d_state)); | 277 | indio_dev = devm_iio_device_alloc(&pdev->dev, |
290 | if (indio_dev == NULL) { | 278 | sizeof(struct accel_3d_state)); |
291 | ret = -ENOMEM; | 279 | if (indio_dev == NULL) |
292 | goto error_ret; | 280 | return -ENOMEM; |
293 | } | 281 | |
294 | platform_set_drvdata(pdev, indio_dev); | 282 | platform_set_drvdata(pdev, indio_dev); |
295 | 283 | ||
296 | accel_state = iio_priv(indio_dev); | 284 | accel_state = iio_priv(indio_dev); |
@@ -302,15 +290,14 @@ static int hid_accel_3d_probe(struct platform_device *pdev) | |||
302 | &accel_state->common_attributes); | 290 | &accel_state->common_attributes); |
303 | if (ret) { | 291 | if (ret) { |
304 | dev_err(&pdev->dev, "failed to setup common attributes\n"); | 292 | dev_err(&pdev->dev, "failed to setup common attributes\n"); |
305 | goto error_free_dev; | 293 | return ret; |
306 | } | 294 | } |
307 | 295 | ||
308 | channels = kmemdup(accel_3d_channels, sizeof(accel_3d_channels), | 296 | channels = kmemdup(accel_3d_channels, sizeof(accel_3d_channels), |
309 | GFP_KERNEL); | 297 | GFP_KERNEL); |
310 | if (!channels) { | 298 | if (!channels) { |
311 | ret = -ENOMEM; | ||
312 | dev_err(&pdev->dev, "failed to duplicate channels\n"); | 299 | dev_err(&pdev->dev, "failed to duplicate channels\n"); |
313 | goto error_free_dev; | 300 | return -ENOMEM; |
314 | } | 301 | } |
315 | 302 | ||
316 | ret = accel_3d_parse_report(pdev, hsdev, channels, | 303 | ret = accel_3d_parse_report(pdev, hsdev, channels, |
@@ -367,9 +354,6 @@ error_unreg_buffer_funcs: | |||
367 | iio_triggered_buffer_cleanup(indio_dev); | 354 | iio_triggered_buffer_cleanup(indio_dev); |
368 | error_free_dev_mem: | 355 | error_free_dev_mem: |
369 | kfree(indio_dev->channels); | 356 | kfree(indio_dev->channels); |
370 | error_free_dev: | ||
371 | iio_device_free(indio_dev); | ||
372 | error_ret: | ||
373 | return ret; | 357 | return ret; |
374 | } | 358 | } |
375 | 359 | ||
@@ -384,14 +368,23 @@ static int hid_accel_3d_remove(struct platform_device *pdev) | |||
384 | hid_sensor_remove_trigger(indio_dev); | 368 | hid_sensor_remove_trigger(indio_dev); |
385 | iio_triggered_buffer_cleanup(indio_dev); | 369 | iio_triggered_buffer_cleanup(indio_dev); |
386 | kfree(indio_dev->channels); | 370 | kfree(indio_dev->channels); |
387 | iio_device_free(indio_dev); | ||
388 | 371 | ||
389 | return 0; | 372 | return 0; |
390 | } | 373 | } |
391 | 374 | ||
375 | static struct platform_device_id hid_accel_3d_ids[] = { | ||
376 | { | ||
377 | /* Format: HID-SENSOR-usage_id_in_hex_lowercase */ | ||
378 | .name = "HID-SENSOR-200073", | ||
379 | }, | ||
380 | { /* sentinel */ } | ||
381 | }; | ||
382 | MODULE_DEVICE_TABLE(platform, hid_accel_3d_ids); | ||
383 | |||
392 | static struct platform_driver hid_accel_3d_platform_driver = { | 384 | static struct platform_driver hid_accel_3d_platform_driver = { |
385 | .id_table = hid_accel_3d_ids, | ||
393 | .driver = { | 386 | .driver = { |
394 | .name = DRIVER_NAME, | 387 | .name = KBUILD_MODNAME, |
395 | .owner = THIS_MODULE, | 388 | .owner = THIS_MODULE, |
396 | }, | 389 | }, |
397 | .probe = hid_accel_3d_probe, | 390 | .probe = hid_accel_3d_probe, |
diff --git a/drivers/iio/accel/kxsd9.c b/drivers/iio/accel/kxsd9.c index 7229645bf1d7..709c13259f14 100644 --- a/drivers/iio/accel/kxsd9.c +++ b/drivers/iio/accel/kxsd9.c | |||
@@ -224,11 +224,10 @@ static int kxsd9_probe(struct spi_device *spi) | |||
224 | struct kxsd9_state *st; | 224 | struct kxsd9_state *st; |
225 | int ret; | 225 | int ret; |
226 | 226 | ||
227 | indio_dev = iio_device_alloc(sizeof(*st)); | 227 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
228 | if (indio_dev == NULL) { | 228 | if (!indio_dev) |
229 | ret = -ENOMEM; | 229 | return -ENOMEM; |
230 | goto error_ret; | 230 | |
231 | } | ||
232 | st = iio_priv(indio_dev); | 231 | st = iio_priv(indio_dev); |
233 | spi_set_drvdata(spi, indio_dev); | 232 | spi_set_drvdata(spi, indio_dev); |
234 | 233 | ||
@@ -247,20 +246,14 @@ static int kxsd9_probe(struct spi_device *spi) | |||
247 | 246 | ||
248 | ret = iio_device_register(indio_dev); | 247 | ret = iio_device_register(indio_dev); |
249 | if (ret) | 248 | if (ret) |
250 | goto error_free_dev; | 249 | return ret; |
251 | 250 | ||
252 | return 0; | 251 | return 0; |
253 | |||
254 | error_free_dev: | ||
255 | iio_device_free(indio_dev); | ||
256 | error_ret: | ||
257 | return ret; | ||
258 | } | 252 | } |
259 | 253 | ||
260 | static int kxsd9_remove(struct spi_device *spi) | 254 | static int kxsd9_remove(struct spi_device *spi) |
261 | { | 255 | { |
262 | iio_device_unregister(spi_get_drvdata(spi)); | 256 | iio_device_unregister(spi_get_drvdata(spi)); |
263 | iio_device_free(spi_get_drvdata(spi)); | ||
264 | 257 | ||
265 | return 0; | 258 | return 0; |
266 | } | 259 | } |
diff --git a/drivers/iio/accel/st_accel.h b/drivers/iio/accel/st_accel.h index 37949b94377d..c3877630b2e4 100644 --- a/drivers/iio/accel/st_accel.h +++ b/drivers/iio/accel/st_accel.h | |||
@@ -25,7 +25,16 @@ | |||
25 | #define LSM303DLM_ACCEL_DEV_NAME "lsm303dlm_accel" | 25 | #define LSM303DLM_ACCEL_DEV_NAME "lsm303dlm_accel" |
26 | #define LSM330_ACCEL_DEV_NAME "lsm330_accel" | 26 | #define LSM330_ACCEL_DEV_NAME "lsm330_accel" |
27 | 27 | ||
28 | int st_accel_common_probe(struct iio_dev *indio_dev); | 28 | /** |
29 | * struct st_sensors_platform_data - default accel platform data | ||
30 | * @drdy_int_pin: default accel DRDY is available on INT1 pin. | ||
31 | */ | ||
32 | static const struct st_sensors_platform_data default_accel_pdata = { | ||
33 | .drdy_int_pin = 1, | ||
34 | }; | ||
35 | |||
36 | int st_accel_common_probe(struct iio_dev *indio_dev, | ||
37 | struct st_sensors_platform_data *pdata); | ||
29 | void st_accel_common_remove(struct iio_dev *indio_dev); | 38 | void st_accel_common_remove(struct iio_dev *indio_dev); |
30 | 39 | ||
31 | #ifdef CONFIG_IIO_BUFFER | 40 | #ifdef CONFIG_IIO_BUFFER |
diff --git a/drivers/iio/accel/st_accel_core.c b/drivers/iio/accel/st_accel_core.c index 4aec121261d7..1458343f6f3f 100644 --- a/drivers/iio/accel/st_accel_core.c +++ b/drivers/iio/accel/st_accel_core.c | |||
@@ -65,7 +65,8 @@ | |||
65 | #define ST_ACCEL_1_BDU_ADDR 0x23 | 65 | #define ST_ACCEL_1_BDU_ADDR 0x23 |
66 | #define ST_ACCEL_1_BDU_MASK 0x80 | 66 | #define ST_ACCEL_1_BDU_MASK 0x80 |
67 | #define ST_ACCEL_1_DRDY_IRQ_ADDR 0x22 | 67 | #define ST_ACCEL_1_DRDY_IRQ_ADDR 0x22 |
68 | #define ST_ACCEL_1_DRDY_IRQ_MASK 0x10 | 68 | #define ST_ACCEL_1_DRDY_IRQ_INT1_MASK 0x10 |
69 | #define ST_ACCEL_1_DRDY_IRQ_INT2_MASK 0x08 | ||
69 | #define ST_ACCEL_1_MULTIREAD_BIT true | 70 | #define ST_ACCEL_1_MULTIREAD_BIT true |
70 | 71 | ||
71 | /* CUSTOM VALUES FOR SENSOR 2 */ | 72 | /* CUSTOM VALUES FOR SENSOR 2 */ |
@@ -89,7 +90,8 @@ | |||
89 | #define ST_ACCEL_2_BDU_ADDR 0x23 | 90 | #define ST_ACCEL_2_BDU_ADDR 0x23 |
90 | #define ST_ACCEL_2_BDU_MASK 0x80 | 91 | #define ST_ACCEL_2_BDU_MASK 0x80 |
91 | #define ST_ACCEL_2_DRDY_IRQ_ADDR 0x22 | 92 | #define ST_ACCEL_2_DRDY_IRQ_ADDR 0x22 |
92 | #define ST_ACCEL_2_DRDY_IRQ_MASK 0x02 | 93 | #define ST_ACCEL_2_DRDY_IRQ_INT1_MASK 0x02 |
94 | #define ST_ACCEL_2_DRDY_IRQ_INT2_MASK 0x10 | ||
93 | #define ST_ACCEL_2_MULTIREAD_BIT true | 95 | #define ST_ACCEL_2_MULTIREAD_BIT true |
94 | 96 | ||
95 | /* CUSTOM VALUES FOR SENSOR 3 */ | 97 | /* CUSTOM VALUES FOR SENSOR 3 */ |
@@ -121,7 +123,8 @@ | |||
121 | #define ST_ACCEL_3_BDU_ADDR 0x20 | 123 | #define ST_ACCEL_3_BDU_ADDR 0x20 |
122 | #define ST_ACCEL_3_BDU_MASK 0x08 | 124 | #define ST_ACCEL_3_BDU_MASK 0x08 |
123 | #define ST_ACCEL_3_DRDY_IRQ_ADDR 0x23 | 125 | #define ST_ACCEL_3_DRDY_IRQ_ADDR 0x23 |
124 | #define ST_ACCEL_3_DRDY_IRQ_MASK 0x80 | 126 | #define ST_ACCEL_3_DRDY_IRQ_INT1_MASK 0x80 |
127 | #define ST_ACCEL_3_DRDY_IRQ_INT2_MASK 0x00 | ||
125 | #define ST_ACCEL_3_IG1_EN_ADDR 0x23 | 128 | #define ST_ACCEL_3_IG1_EN_ADDR 0x23 |
126 | #define ST_ACCEL_3_IG1_EN_MASK 0x08 | 129 | #define ST_ACCEL_3_IG1_EN_MASK 0x08 |
127 | #define ST_ACCEL_3_MULTIREAD_BIT false | 130 | #define ST_ACCEL_3_MULTIREAD_BIT false |
@@ -224,7 +227,8 @@ static const struct st_sensors st_accel_sensors[] = { | |||
224 | }, | 227 | }, |
225 | .drdy_irq = { | 228 | .drdy_irq = { |
226 | .addr = ST_ACCEL_1_DRDY_IRQ_ADDR, | 229 | .addr = ST_ACCEL_1_DRDY_IRQ_ADDR, |
227 | .mask = ST_ACCEL_1_DRDY_IRQ_MASK, | 230 | .mask_int1 = ST_ACCEL_1_DRDY_IRQ_INT1_MASK, |
231 | .mask_int2 = ST_ACCEL_1_DRDY_IRQ_INT2_MASK, | ||
228 | }, | 232 | }, |
229 | .multi_read_bit = ST_ACCEL_1_MULTIREAD_BIT, | 233 | .multi_read_bit = ST_ACCEL_1_MULTIREAD_BIT, |
230 | .bootime = 2, | 234 | .bootime = 2, |
@@ -285,7 +289,8 @@ static const struct st_sensors st_accel_sensors[] = { | |||
285 | }, | 289 | }, |
286 | .drdy_irq = { | 290 | .drdy_irq = { |
287 | .addr = ST_ACCEL_2_DRDY_IRQ_ADDR, | 291 | .addr = ST_ACCEL_2_DRDY_IRQ_ADDR, |
288 | .mask = ST_ACCEL_2_DRDY_IRQ_MASK, | 292 | .mask_int1 = ST_ACCEL_2_DRDY_IRQ_INT1_MASK, |
293 | .mask_int2 = ST_ACCEL_2_DRDY_IRQ_INT2_MASK, | ||
289 | }, | 294 | }, |
290 | .multi_read_bit = ST_ACCEL_2_MULTIREAD_BIT, | 295 | .multi_read_bit = ST_ACCEL_2_MULTIREAD_BIT, |
291 | .bootime = 2, | 296 | .bootime = 2, |
@@ -358,7 +363,8 @@ static const struct st_sensors st_accel_sensors[] = { | |||
358 | }, | 363 | }, |
359 | .drdy_irq = { | 364 | .drdy_irq = { |
360 | .addr = ST_ACCEL_3_DRDY_IRQ_ADDR, | 365 | .addr = ST_ACCEL_3_DRDY_IRQ_ADDR, |
361 | .mask = ST_ACCEL_3_DRDY_IRQ_MASK, | 366 | .mask_int1 = ST_ACCEL_3_DRDY_IRQ_INT1_MASK, |
367 | .mask_int2 = ST_ACCEL_3_DRDY_IRQ_INT2_MASK, | ||
362 | .ig1 = { | 368 | .ig1 = { |
363 | .en_addr = ST_ACCEL_3_IG1_EN_ADDR, | 369 | .en_addr = ST_ACCEL_3_IG1_EN_ADDR, |
364 | .en_mask = ST_ACCEL_3_IG1_EN_MASK, | 370 | .en_mask = ST_ACCEL_3_IG1_EN_MASK, |
@@ -443,7 +449,8 @@ static const struct iio_trigger_ops st_accel_trigger_ops = { | |||
443 | #define ST_ACCEL_TRIGGER_OPS NULL | 449 | #define ST_ACCEL_TRIGGER_OPS NULL |
444 | #endif | 450 | #endif |
445 | 451 | ||
446 | int st_accel_common_probe(struct iio_dev *indio_dev) | 452 | int st_accel_common_probe(struct iio_dev *indio_dev, |
453 | struct st_sensors_platform_data *plat_data) | ||
447 | { | 454 | { |
448 | int err; | 455 | int err; |
449 | struct st_sensor_data *adata = iio_priv(indio_dev); | 456 | struct st_sensor_data *adata = iio_priv(indio_dev); |
@@ -465,7 +472,11 @@ int st_accel_common_probe(struct iio_dev *indio_dev) | |||
465 | &adata->sensor->fs.fs_avl[0]; | 472 | &adata->sensor->fs.fs_avl[0]; |
466 | adata->odr = adata->sensor->odr.odr_avl[0].hz; | 473 | adata->odr = adata->sensor->odr.odr_avl[0].hz; |
467 | 474 | ||
468 | err = st_sensors_init_sensor(indio_dev); | 475 | if (!plat_data) |
476 | plat_data = | ||
477 | (struct st_sensors_platform_data *)&default_accel_pdata; | ||
478 | |||
479 | err = st_sensors_init_sensor(indio_dev, plat_data); | ||
469 | if (err < 0) | 480 | if (err < 0) |
470 | goto st_accel_common_probe_error; | 481 | goto st_accel_common_probe_error; |
471 | 482 | ||
@@ -506,7 +517,6 @@ void st_accel_common_remove(struct iio_dev *indio_dev) | |||
506 | st_sensors_deallocate_trigger(indio_dev); | 517 | st_sensors_deallocate_trigger(indio_dev); |
507 | st_accel_deallocate_ring(indio_dev); | 518 | st_accel_deallocate_ring(indio_dev); |
508 | } | 519 | } |
509 | iio_device_free(indio_dev); | ||
510 | } | 520 | } |
511 | EXPORT_SYMBOL(st_accel_common_remove); | 521 | EXPORT_SYMBOL(st_accel_common_remove); |
512 | 522 | ||
diff --git a/drivers/iio/accel/st_accel_i2c.c b/drivers/iio/accel/st_accel_i2c.c index ffc9d097e484..d7bedbdfc81d 100644 --- a/drivers/iio/accel/st_accel_i2c.c +++ b/drivers/iio/accel/st_accel_i2c.c | |||
@@ -25,27 +25,20 @@ static int st_accel_i2c_probe(struct i2c_client *client, | |||
25 | struct st_sensor_data *adata; | 25 | struct st_sensor_data *adata; |
26 | int err; | 26 | int err; |
27 | 27 | ||
28 | indio_dev = iio_device_alloc(sizeof(*adata)); | 28 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*adata)); |
29 | if (indio_dev == NULL) { | 29 | if (!indio_dev) |
30 | err = -ENOMEM; | 30 | return -ENOMEM; |
31 | goto iio_device_alloc_error; | ||
32 | } | ||
33 | 31 | ||
34 | adata = iio_priv(indio_dev); | 32 | adata = iio_priv(indio_dev); |
35 | adata->dev = &client->dev; | 33 | adata->dev = &client->dev; |
36 | 34 | ||
37 | st_sensors_i2c_configure(indio_dev, client, adata); | 35 | st_sensors_i2c_configure(indio_dev, client, adata); |
38 | 36 | ||
39 | err = st_accel_common_probe(indio_dev); | 37 | err = st_accel_common_probe(indio_dev, client->dev.platform_data); |
40 | if (err < 0) | 38 | if (err < 0) |
41 | goto st_accel_common_probe_error; | 39 | return err; |
42 | 40 | ||
43 | return 0; | 41 | return 0; |
44 | |||
45 | st_accel_common_probe_error: | ||
46 | iio_device_free(indio_dev); | ||
47 | iio_device_alloc_error: | ||
48 | return err; | ||
49 | } | 42 | } |
50 | 43 | ||
51 | static int st_accel_i2c_remove(struct i2c_client *client) | 44 | static int st_accel_i2c_remove(struct i2c_client *client) |
diff --git a/drivers/iio/accel/st_accel_spi.c b/drivers/iio/accel/st_accel_spi.c index 22b35bfea7d2..195639646e34 100644 --- a/drivers/iio/accel/st_accel_spi.c +++ b/drivers/iio/accel/st_accel_spi.c | |||
@@ -24,27 +24,20 @@ static int st_accel_spi_probe(struct spi_device *spi) | |||
24 | struct st_sensor_data *adata; | 24 | struct st_sensor_data *adata; |
25 | int err; | 25 | int err; |
26 | 26 | ||
27 | indio_dev = iio_device_alloc(sizeof(*adata)); | 27 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*adata)); |
28 | if (indio_dev == NULL) { | 28 | if (!indio_dev) |
29 | err = -ENOMEM; | 29 | return -ENOMEM; |
30 | goto iio_device_alloc_error; | ||
31 | } | ||
32 | 30 | ||
33 | adata = iio_priv(indio_dev); | 31 | adata = iio_priv(indio_dev); |
34 | adata->dev = &spi->dev; | 32 | adata->dev = &spi->dev; |
35 | 33 | ||
36 | st_sensors_spi_configure(indio_dev, spi, adata); | 34 | st_sensors_spi_configure(indio_dev, spi, adata); |
37 | 35 | ||
38 | err = st_accel_common_probe(indio_dev); | 36 | err = st_accel_common_probe(indio_dev, spi->dev.platform_data); |
39 | if (err < 0) | 37 | if (err < 0) |
40 | goto st_accel_common_probe_error; | 38 | return err; |
41 | 39 | ||
42 | return 0; | 40 | return 0; |
43 | |||
44 | st_accel_common_probe_error: | ||
45 | iio_device_free(indio_dev); | ||
46 | iio_device_alloc_error: | ||
47 | return err; | ||
48 | } | 41 | } |
49 | 42 | ||
50 | static int st_accel_spi_remove(struct spi_device *spi) | 43 | static int st_accel_spi_remove(struct spi_device *spi) |
diff --git a/drivers/iio/adc/Kconfig b/drivers/iio/adc/Kconfig index 93129ec4b649..09371cbc9dc1 100644 --- a/drivers/iio/adc/Kconfig +++ b/drivers/iio/adc/Kconfig | |||
@@ -1,6 +1,8 @@ | |||
1 | # | 1 | # |
2 | # ADC drivers | 2 | # ADC drivers |
3 | # | 3 | # |
4 | # When adding new entries keep the list in alphabetical order | ||
5 | |||
4 | menu "Analog to digital converters" | 6 | menu "Analog to digital converters" |
5 | 7 | ||
6 | config AD_SIGMA_DELTA | 8 | config AD_SIGMA_DELTA |
@@ -30,17 +32,20 @@ config AD7298 | |||
30 | To compile this driver as a module, choose M here: the | 32 | To compile this driver as a module, choose M here: the |
31 | module will be called ad7298. | 33 | module will be called ad7298. |
32 | 34 | ||
33 | config AD7923 | 35 | config AD7476 |
34 | tristate "Analog Devices AD7923 and similar ADCs driver" | 36 | tristate "Analog Devices AD7476 and similar 1-channel ADCs driver" |
35 | depends on SPI | 37 | depends on SPI |
36 | select IIO_BUFFER | 38 | select IIO_BUFFER |
37 | select IIO_TRIGGERED_BUFFER | 39 | select IIO_TRIGGERED_BUFFER |
38 | help | 40 | help |
39 | Say yes here to build support for Analog Devices | 41 | Say yes here to build support for Analog Devices AD7273, AD7274, AD7276, |
40 | AD7904, AD7914, AD7923, AD7924 4 Channel ADCs. | 42 | AD7277, AD7278, AD7475, AD7476, AD7477, AD7478, AD7466, AD7467, AD7468, |
43 | AD7495, AD7910, AD7920, AD7920 SPI analog to digital converters (ADC). | ||
44 | |||
45 | If unsure, say N (but it's safe to say "Y"). | ||
41 | 46 | ||
42 | To compile this driver as a module, choose M here: the | 47 | To compile this driver as a module, choose M here: the |
43 | module will be called ad7923. | 48 | module will be called ad7476. |
44 | 49 | ||
45 | config AD7791 | 50 | config AD7791 |
46 | tristate "Analog Devices AD7791 ADC driver" | 51 | tristate "Analog Devices AD7791 ADC driver" |
@@ -66,33 +71,30 @@ config AD7793 | |||
66 | To compile this driver as a module, choose M here: the | 71 | To compile this driver as a module, choose M here: the |
67 | module will be called AD7793. | 72 | module will be called AD7793. |
68 | 73 | ||
69 | config AD7476 | 74 | config AD7887 |
70 | tristate "Analog Devices AD7476 and similar 1-channel ADCs driver" | 75 | tristate "Analog Devices AD7887 ADC driver" |
71 | depends on SPI | 76 | depends on SPI |
72 | select IIO_BUFFER | 77 | select IIO_BUFFER |
73 | select IIO_TRIGGERED_BUFFER | 78 | select IIO_TRIGGERED_BUFFER |
74 | help | 79 | help |
75 | Say yes here to build support for Analog Devices AD7273, AD7274, AD7276, | 80 | Say yes here to build support for Analog Devices |
76 | AD7277, AD7278, AD7475, AD7476, AD7477, AD7478, AD7466, AD7467, AD7468, | 81 | AD7887 SPI analog to digital converter (ADC). |
77 | AD7495, AD7910, AD7920, AD7920 SPI analog to digital converters (ADC). | ||
78 | |||
79 | If unsure, say N (but it's safe to say "Y"). | 82 | If unsure, say N (but it's safe to say "Y"). |
80 | 83 | ||
81 | To compile this driver as a module, choose M here: the | 84 | To compile this driver as a module, choose M here: the |
82 | module will be called ad7476. | 85 | module will be called ad7887. |
83 | 86 | ||
84 | config AD7887 | 87 | config AD7923 |
85 | tristate "Analog Devices AD7887 ADC driver" | 88 | tristate "Analog Devices AD7923 and similar ADCs driver" |
86 | depends on SPI | 89 | depends on SPI |
87 | select IIO_BUFFER | 90 | select IIO_BUFFER |
88 | select IIO_TRIGGERED_BUFFER | 91 | select IIO_TRIGGERED_BUFFER |
89 | help | 92 | help |
90 | Say yes here to build support for Analog Devices | 93 | Say yes here to build support for Analog Devices |
91 | AD7887 SPI analog to digital converter (ADC). | 94 | AD7904, AD7914, AD7923, AD7924 4 Channel ADCs. |
92 | If unsure, say N (but it's safe to say "Y"). | ||
93 | 95 | ||
94 | To compile this driver as a module, choose M here: the | 96 | To compile this driver as a module, choose M here: the |
95 | module will be called ad7887. | 97 | module will be called ad7923. |
96 | 98 | ||
97 | config AT91_ADC | 99 | config AT91_ADC |
98 | tristate "Atmel AT91 ADC" | 100 | tristate "Atmel AT91 ADC" |
@@ -143,6 +145,15 @@ config MCP320X | |||
143 | This driver can also be built as a module. If so, the module will be | 145 | This driver can also be built as a module. If so, the module will be |
144 | called mcp320x. | 146 | called mcp320x. |
145 | 147 | ||
148 | config NAU7802 | ||
149 | tristate "Nuvoton NAU7802 ADC driver" | ||
150 | depends on I2C | ||
151 | help | ||
152 | Say yes here to build support for Nuvoton NAU7802 ADC. | ||
153 | |||
154 | To compile this driver as a module, choose M here: the | ||
155 | module will be called nau7802. | ||
156 | |||
146 | config TI_ADC081C | 157 | config TI_ADC081C |
147 | tristate "Texas Instruments ADC081C021/027" | 158 | tristate "Texas Instruments ADC081C021/027" |
148 | depends on I2C | 159 | depends on I2C |
@@ -154,12 +165,26 @@ config TI_ADC081C | |||
154 | called ti-adc081c. | 165 | called ti-adc081c. |
155 | 166 | ||
156 | config TI_AM335X_ADC | 167 | config TI_AM335X_ADC |
157 | tristate "TI's ADC driver" | 168 | tristate "TI's AM335X ADC driver" |
158 | depends on MFD_TI_AM335X_TSCADC | 169 | depends on MFD_TI_AM335X_TSCADC |
159 | help | 170 | help |
160 | Say yes here to build support for Texas Instruments ADC | 171 | Say yes here to build support for Texas Instruments ADC |
161 | driver which is also a MFD client. | 172 | driver which is also a MFD client. |
162 | 173 | ||
174 | config TWL6030_GPADC | ||
175 | tristate "TWL6030 GPADC (General Purpose A/D Converter) Support" | ||
176 | depends on TWL4030_CORE | ||
177 | default n | ||
178 | help | ||
179 | Say yes here if you want support for the TWL6030/TWL6032 General | ||
180 | Purpose A/D Converter. This will add support for battery type | ||
181 | detection, battery voltage and temperature measurement, die | ||
182 | temperature measurement, system supply voltage, audio accessory, | ||
183 | USB ID detection. | ||
184 | |||
185 | This driver can also be built as a module. If so, the module will be | ||
186 | called twl6030-gpadc. | ||
187 | |||
163 | config VIPERBOARD_ADC | 188 | config VIPERBOARD_ADC |
164 | tristate "Viperboard ADC support" | 189 | tristate "Viperboard ADC support" |
165 | depends on MFD_VIPERBOARD && USB | 190 | depends on MFD_VIPERBOARD && USB |
diff --git a/drivers/iio/adc/Makefile b/drivers/iio/adc/Makefile index 8f475d31fe4d..33656ef7d1f6 100644 --- a/drivers/iio/adc/Makefile +++ b/drivers/iio/adc/Makefile | |||
@@ -2,6 +2,7 @@ | |||
2 | # Makefile for IIO ADC drivers | 2 | # Makefile for IIO ADC drivers |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | obj-$(CONFIG_AD_SIGMA_DELTA) += ad_sigma_delta.o | 6 | obj-$(CONFIG_AD_SIGMA_DELTA) += ad_sigma_delta.o |
6 | obj-$(CONFIG_AD7266) += ad7266.o | 7 | obj-$(CONFIG_AD7266) += ad7266.o |
7 | obj-$(CONFIG_AD7298) += ad7298.o | 8 | obj-$(CONFIG_AD7298) += ad7298.o |
@@ -15,6 +16,8 @@ obj-$(CONFIG_EXYNOS_ADC) += exynos_adc.o | |||
15 | obj-$(CONFIG_LP8788_ADC) += lp8788_adc.o | 16 | obj-$(CONFIG_LP8788_ADC) += lp8788_adc.o |
16 | obj-$(CONFIG_MAX1363) += max1363.o | 17 | obj-$(CONFIG_MAX1363) += max1363.o |
17 | obj-$(CONFIG_MCP320X) += mcp320x.o | 18 | obj-$(CONFIG_MCP320X) += mcp320x.o |
19 | obj-$(CONFIG_NAU7802) += nau7802.o | ||
18 | obj-$(CONFIG_TI_ADC081C) += ti-adc081c.o | 20 | obj-$(CONFIG_TI_ADC081C) += ti-adc081c.o |
19 | obj-$(CONFIG_TI_AM335X_ADC) += ti_am335x_adc.o | 21 | obj-$(CONFIG_TI_AM335X_ADC) += ti_am335x_adc.o |
22 | obj-$(CONFIG_TWL6030_GPADC) += twl6030-gpadc.o | ||
20 | obj-$(CONFIG_VIPERBOARD_ADC) += viperboard_adc.o | 23 | obj-$(CONFIG_VIPERBOARD_ADC) += viperboard_adc.o |
diff --git a/drivers/iio/adc/ad7266.c b/drivers/iio/adc/ad7266.c index c2744a75c3b0..371731df1634 100644 --- a/drivers/iio/adc/ad7266.c +++ b/drivers/iio/adc/ad7266.c | |||
@@ -399,17 +399,17 @@ static int ad7266_probe(struct spi_device *spi) | |||
399 | unsigned int i; | 399 | unsigned int i; |
400 | int ret; | 400 | int ret; |
401 | 401 | ||
402 | indio_dev = iio_device_alloc(sizeof(*st)); | 402 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
403 | if (indio_dev == NULL) | 403 | if (indio_dev == NULL) |
404 | return -ENOMEM; | 404 | return -ENOMEM; |
405 | 405 | ||
406 | st = iio_priv(indio_dev); | 406 | st = iio_priv(indio_dev); |
407 | 407 | ||
408 | st->reg = regulator_get(&spi->dev, "vref"); | 408 | st->reg = devm_regulator_get(&spi->dev, "vref"); |
409 | if (!IS_ERR_OR_NULL(st->reg)) { | 409 | if (!IS_ERR_OR_NULL(st->reg)) { |
410 | ret = regulator_enable(st->reg); | 410 | ret = regulator_enable(st->reg); |
411 | if (ret) | 411 | if (ret) |
412 | goto error_put_reg; | 412 | return ret; |
413 | 413 | ||
414 | ret = regulator_get_voltage(st->reg); | 414 | ret = regulator_get_voltage(st->reg); |
415 | if (ret < 0) | 415 | if (ret < 0) |
@@ -489,11 +489,6 @@ error_free_gpios: | |||
489 | error_disable_reg: | 489 | error_disable_reg: |
490 | if (!IS_ERR_OR_NULL(st->reg)) | 490 | if (!IS_ERR_OR_NULL(st->reg)) |
491 | regulator_disable(st->reg); | 491 | regulator_disable(st->reg); |
492 | error_put_reg: | ||
493 | if (!IS_ERR_OR_NULL(st->reg)) | ||
494 | regulator_put(st->reg); | ||
495 | |||
496 | iio_device_free(indio_dev); | ||
497 | 492 | ||
498 | return ret; | 493 | return ret; |
499 | } | 494 | } |
@@ -507,11 +502,8 @@ static int ad7266_remove(struct spi_device *spi) | |||
507 | iio_triggered_buffer_cleanup(indio_dev); | 502 | iio_triggered_buffer_cleanup(indio_dev); |
508 | if (!st->fixed_addr) | 503 | if (!st->fixed_addr) |
509 | gpio_free_array(st->gpios, ARRAY_SIZE(st->gpios)); | 504 | gpio_free_array(st->gpios, ARRAY_SIZE(st->gpios)); |
510 | if (!IS_ERR_OR_NULL(st->reg)) { | 505 | if (!IS_ERR_OR_NULL(st->reg)) |
511 | regulator_disable(st->reg); | 506 | regulator_disable(st->reg); |
512 | regulator_put(st->reg); | ||
513 | } | ||
514 | iio_device_free(indio_dev); | ||
515 | 507 | ||
516 | return 0; | 508 | return 0; |
517 | } | 509 | } |
diff --git a/drivers/iio/adc/ad7298.c b/drivers/iio/adc/ad7298.c index 03b77189dbfe..85d1481c312f 100644 --- a/drivers/iio/adc/ad7298.c +++ b/drivers/iio/adc/ad7298.c | |||
@@ -296,9 +296,10 @@ static int ad7298_probe(struct spi_device *spi) | |||
296 | { | 296 | { |
297 | struct ad7298_platform_data *pdata = spi->dev.platform_data; | 297 | struct ad7298_platform_data *pdata = spi->dev.platform_data; |
298 | struct ad7298_state *st; | 298 | struct ad7298_state *st; |
299 | struct iio_dev *indio_dev = iio_device_alloc(sizeof(*st)); | 299 | struct iio_dev *indio_dev; |
300 | int ret; | 300 | int ret; |
301 | 301 | ||
302 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); | ||
302 | if (indio_dev == NULL) | 303 | if (indio_dev == NULL) |
303 | return -ENOMEM; | 304 | return -ENOMEM; |
304 | 305 | ||
@@ -308,14 +309,13 @@ static int ad7298_probe(struct spi_device *spi) | |||
308 | st->ext_ref = AD7298_EXTREF; | 309 | st->ext_ref = AD7298_EXTREF; |
309 | 310 | ||
310 | if (st->ext_ref) { | 311 | if (st->ext_ref) { |
311 | st->reg = regulator_get(&spi->dev, "vref"); | 312 | st->reg = devm_regulator_get(&spi->dev, "vref"); |
312 | if (IS_ERR(st->reg)) { | 313 | if (IS_ERR(st->reg)) |
313 | ret = PTR_ERR(st->reg); | 314 | return PTR_ERR(st->reg); |
314 | goto error_free; | 315 | |
315 | } | ||
316 | ret = regulator_enable(st->reg); | 316 | ret = regulator_enable(st->reg); |
317 | if (ret) | 317 | if (ret) |
318 | goto error_put_reg; | 318 | return ret; |
319 | } | 319 | } |
320 | 320 | ||
321 | spi_set_drvdata(spi, indio_dev); | 321 | spi_set_drvdata(spi, indio_dev); |
@@ -361,11 +361,6 @@ error_cleanup_ring: | |||
361 | error_disable_reg: | 361 | error_disable_reg: |
362 | if (st->ext_ref) | 362 | if (st->ext_ref) |
363 | regulator_disable(st->reg); | 363 | regulator_disable(st->reg); |
364 | error_put_reg: | ||
365 | if (st->ext_ref) | ||
366 | regulator_put(st->reg); | ||
367 | error_free: | ||
368 | iio_device_free(indio_dev); | ||
369 | 364 | ||
370 | return ret; | 365 | return ret; |
371 | } | 366 | } |
@@ -377,11 +372,8 @@ static int ad7298_remove(struct spi_device *spi) | |||
377 | 372 | ||
378 | iio_device_unregister(indio_dev); | 373 | iio_device_unregister(indio_dev); |
379 | iio_triggered_buffer_cleanup(indio_dev); | 374 | iio_triggered_buffer_cleanup(indio_dev); |
380 | if (st->ext_ref) { | 375 | if (st->ext_ref) |
381 | regulator_disable(st->reg); | 376 | regulator_disable(st->reg); |
382 | regulator_put(st->reg); | ||
383 | } | ||
384 | iio_device_free(indio_dev); | ||
385 | 377 | ||
386 | return 0; | 378 | return 0; |
387 | } | 379 | } |
diff --git a/drivers/iio/adc/ad7476.c b/drivers/iio/adc/ad7476.c index 2e98bef4af67..6d2b1d8d1a1f 100644 --- a/drivers/iio/adc/ad7476.c +++ b/drivers/iio/adc/ad7476.c | |||
@@ -213,24 +213,21 @@ static int ad7476_probe(struct spi_device *spi) | |||
213 | struct iio_dev *indio_dev; | 213 | struct iio_dev *indio_dev; |
214 | int ret; | 214 | int ret; |
215 | 215 | ||
216 | indio_dev = iio_device_alloc(sizeof(*st)); | 216 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
217 | if (indio_dev == NULL) { | 217 | if (!indio_dev) |
218 | ret = -ENOMEM; | 218 | return -ENOMEM; |
219 | goto error_ret; | 219 | |
220 | } | ||
221 | st = iio_priv(indio_dev); | 220 | st = iio_priv(indio_dev); |
222 | st->chip_info = | 221 | st->chip_info = |
223 | &ad7476_chip_info_tbl[spi_get_device_id(spi)->driver_data]; | 222 | &ad7476_chip_info_tbl[spi_get_device_id(spi)->driver_data]; |
224 | 223 | ||
225 | st->reg = regulator_get(&spi->dev, "vcc"); | 224 | st->reg = devm_regulator_get(&spi->dev, "vcc"); |
226 | if (IS_ERR(st->reg)) { | 225 | if (IS_ERR(st->reg)) |
227 | ret = PTR_ERR(st->reg); | 226 | return PTR_ERR(st->reg); |
228 | goto error_free_dev; | ||
229 | } | ||
230 | 227 | ||
231 | ret = regulator_enable(st->reg); | 228 | ret = regulator_enable(st->reg); |
232 | if (ret) | 229 | if (ret) |
233 | goto error_put_reg; | 230 | return ret; |
234 | 231 | ||
235 | spi_set_drvdata(spi, indio_dev); | 232 | spi_set_drvdata(spi, indio_dev); |
236 | 233 | ||
@@ -268,12 +265,7 @@ error_ring_unregister: | |||
268 | iio_triggered_buffer_cleanup(indio_dev); | 265 | iio_triggered_buffer_cleanup(indio_dev); |
269 | error_disable_reg: | 266 | error_disable_reg: |
270 | regulator_disable(st->reg); | 267 | regulator_disable(st->reg); |
271 | error_put_reg: | ||
272 | regulator_put(st->reg); | ||
273 | error_free_dev: | ||
274 | iio_device_free(indio_dev); | ||
275 | 268 | ||
276 | error_ret: | ||
277 | return ret; | 269 | return ret; |
278 | } | 270 | } |
279 | 271 | ||
@@ -285,8 +277,6 @@ static int ad7476_remove(struct spi_device *spi) | |||
285 | iio_device_unregister(indio_dev); | 277 | iio_device_unregister(indio_dev); |
286 | iio_triggered_buffer_cleanup(indio_dev); | 278 | iio_triggered_buffer_cleanup(indio_dev); |
287 | regulator_disable(st->reg); | 279 | regulator_disable(st->reg); |
288 | regulator_put(st->reg); | ||
289 | iio_device_free(indio_dev); | ||
290 | 280 | ||
291 | return 0; | 281 | return 0; |
292 | } | 282 | } |
diff --git a/drivers/iio/adc/ad7791.c b/drivers/iio/adc/ad7791.c index 5e8d1da6887f..c20203577d2d 100644 --- a/drivers/iio/adc/ad7791.c +++ b/drivers/iio/adc/ad7791.c | |||
@@ -361,21 +361,19 @@ static int ad7791_probe(struct spi_device *spi) | |||
361 | return -ENXIO; | 361 | return -ENXIO; |
362 | } | 362 | } |
363 | 363 | ||
364 | indio_dev = iio_device_alloc(sizeof(*st)); | 364 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
365 | if (!indio_dev) | 365 | if (!indio_dev) |
366 | return -ENOMEM; | 366 | return -ENOMEM; |
367 | 367 | ||
368 | st = iio_priv(indio_dev); | 368 | st = iio_priv(indio_dev); |
369 | 369 | ||
370 | st->reg = regulator_get(&spi->dev, "refin"); | 370 | st->reg = devm_regulator_get(&spi->dev, "refin"); |
371 | if (IS_ERR(st->reg)) { | 371 | if (IS_ERR(st->reg)) |
372 | ret = PTR_ERR(st->reg); | 372 | return PTR_ERR(st->reg); |
373 | goto err_iio_free; | ||
374 | } | ||
375 | 373 | ||
376 | ret = regulator_enable(st->reg); | 374 | ret = regulator_enable(st->reg); |
377 | if (ret) | 375 | if (ret) |
378 | goto error_put_reg; | 376 | return ret; |
379 | 377 | ||
380 | st->info = &ad7791_chip_infos[spi_get_device_id(spi)->driver_data]; | 378 | st->info = &ad7791_chip_infos[spi_get_device_id(spi)->driver_data]; |
381 | ad_sd_init(&st->sd, indio_dev, spi, &ad7791_sigma_delta_info); | 379 | ad_sd_init(&st->sd, indio_dev, spi, &ad7791_sigma_delta_info); |
@@ -410,10 +408,6 @@ error_remove_trigger: | |||
410 | ad_sd_cleanup_buffer_and_trigger(indio_dev); | 408 | ad_sd_cleanup_buffer_and_trigger(indio_dev); |
411 | error_disable_reg: | 409 | error_disable_reg: |
412 | regulator_disable(st->reg); | 410 | regulator_disable(st->reg); |
413 | error_put_reg: | ||
414 | regulator_put(st->reg); | ||
415 | err_iio_free: | ||
416 | iio_device_free(indio_dev); | ||
417 | 411 | ||
418 | return ret; | 412 | return ret; |
419 | } | 413 | } |
@@ -427,9 +421,6 @@ static int ad7791_remove(struct spi_device *spi) | |||
427 | ad_sd_cleanup_buffer_and_trigger(indio_dev); | 421 | ad_sd_cleanup_buffer_and_trigger(indio_dev); |
428 | 422 | ||
429 | regulator_disable(st->reg); | 423 | regulator_disable(st->reg); |
430 | regulator_put(st->reg); | ||
431 | |||
432 | iio_device_free(indio_dev); | ||
433 | 424 | ||
434 | return 0; | 425 | return 0; |
435 | } | 426 | } |
diff --git a/drivers/iio/adc/ad7793.c b/drivers/iio/adc/ad7793.c index 334e31ff7a4e..4dddeabdfbb0 100644 --- a/drivers/iio/adc/ad7793.c +++ b/drivers/iio/adc/ad7793.c | |||
@@ -757,7 +757,7 @@ static int ad7793_probe(struct spi_device *spi) | |||
757 | return -ENODEV; | 757 | return -ENODEV; |
758 | } | 758 | } |
759 | 759 | ||
760 | indio_dev = iio_device_alloc(sizeof(*st)); | 760 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
761 | if (indio_dev == NULL) | 761 | if (indio_dev == NULL) |
762 | return -ENOMEM; | 762 | return -ENOMEM; |
763 | 763 | ||
@@ -766,15 +766,13 @@ static int ad7793_probe(struct spi_device *spi) | |||
766 | ad_sd_init(&st->sd, indio_dev, spi, &ad7793_sigma_delta_info); | 766 | ad_sd_init(&st->sd, indio_dev, spi, &ad7793_sigma_delta_info); |
767 | 767 | ||
768 | if (pdata->refsel != AD7793_REFSEL_INTERNAL) { | 768 | if (pdata->refsel != AD7793_REFSEL_INTERNAL) { |
769 | st->reg = regulator_get(&spi->dev, "refin"); | 769 | st->reg = devm_regulator_get(&spi->dev, "refin"); |
770 | if (IS_ERR(st->reg)) { | 770 | if (IS_ERR(st->reg)) |
771 | ret = PTR_ERR(st->reg); | 771 | return PTR_ERR(st->reg); |
772 | goto error_device_free; | ||
773 | } | ||
774 | 772 | ||
775 | ret = regulator_enable(st->reg); | 773 | ret = regulator_enable(st->reg); |
776 | if (ret) | 774 | if (ret) |
777 | goto error_put_reg; | 775 | return ret; |
778 | 776 | ||
779 | vref_mv = regulator_get_voltage(st->reg); | 777 | vref_mv = regulator_get_voltage(st->reg); |
780 | if (vref_mv < 0) { | 778 | if (vref_mv < 0) { |
@@ -818,11 +816,6 @@ error_remove_trigger: | |||
818 | error_disable_reg: | 816 | error_disable_reg: |
819 | if (pdata->refsel != AD7793_REFSEL_INTERNAL) | 817 | if (pdata->refsel != AD7793_REFSEL_INTERNAL) |
820 | regulator_disable(st->reg); | 818 | regulator_disable(st->reg); |
821 | error_put_reg: | ||
822 | if (pdata->refsel != AD7793_REFSEL_INTERNAL) | ||
823 | regulator_put(st->reg); | ||
824 | error_device_free: | ||
825 | iio_device_free(indio_dev); | ||
826 | 819 | ||
827 | return ret; | 820 | return ret; |
828 | } | 821 | } |
@@ -836,12 +829,8 @@ static int ad7793_remove(struct spi_device *spi) | |||
836 | iio_device_unregister(indio_dev); | 829 | iio_device_unregister(indio_dev); |
837 | ad_sd_cleanup_buffer_and_trigger(indio_dev); | 830 | ad_sd_cleanup_buffer_and_trigger(indio_dev); |
838 | 831 | ||
839 | if (pdata->refsel != AD7793_REFSEL_INTERNAL) { | 832 | if (pdata->refsel != AD7793_REFSEL_INTERNAL) |
840 | regulator_disable(st->reg); | 833 | regulator_disable(st->reg); |
841 | regulator_put(st->reg); | ||
842 | } | ||
843 | |||
844 | iio_device_free(indio_dev); | ||
845 | 834 | ||
846 | return 0; | 835 | return 0; |
847 | } | 836 | } |
diff --git a/drivers/iio/adc/ad7887.c b/drivers/iio/adc/ad7887.c index dd15a5b0f701..9dd077b78759 100644 --- a/drivers/iio/adc/ad7887.c +++ b/drivers/iio/adc/ad7887.c | |||
@@ -237,25 +237,24 @@ static int ad7887_probe(struct spi_device *spi) | |||
237 | { | 237 | { |
238 | struct ad7887_platform_data *pdata = spi->dev.platform_data; | 238 | struct ad7887_platform_data *pdata = spi->dev.platform_data; |
239 | struct ad7887_state *st; | 239 | struct ad7887_state *st; |
240 | struct iio_dev *indio_dev = iio_device_alloc(sizeof(*st)); | 240 | struct iio_dev *indio_dev; |
241 | uint8_t mode; | 241 | uint8_t mode; |
242 | int ret; | 242 | int ret; |
243 | 243 | ||
244 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); | ||
244 | if (indio_dev == NULL) | 245 | if (indio_dev == NULL) |
245 | return -ENOMEM; | 246 | return -ENOMEM; |
246 | 247 | ||
247 | st = iio_priv(indio_dev); | 248 | st = iio_priv(indio_dev); |
248 | 249 | ||
249 | if (!pdata || !pdata->use_onchip_ref) { | 250 | if (!pdata || !pdata->use_onchip_ref) { |
250 | st->reg = regulator_get(&spi->dev, "vref"); | 251 | st->reg = devm_regulator_get(&spi->dev, "vref"); |
251 | if (IS_ERR(st->reg)) { | 252 | if (IS_ERR(st->reg)) |
252 | ret = PTR_ERR(st->reg); | 253 | return PTR_ERR(st->reg); |
253 | goto error_free; | ||
254 | } | ||
255 | 254 | ||
256 | ret = regulator_enable(st->reg); | 255 | ret = regulator_enable(st->reg); |
257 | if (ret) | 256 | if (ret) |
258 | goto error_put_reg; | 257 | return ret; |
259 | } | 258 | } |
260 | 259 | ||
261 | st->chip_info = | 260 | st->chip_info = |
@@ -331,11 +330,6 @@ error_unregister_ring: | |||
331 | error_disable_reg: | 330 | error_disable_reg: |
332 | if (st->reg) | 331 | if (st->reg) |
333 | regulator_disable(st->reg); | 332 | regulator_disable(st->reg); |
334 | error_put_reg: | ||
335 | if (st->reg) | ||
336 | regulator_put(st->reg); | ||
337 | error_free: | ||
338 | iio_device_free(indio_dev); | ||
339 | 333 | ||
340 | return ret; | 334 | return ret; |
341 | } | 335 | } |
@@ -347,11 +341,8 @@ static int ad7887_remove(struct spi_device *spi) | |||
347 | 341 | ||
348 | iio_device_unregister(indio_dev); | 342 | iio_device_unregister(indio_dev); |
349 | iio_triggered_buffer_cleanup(indio_dev); | 343 | iio_triggered_buffer_cleanup(indio_dev); |
350 | if (st->reg) { | 344 | if (st->reg) |
351 | regulator_disable(st->reg); | 345 | regulator_disable(st->reg); |
352 | regulator_put(st->reg); | ||
353 | } | ||
354 | iio_device_free(indio_dev); | ||
355 | 346 | ||
356 | return 0; | 347 | return 0; |
357 | } | 348 | } |
diff --git a/drivers/iio/adc/ad7923.c b/drivers/iio/adc/ad7923.c index 97fa0d3dc4aa..4108dbb28c3d 100644 --- a/drivers/iio/adc/ad7923.c +++ b/drivers/iio/adc/ad7923.c | |||
@@ -275,10 +275,11 @@ static const struct iio_info ad7923_info = { | |||
275 | static int ad7923_probe(struct spi_device *spi) | 275 | static int ad7923_probe(struct spi_device *spi) |
276 | { | 276 | { |
277 | struct ad7923_state *st; | 277 | struct ad7923_state *st; |
278 | struct iio_dev *indio_dev = iio_device_alloc(sizeof(*st)); | 278 | struct iio_dev *indio_dev; |
279 | const struct ad7923_chip_info *info; | 279 | const struct ad7923_chip_info *info; |
280 | int ret; | 280 | int ret; |
281 | 281 | ||
282 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); | ||
282 | if (indio_dev == NULL) | 283 | if (indio_dev == NULL) |
283 | return -ENOMEM; | 284 | return -ENOMEM; |
284 | 285 | ||
@@ -311,14 +312,13 @@ static int ad7923_probe(struct spi_device *spi) | |||
311 | spi_message_add_tail(&st->scan_single_xfer[0], &st->scan_single_msg); | 312 | spi_message_add_tail(&st->scan_single_xfer[0], &st->scan_single_msg); |
312 | spi_message_add_tail(&st->scan_single_xfer[1], &st->scan_single_msg); | 313 | spi_message_add_tail(&st->scan_single_xfer[1], &st->scan_single_msg); |
313 | 314 | ||
314 | st->reg = regulator_get(&spi->dev, "refin"); | 315 | st->reg = devm_regulator_get(&spi->dev, "refin"); |
315 | if (IS_ERR(st->reg)) { | 316 | if (IS_ERR(st->reg)) |
316 | ret = PTR_ERR(st->reg); | 317 | return PTR_ERR(st->reg); |
317 | goto error_free; | 318 | |
318 | } | ||
319 | ret = regulator_enable(st->reg); | 319 | ret = regulator_enable(st->reg); |
320 | if (ret) | 320 | if (ret) |
321 | goto error_put_reg; | 321 | return ret; |
322 | 322 | ||
323 | ret = iio_triggered_buffer_setup(indio_dev, NULL, | 323 | ret = iio_triggered_buffer_setup(indio_dev, NULL, |
324 | &ad7923_trigger_handler, NULL); | 324 | &ad7923_trigger_handler, NULL); |
@@ -335,10 +335,6 @@ error_cleanup_ring: | |||
335 | iio_triggered_buffer_cleanup(indio_dev); | 335 | iio_triggered_buffer_cleanup(indio_dev); |
336 | error_disable_reg: | 336 | error_disable_reg: |
337 | regulator_disable(st->reg); | 337 | regulator_disable(st->reg); |
338 | error_put_reg: | ||
339 | regulator_put(st->reg); | ||
340 | error_free: | ||
341 | iio_device_free(indio_dev); | ||
342 | 338 | ||
343 | return ret; | 339 | return ret; |
344 | } | 340 | } |
@@ -351,8 +347,6 @@ static int ad7923_remove(struct spi_device *spi) | |||
351 | iio_device_unregister(indio_dev); | 347 | iio_device_unregister(indio_dev); |
352 | iio_triggered_buffer_cleanup(indio_dev); | 348 | iio_triggered_buffer_cleanup(indio_dev); |
353 | regulator_disable(st->reg); | 349 | regulator_disable(st->reg); |
354 | regulator_put(st->reg); | ||
355 | iio_device_free(indio_dev); | ||
356 | 350 | ||
357 | return 0; | 351 | return 0; |
358 | } | 352 | } |
diff --git a/drivers/iio/adc/at91_adc.c b/drivers/iio/adc/at91_adc.c index b6db6a0e09cd..84be63bdf038 100644 --- a/drivers/iio/adc/at91_adc.c +++ b/drivers/iio/adc/at91_adc.c | |||
@@ -39,6 +39,10 @@ | |||
39 | #define at91_adc_writel(st, reg, val) \ | 39 | #define at91_adc_writel(st, reg, val) \ |
40 | (writel_relaxed(val, st->reg_base + reg)) | 40 | (writel_relaxed(val, st->reg_base + reg)) |
41 | 41 | ||
42 | struct at91_adc_caps { | ||
43 | struct at91_adc_reg_desc registers; | ||
44 | }; | ||
45 | |||
42 | struct at91_adc_state { | 46 | struct at91_adc_state { |
43 | struct clk *adc_clk; | 47 | struct clk *adc_clk; |
44 | u16 *buffer; | 48 | u16 *buffer; |
@@ -62,6 +66,7 @@ struct at91_adc_state { | |||
62 | u32 res; /* resolution used for convertions */ | 66 | u32 res; /* resolution used for convertions */ |
63 | bool low_res; /* the resolution corresponds to the lowest one */ | 67 | bool low_res; /* the resolution corresponds to the lowest one */ |
64 | wait_queue_head_t wq_data_avail; | 68 | wait_queue_head_t wq_data_avail; |
69 | struct at91_adc_caps *caps; | ||
65 | }; | 70 | }; |
66 | 71 | ||
67 | static irqreturn_t at91_adc_trigger_handler(int irq, void *p) | 72 | static irqreturn_t at91_adc_trigger_handler(int irq, void *p) |
@@ -429,6 +434,8 @@ ret: | |||
429 | return ret; | 434 | return ret; |
430 | } | 435 | } |
431 | 436 | ||
437 | static const struct of_device_id at91_adc_dt_ids[]; | ||
438 | |||
432 | static int at91_adc_probe_dt(struct at91_adc_state *st, | 439 | static int at91_adc_probe_dt(struct at91_adc_state *st, |
433 | struct platform_device *pdev) | 440 | struct platform_device *pdev) |
434 | { | 441 | { |
@@ -441,6 +448,9 @@ static int at91_adc_probe_dt(struct at91_adc_state *st, | |||
441 | if (!node) | 448 | if (!node) |
442 | return -EINVAL; | 449 | return -EINVAL; |
443 | 450 | ||
451 | st->caps = (struct at91_adc_caps *) | ||
452 | of_match_device(at91_adc_dt_ids, &pdev->dev)->data; | ||
453 | |||
444 | st->use_external = of_property_read_bool(node, "atmel,adc-use-external-triggers"); | 454 | st->use_external = of_property_read_bool(node, "atmel,adc-use-external-triggers"); |
445 | 455 | ||
446 | if (of_property_read_u32(node, "atmel,adc-channels-used", &prop)) { | 456 | if (of_property_read_u32(node, "atmel,adc-channels-used", &prop)) { |
@@ -481,43 +491,7 @@ static int at91_adc_probe_dt(struct at91_adc_state *st, | |||
481 | if (ret) | 491 | if (ret) |
482 | goto error_ret; | 492 | goto error_ret; |
483 | 493 | ||
484 | st->registers = devm_kzalloc(&idev->dev, | 494 | st->registers = &st->caps->registers; |
485 | sizeof(struct at91_adc_reg_desc), | ||
486 | GFP_KERNEL); | ||
487 | if (!st->registers) { | ||
488 | dev_err(&idev->dev, "Could not allocate register memory.\n"); | ||
489 | ret = -ENOMEM; | ||
490 | goto error_ret; | ||
491 | } | ||
492 | |||
493 | if (of_property_read_u32(node, "atmel,adc-channel-base", &prop)) { | ||
494 | dev_err(&idev->dev, "Missing adc-channel-base property in the DT.\n"); | ||
495 | ret = -EINVAL; | ||
496 | goto error_ret; | ||
497 | } | ||
498 | st->registers->channel_base = prop; | ||
499 | |||
500 | if (of_property_read_u32(node, "atmel,adc-drdy-mask", &prop)) { | ||
501 | dev_err(&idev->dev, "Missing adc-drdy-mask property in the DT.\n"); | ||
502 | ret = -EINVAL; | ||
503 | goto error_ret; | ||
504 | } | ||
505 | st->registers->drdy_mask = prop; | ||
506 | |||
507 | if (of_property_read_u32(node, "atmel,adc-status-register", &prop)) { | ||
508 | dev_err(&idev->dev, "Missing adc-status-register property in the DT.\n"); | ||
509 | ret = -EINVAL; | ||
510 | goto error_ret; | ||
511 | } | ||
512 | st->registers->status_register = prop; | ||
513 | |||
514 | if (of_property_read_u32(node, "atmel,adc-trigger-register", &prop)) { | ||
515 | dev_err(&idev->dev, "Missing adc-trigger-register property in the DT.\n"); | ||
516 | ret = -EINVAL; | ||
517 | goto error_ret; | ||
518 | } | ||
519 | st->registers->trigger_register = prop; | ||
520 | |||
521 | st->trigger_number = of_get_child_count(node); | 495 | st->trigger_number = of_get_child_count(node); |
522 | st->trigger_list = devm_kzalloc(&idev->dev, st->trigger_number * | 496 | st->trigger_list = devm_kzalloc(&idev->dev, st->trigger_number * |
523 | sizeof(struct at91_adc_trigger), | 497 | sizeof(struct at91_adc_trigger), |
@@ -589,11 +563,9 @@ static int at91_adc_probe(struct platform_device *pdev) | |||
589 | struct resource *res; | 563 | struct resource *res; |
590 | u32 reg; | 564 | u32 reg; |
591 | 565 | ||
592 | idev = iio_device_alloc(sizeof(struct at91_adc_state)); | 566 | idev = devm_iio_device_alloc(&pdev->dev, sizeof(struct at91_adc_state)); |
593 | if (idev == NULL) { | 567 | if (!idev) |
594 | ret = -ENOMEM; | 568 | return -ENOMEM; |
595 | goto error_ret; | ||
596 | } | ||
597 | 569 | ||
598 | st = iio_priv(idev); | 570 | st = iio_priv(idev); |
599 | 571 | ||
@@ -604,8 +576,7 @@ static int at91_adc_probe(struct platform_device *pdev) | |||
604 | 576 | ||
605 | if (ret) { | 577 | if (ret) { |
606 | dev_err(&pdev->dev, "No platform data available.\n"); | 578 | dev_err(&pdev->dev, "No platform data available.\n"); |
607 | ret = -EINVAL; | 579 | return -EINVAL; |
608 | goto error_free_device; | ||
609 | } | 580 | } |
610 | 581 | ||
611 | platform_set_drvdata(pdev, idev); | 582 | platform_set_drvdata(pdev, idev); |
@@ -618,16 +589,14 @@ static int at91_adc_probe(struct platform_device *pdev) | |||
618 | st->irq = platform_get_irq(pdev, 0); | 589 | st->irq = platform_get_irq(pdev, 0); |
619 | if (st->irq < 0) { | 590 | if (st->irq < 0) { |
620 | dev_err(&pdev->dev, "No IRQ ID is designated\n"); | 591 | dev_err(&pdev->dev, "No IRQ ID is designated\n"); |
621 | ret = -ENODEV; | 592 | return -ENODEV; |
622 | goto error_free_device; | ||
623 | } | 593 | } |
624 | 594 | ||
625 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 595 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
626 | 596 | ||
627 | st->reg_base = devm_ioremap_resource(&pdev->dev, res); | 597 | st->reg_base = devm_ioremap_resource(&pdev->dev, res); |
628 | if (IS_ERR(st->reg_base)) { | 598 | if (IS_ERR(st->reg_base)) { |
629 | ret = PTR_ERR(st->reg_base); | 599 | return PTR_ERR(st->reg_base); |
630 | goto error_free_device; | ||
631 | } | 600 | } |
632 | 601 | ||
633 | /* | 602 | /* |
@@ -642,7 +611,7 @@ static int at91_adc_probe(struct platform_device *pdev) | |||
642 | idev); | 611 | idev); |
643 | if (ret) { | 612 | if (ret) { |
644 | dev_err(&pdev->dev, "Failed to allocate IRQ.\n"); | 613 | dev_err(&pdev->dev, "Failed to allocate IRQ.\n"); |
645 | goto error_free_device; | 614 | return ret; |
646 | } | 615 | } |
647 | 616 | ||
648 | st->clk = devm_clk_get(&pdev->dev, "adc_clk"); | 617 | st->clk = devm_clk_get(&pdev->dev, "adc_clk"); |
@@ -703,8 +672,8 @@ static int at91_adc_probe(struct platform_device *pdev) | |||
703 | shtim = round_up((st->sample_hold_time * adc_clk / | 672 | shtim = round_up((st->sample_hold_time * adc_clk / |
704 | 1000000) - 1, 1); | 673 | 1000000) - 1, 1); |
705 | 674 | ||
706 | reg = AT91_ADC_PRESCAL_(prsc) & AT91_ADC_PRESCAL; | 675 | reg = AT91_ADC_PRESCAL_(prsc) & st->registers->mr_prescal_mask; |
707 | reg |= AT91_ADC_STARTUP_(ticks) & AT91_ADC_STARTUP; | 676 | reg |= AT91_ADC_STARTUP_(ticks) & st->registers->mr_startup_mask; |
708 | if (st->low_res) | 677 | if (st->low_res) |
709 | reg |= AT91_ADC_LOWRES; | 678 | reg |= AT91_ADC_LOWRES; |
710 | if (st->sleep_mode) | 679 | if (st->sleep_mode) |
@@ -752,9 +721,6 @@ error_disable_clk: | |||
752 | clk_disable_unprepare(st->clk); | 721 | clk_disable_unprepare(st->clk); |
753 | error_free_irq: | 722 | error_free_irq: |
754 | free_irq(st->irq, idev); | 723 | free_irq(st->irq, idev); |
755 | error_free_device: | ||
756 | iio_device_free(idev); | ||
757 | error_ret: | ||
758 | return ret; | 724 | return ret; |
759 | } | 725 | } |
760 | 726 | ||
@@ -769,14 +735,49 @@ static int at91_adc_remove(struct platform_device *pdev) | |||
769 | clk_disable_unprepare(st->adc_clk); | 735 | clk_disable_unprepare(st->adc_clk); |
770 | clk_disable_unprepare(st->clk); | 736 | clk_disable_unprepare(st->clk); |
771 | free_irq(st->irq, idev); | 737 | free_irq(st->irq, idev); |
772 | iio_device_free(idev); | ||
773 | 738 | ||
774 | return 0; | 739 | return 0; |
775 | } | 740 | } |
776 | 741 | ||
777 | #ifdef CONFIG_OF | 742 | #ifdef CONFIG_OF |
743 | static struct at91_adc_caps at91sam9260_caps = { | ||
744 | .registers = { | ||
745 | .channel_base = AT91_ADC_CHR(0), | ||
746 | .drdy_mask = AT91_ADC_DRDY, | ||
747 | .status_register = AT91_ADC_SR, | ||
748 | .trigger_register = AT91_ADC_TRGR_9260, | ||
749 | .mr_prescal_mask = AT91_ADC_PRESCAL_9260, | ||
750 | .mr_startup_mask = AT91_ADC_STARTUP_9260, | ||
751 | }, | ||
752 | }; | ||
753 | |||
754 | static struct at91_adc_caps at91sam9g45_caps = { | ||
755 | .registers = { | ||
756 | .channel_base = AT91_ADC_CHR(0), | ||
757 | .drdy_mask = AT91_ADC_DRDY, | ||
758 | .status_register = AT91_ADC_SR, | ||
759 | .trigger_register = AT91_ADC_TRGR_9G45, | ||
760 | .mr_prescal_mask = AT91_ADC_PRESCAL_9G45, | ||
761 | .mr_startup_mask = AT91_ADC_STARTUP_9G45, | ||
762 | }, | ||
763 | }; | ||
764 | |||
765 | static struct at91_adc_caps at91sam9x5_caps = { | ||
766 | .registers = { | ||
767 | .channel_base = AT91_ADC_CDR0_9X5, | ||
768 | .drdy_mask = AT91_ADC_SR_DRDY_9X5, | ||
769 | .status_register = AT91_ADC_SR_9X5, | ||
770 | .trigger_register = AT91_ADC_TRGR_9X5, | ||
771 | /* prescal mask is same as 9G45 */ | ||
772 | .mr_prescal_mask = AT91_ADC_PRESCAL_9G45, | ||
773 | .mr_startup_mask = AT91_ADC_STARTUP_9X5, | ||
774 | }, | ||
775 | }; | ||
776 | |||
778 | static const struct of_device_id at91_adc_dt_ids[] = { | 777 | static const struct of_device_id at91_adc_dt_ids[] = { |
779 | { .compatible = "atmel,at91sam9260-adc" }, | 778 | { .compatible = "atmel,at91sam9260-adc", .data = &at91sam9260_caps }, |
779 | { .compatible = "atmel,at91sam9g45-adc", .data = &at91sam9g45_caps }, | ||
780 | { .compatible = "atmel,at91sam9x5-adc", .data = &at91sam9x5_caps }, | ||
780 | {}, | 781 | {}, |
781 | }; | 782 | }; |
782 | MODULE_DEVICE_TABLE(of, at91_adc_dt_ids); | 783 | MODULE_DEVICE_TABLE(of, at91_adc_dt_ids); |
diff --git a/drivers/iio/adc/exynos_adc.c b/drivers/iio/adc/exynos_adc.c index 9809fc9a35d2..d25b262193a7 100644 --- a/drivers/iio/adc/exynos_adc.c +++ b/drivers/iio/adc/exynos_adc.c | |||
@@ -33,6 +33,7 @@ | |||
33 | #include <linux/of_irq.h> | 33 | #include <linux/of_irq.h> |
34 | #include <linux/regulator/consumer.h> | 34 | #include <linux/regulator/consumer.h> |
35 | #include <linux/of_platform.h> | 35 | #include <linux/of_platform.h> |
36 | #include <linux/err.h> | ||
36 | 37 | ||
37 | #include <linux/iio/iio.h> | 38 | #include <linux/iio/iio.h> |
38 | #include <linux/iio/machine.h> | 39 | #include <linux/iio/machine.h> |
@@ -261,7 +262,7 @@ static int exynos_adc_probe(struct platform_device *pdev) | |||
261 | if (!np) | 262 | if (!np) |
262 | return ret; | 263 | return ret; |
263 | 264 | ||
264 | indio_dev = iio_device_alloc(sizeof(struct exynos_adc)); | 265 | indio_dev = devm_iio_device_alloc(&pdev->dev, sizeof(struct exynos_adc)); |
265 | if (!indio_dev) { | 266 | if (!indio_dev) { |
266 | dev_err(&pdev->dev, "failed allocating iio device\n"); | 267 | dev_err(&pdev->dev, "failed allocating iio device\n"); |
267 | return -ENOMEM; | 268 | return -ENOMEM; |
@@ -271,23 +272,18 @@ static int exynos_adc_probe(struct platform_device *pdev) | |||
271 | 272 | ||
272 | mem = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 273 | mem = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
273 | info->regs = devm_ioremap_resource(&pdev->dev, mem); | 274 | info->regs = devm_ioremap_resource(&pdev->dev, mem); |
274 | if (IS_ERR(info->regs)) { | 275 | if (IS_ERR(info->regs)) |
275 | ret = PTR_ERR(info->regs); | 276 | return PTR_ERR(info->regs); |
276 | goto err_iio; | ||
277 | } | ||
278 | 277 | ||
279 | mem = platform_get_resource(pdev, IORESOURCE_MEM, 1); | 278 | mem = platform_get_resource(pdev, IORESOURCE_MEM, 1); |
280 | info->enable_reg = devm_ioremap_resource(&pdev->dev, mem); | 279 | info->enable_reg = devm_ioremap_resource(&pdev->dev, mem); |
281 | if (IS_ERR(info->enable_reg)) { | 280 | if (IS_ERR(info->enable_reg)) |
282 | ret = PTR_ERR(info->enable_reg); | 281 | return PTR_ERR(info->enable_reg); |
283 | goto err_iio; | ||
284 | } | ||
285 | 282 | ||
286 | irq = platform_get_irq(pdev, 0); | 283 | irq = platform_get_irq(pdev, 0); |
287 | if (irq < 0) { | 284 | if (irq < 0) { |
288 | dev_err(&pdev->dev, "no irq resource?\n"); | 285 | dev_err(&pdev->dev, "no irq resource?\n"); |
289 | ret = irq; | 286 | return irq; |
290 | goto err_iio; | ||
291 | } | 287 | } |
292 | 288 | ||
293 | info->irq = irq; | 289 | info->irq = irq; |
@@ -299,7 +295,7 @@ static int exynos_adc_probe(struct platform_device *pdev) | |||
299 | if (ret < 0) { | 295 | if (ret < 0) { |
300 | dev_err(&pdev->dev, "failed requesting irq, irq = %d\n", | 296 | dev_err(&pdev->dev, "failed requesting irq, irq = %d\n", |
301 | info->irq); | 297 | info->irq); |
302 | goto err_iio; | 298 | return ret; |
303 | } | 299 | } |
304 | 300 | ||
305 | writel(1, info->enable_reg); | 301 | writel(1, info->enable_reg); |
@@ -365,8 +361,6 @@ err_iio_dev: | |||
365 | iio_device_unregister(indio_dev); | 361 | iio_device_unregister(indio_dev); |
366 | err_irq: | 362 | err_irq: |
367 | free_irq(info->irq, info); | 363 | free_irq(info->irq, info); |
368 | err_iio: | ||
369 | iio_device_free(indio_dev); | ||
370 | return ret; | 364 | return ret; |
371 | } | 365 | } |
372 | 366 | ||
@@ -382,7 +376,6 @@ static int exynos_adc_remove(struct platform_device *pdev) | |||
382 | writel(0, info->enable_reg); | 376 | writel(0, info->enable_reg); |
383 | iio_device_unregister(indio_dev); | 377 | iio_device_unregister(indio_dev); |
384 | free_irq(info->irq, info); | 378 | free_irq(info->irq, info); |
385 | iio_device_free(indio_dev); | ||
386 | 379 | ||
387 | return 0; | 380 | return 0; |
388 | } | 381 | } |
diff --git a/drivers/iio/adc/lp8788_adc.c b/drivers/iio/adc/lp8788_adc.c index 62bc39e9c94f..5c8c91595f47 100644 --- a/drivers/iio/adc/lp8788_adc.c +++ b/drivers/iio/adc/lp8788_adc.c | |||
@@ -194,7 +194,7 @@ static int lp8788_adc_probe(struct platform_device *pdev) | |||
194 | struct lp8788_adc *adc; | 194 | struct lp8788_adc *adc; |
195 | int ret; | 195 | int ret; |
196 | 196 | ||
197 | indio_dev = iio_device_alloc(sizeof(*adc)); | 197 | indio_dev = devm_iio_device_alloc(&pdev->dev, sizeof(*adc)); |
198 | if (!indio_dev) | 198 | if (!indio_dev) |
199 | return -ENOMEM; | 199 | return -ENOMEM; |
200 | 200 | ||
@@ -205,7 +205,7 @@ static int lp8788_adc_probe(struct platform_device *pdev) | |||
205 | indio_dev->dev.of_node = pdev->dev.of_node; | 205 | indio_dev->dev.of_node = pdev->dev.of_node; |
206 | ret = lp8788_iio_map_register(indio_dev, lp->pdata, adc); | 206 | ret = lp8788_iio_map_register(indio_dev, lp->pdata, adc); |
207 | if (ret) | 207 | if (ret) |
208 | goto err_iio_map; | 208 | return ret; |
209 | 209 | ||
210 | mutex_init(&adc->lock); | 210 | mutex_init(&adc->lock); |
211 | 211 | ||
@@ -226,8 +226,6 @@ static int lp8788_adc_probe(struct platform_device *pdev) | |||
226 | 226 | ||
227 | err_iio_device: | 227 | err_iio_device: |
228 | iio_map_array_unregister(indio_dev); | 228 | iio_map_array_unregister(indio_dev); |
229 | err_iio_map: | ||
230 | iio_device_free(indio_dev); | ||
231 | return ret; | 229 | return ret; |
232 | } | 230 | } |
233 | 231 | ||
@@ -237,7 +235,6 @@ static int lp8788_adc_remove(struct platform_device *pdev) | |||
237 | 235 | ||
238 | iio_device_unregister(indio_dev); | 236 | iio_device_unregister(indio_dev); |
239 | iio_map_array_unregister(indio_dev); | 237 | iio_map_array_unregister(indio_dev); |
240 | iio_device_free(indio_dev); | ||
241 | 238 | ||
242 | return 0; | 239 | return 0; |
243 | } | 240 | } |
diff --git a/drivers/iio/adc/max1363.c b/drivers/iio/adc/max1363.c index f148d00b83f7..4fb35d1d7494 100644 --- a/drivers/iio/adc/max1363.c +++ b/drivers/iio/adc/max1363.c | |||
@@ -1498,16 +1498,15 @@ static int max1363_probe(struct i2c_client *client, | |||
1498 | struct iio_dev *indio_dev; | 1498 | struct iio_dev *indio_dev; |
1499 | struct regulator *vref; | 1499 | struct regulator *vref; |
1500 | 1500 | ||
1501 | indio_dev = iio_device_alloc(sizeof(struct max1363_state)); | 1501 | indio_dev = devm_iio_device_alloc(&client->dev, |
1502 | if (indio_dev == NULL) { | 1502 | sizeof(struct max1363_state)); |
1503 | ret = -ENOMEM; | 1503 | if (!indio_dev) |
1504 | goto error_out; | 1504 | return -ENOMEM; |
1505 | } | ||
1506 | 1505 | ||
1507 | indio_dev->dev.of_node = client->dev.of_node; | 1506 | indio_dev->dev.of_node = client->dev.of_node; |
1508 | ret = iio_map_array_register(indio_dev, client->dev.platform_data); | 1507 | ret = iio_map_array_register(indio_dev, client->dev.platform_data); |
1509 | if (ret < 0) | 1508 | if (ret < 0) |
1510 | goto error_free_device; | 1509 | return ret; |
1511 | 1510 | ||
1512 | st = iio_priv(indio_dev); | 1511 | st = iio_priv(indio_dev); |
1513 | 1512 | ||
@@ -1590,9 +1589,6 @@ error_disable_reg: | |||
1590 | regulator_disable(st->reg); | 1589 | regulator_disable(st->reg); |
1591 | error_unregister_map: | 1590 | error_unregister_map: |
1592 | iio_map_array_unregister(indio_dev); | 1591 | iio_map_array_unregister(indio_dev); |
1593 | error_free_device: | ||
1594 | iio_device_free(indio_dev); | ||
1595 | error_out: | ||
1596 | return ret; | 1592 | return ret; |
1597 | } | 1593 | } |
1598 | 1594 | ||
@@ -1607,7 +1603,6 @@ static int max1363_remove(struct i2c_client *client) | |||
1607 | regulator_disable(st->vref); | 1603 | regulator_disable(st->vref); |
1608 | regulator_disable(st->reg); | 1604 | regulator_disable(st->reg); |
1609 | iio_map_array_unregister(indio_dev); | 1605 | iio_map_array_unregister(indio_dev); |
1610 | iio_device_free(indio_dev); | ||
1611 | 1606 | ||
1612 | return 0; | 1607 | return 0; |
1613 | } | 1608 | } |
diff --git a/drivers/iio/adc/mcp320x.c b/drivers/iio/adc/mcp320x.c index ebc015922a79..28a086e48776 100644 --- a/drivers/iio/adc/mcp320x.c +++ b/drivers/iio/adc/mcp320x.c | |||
@@ -169,7 +169,7 @@ static int mcp320x_probe(struct spi_device *spi) | |||
169 | const struct mcp3208_chip_info *chip_info; | 169 | const struct mcp3208_chip_info *chip_info; |
170 | int ret; | 170 | int ret; |
171 | 171 | ||
172 | indio_dev = iio_device_alloc(sizeof(*adc)); | 172 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*adc)); |
173 | if (!indio_dev) | 173 | if (!indio_dev) |
174 | return -ENOMEM; | 174 | return -ENOMEM; |
175 | 175 | ||
@@ -193,15 +193,13 @@ static int mcp320x_probe(struct spi_device *spi) | |||
193 | spi_message_init_with_transfers(&adc->msg, adc->transfer, | 193 | spi_message_init_with_transfers(&adc->msg, adc->transfer, |
194 | ARRAY_SIZE(adc->transfer)); | 194 | ARRAY_SIZE(adc->transfer)); |
195 | 195 | ||
196 | adc->reg = regulator_get(&spi->dev, "vref"); | 196 | adc->reg = devm_regulator_get(&spi->dev, "vref"); |
197 | if (IS_ERR(adc->reg)) { | 197 | if (IS_ERR(adc->reg)) |
198 | ret = PTR_ERR(adc->reg); | 198 | return PTR_ERR(adc->reg); |
199 | goto iio_free; | ||
200 | } | ||
201 | 199 | ||
202 | ret = regulator_enable(adc->reg); | 200 | ret = regulator_enable(adc->reg); |
203 | if (ret < 0) | 201 | if (ret < 0) |
204 | goto reg_free; | 202 | return ret; |
205 | 203 | ||
206 | mutex_init(&adc->lock); | 204 | mutex_init(&adc->lock); |
207 | 205 | ||
@@ -213,10 +211,6 @@ static int mcp320x_probe(struct spi_device *spi) | |||
213 | 211 | ||
214 | reg_disable: | 212 | reg_disable: |
215 | regulator_disable(adc->reg); | 213 | regulator_disable(adc->reg); |
216 | reg_free: | ||
217 | regulator_put(adc->reg); | ||
218 | iio_free: | ||
219 | iio_device_free(indio_dev); | ||
220 | 214 | ||
221 | return ret; | 215 | return ret; |
222 | } | 216 | } |
@@ -228,8 +222,6 @@ static int mcp320x_remove(struct spi_device *spi) | |||
228 | 222 | ||
229 | iio_device_unregister(indio_dev); | 223 | iio_device_unregister(indio_dev); |
230 | regulator_disable(adc->reg); | 224 | regulator_disable(adc->reg); |
231 | regulator_put(adc->reg); | ||
232 | iio_device_free(indio_dev); | ||
233 | 225 | ||
234 | return 0; | 226 | return 0; |
235 | } | 227 | } |
diff --git a/drivers/iio/adc/nau7802.c b/drivers/iio/adc/nau7802.c new file mode 100644 index 000000000000..bdf03468f3b8 --- /dev/null +++ b/drivers/iio/adc/nau7802.c | |||
@@ -0,0 +1,581 @@ | |||
1 | /* | ||
2 | * Driver for the Nuvoton NAU7802 ADC | ||
3 | * | ||
4 | * Copyright 2013 Free Electrons | ||
5 | * | ||
6 | * Licensed under the GPLv2 or later. | ||
7 | */ | ||
8 | |||
9 | #include <linux/delay.h> | ||
10 | #include <linux/i2c.h> | ||
11 | #include <linux/interrupt.h> | ||
12 | #include <linux/module.h> | ||
13 | #include <linux/wait.h> | ||
14 | #include <linux/log2.h> | ||
15 | |||
16 | #include <linux/iio/iio.h> | ||
17 | #include <linux/iio/sysfs.h> | ||
18 | |||
19 | #define NAU7802_REG_PUCTRL 0x00 | ||
20 | #define NAU7802_PUCTRL_RR(x) (x << 0) | ||
21 | #define NAU7802_PUCTRL_RR_BIT NAU7802_PUCTRL_RR(1) | ||
22 | #define NAU7802_PUCTRL_PUD(x) (x << 1) | ||
23 | #define NAU7802_PUCTRL_PUD_BIT NAU7802_PUCTRL_PUD(1) | ||
24 | #define NAU7802_PUCTRL_PUA(x) (x << 2) | ||
25 | #define NAU7802_PUCTRL_PUA_BIT NAU7802_PUCTRL_PUA(1) | ||
26 | #define NAU7802_PUCTRL_PUR(x) (x << 3) | ||
27 | #define NAU7802_PUCTRL_PUR_BIT NAU7802_PUCTRL_PUR(1) | ||
28 | #define NAU7802_PUCTRL_CS(x) (x << 4) | ||
29 | #define NAU7802_PUCTRL_CS_BIT NAU7802_PUCTRL_CS(1) | ||
30 | #define NAU7802_PUCTRL_CR(x) (x << 5) | ||
31 | #define NAU7802_PUCTRL_CR_BIT NAU7802_PUCTRL_CR(1) | ||
32 | #define NAU7802_PUCTRL_AVDDS(x) (x << 7) | ||
33 | #define NAU7802_PUCTRL_AVDDS_BIT NAU7802_PUCTRL_AVDDS(1) | ||
34 | #define NAU7802_REG_CTRL1 0x01 | ||
35 | #define NAU7802_CTRL1_VLDO(x) (x << 3) | ||
36 | #define NAU7802_CTRL1_GAINS(x) (x) | ||
37 | #define NAU7802_CTRL1_GAINS_BITS 0x07 | ||
38 | #define NAU7802_REG_CTRL2 0x02 | ||
39 | #define NAU7802_CTRL2_CHS(x) (x << 7) | ||
40 | #define NAU7802_CTRL2_CRS(x) (x << 4) | ||
41 | #define NAU7802_SAMP_FREQ_320 0x07 | ||
42 | #define NAU7802_CTRL2_CHS_BIT NAU7802_CTRL2_CHS(1) | ||
43 | #define NAU7802_REG_ADC_B2 0x12 | ||
44 | #define NAU7802_REG_ADC_B1 0x13 | ||
45 | #define NAU7802_REG_ADC_B0 0x14 | ||
46 | #define NAU7802_REG_ADC_CTRL 0x15 | ||
47 | |||
48 | #define NAU7802_MIN_CONVERSIONS 6 | ||
49 | |||
50 | struct nau7802_state { | ||
51 | struct i2c_client *client; | ||
52 | s32 last_value; | ||
53 | struct mutex lock; | ||
54 | struct mutex data_lock; | ||
55 | u32 vref_mv; | ||
56 | u32 conversion_count; | ||
57 | u32 min_conversions; | ||
58 | u8 sample_rate; | ||
59 | u32 scale_avail[8]; | ||
60 | struct completion value_ok; | ||
61 | }; | ||
62 | |||
63 | #define NAU7802_CHANNEL(chan) { \ | ||
64 | .type = IIO_VOLTAGE, \ | ||
65 | .indexed = 1, \ | ||
66 | .channel = (chan), \ | ||
67 | .scan_index = (chan), \ | ||
68 | .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \ | ||
69 | .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) | \ | ||
70 | BIT(IIO_CHAN_INFO_SAMP_FREQ) \ | ||
71 | } | ||
72 | |||
73 | static const struct iio_chan_spec nau7802_chan_array[] = { | ||
74 | NAU7802_CHANNEL(0), | ||
75 | NAU7802_CHANNEL(1), | ||
76 | }; | ||
77 | |||
78 | static const u16 nau7802_sample_freq_avail[] = {10, 20, 40, 80, | ||
79 | 10, 10, 10, 320}; | ||
80 | |||
81 | static IIO_CONST_ATTR_SAMP_FREQ_AVAIL("10 40 80 320"); | ||
82 | |||
83 | static struct attribute *nau7802_attributes[] = { | ||
84 | &iio_const_attr_sampling_frequency_available.dev_attr.attr, | ||
85 | NULL | ||
86 | }; | ||
87 | |||
88 | static const struct attribute_group nau7802_attribute_group = { | ||
89 | .attrs = nau7802_attributes, | ||
90 | }; | ||
91 | |||
92 | static int nau7802_set_gain(struct nau7802_state *st, int gain) | ||
93 | { | ||
94 | int ret; | ||
95 | |||
96 | mutex_lock(&st->lock); | ||
97 | st->conversion_count = 0; | ||
98 | |||
99 | ret = i2c_smbus_read_byte_data(st->client, NAU7802_REG_CTRL1); | ||
100 | if (ret < 0) | ||
101 | goto nau7802_sysfs_set_gain_out; | ||
102 | ret = i2c_smbus_write_byte_data(st->client, NAU7802_REG_CTRL1, | ||
103 | (ret & (~NAU7802_CTRL1_GAINS_BITS)) | | ||
104 | gain); | ||
105 | |||
106 | nau7802_sysfs_set_gain_out: | ||
107 | mutex_unlock(&st->lock); | ||
108 | |||
109 | return ret; | ||
110 | } | ||
111 | |||
112 | static int nau7802_read_conversion(struct nau7802_state *st) | ||
113 | { | ||
114 | int data; | ||
115 | |||
116 | mutex_lock(&st->data_lock); | ||
117 | data = i2c_smbus_read_byte_data(st->client, NAU7802_REG_ADC_B2); | ||
118 | if (data < 0) | ||
119 | goto nau7802_read_conversion_out; | ||
120 | st->last_value = data << 16; | ||
121 | |||
122 | data = i2c_smbus_read_byte_data(st->client, NAU7802_REG_ADC_B1); | ||
123 | if (data < 0) | ||
124 | goto nau7802_read_conversion_out; | ||
125 | st->last_value |= data << 8; | ||
126 | |||
127 | data = i2c_smbus_read_byte_data(st->client, NAU7802_REG_ADC_B0); | ||
128 | if (data < 0) | ||
129 | goto nau7802_read_conversion_out; | ||
130 | st->last_value |= data; | ||
131 | |||
132 | st->last_value = sign_extend32(st->last_value, 23); | ||
133 | |||
134 | nau7802_read_conversion_out: | ||
135 | mutex_unlock(&st->data_lock); | ||
136 | |||
137 | return data; | ||
138 | } | ||
139 | |||
140 | /* | ||
141 | * Conversions are synchronised on the rising edge of NAU7802_PUCTRL_CS_BIT | ||
142 | */ | ||
143 | static int nau7802_sync(struct nau7802_state *st) | ||
144 | { | ||
145 | int ret; | ||
146 | |||
147 | ret = i2c_smbus_read_byte_data(st->client, NAU7802_REG_PUCTRL); | ||
148 | if (ret < 0) | ||
149 | return ret; | ||
150 | ret = i2c_smbus_write_byte_data(st->client, NAU7802_REG_PUCTRL, | ||
151 | ret | NAU7802_PUCTRL_CS_BIT); | ||
152 | |||
153 | return ret; | ||
154 | } | ||
155 | |||
156 | static irqreturn_t nau7802_eoc_trigger(int irq, void *private) | ||
157 | { | ||
158 | struct iio_dev *indio_dev = private; | ||
159 | struct nau7802_state *st = iio_priv(indio_dev); | ||
160 | int status; | ||
161 | |||
162 | status = i2c_smbus_read_byte_data(st->client, NAU7802_REG_PUCTRL); | ||
163 | if (status < 0) | ||
164 | return IRQ_HANDLED; | ||
165 | |||
166 | if (!(status & NAU7802_PUCTRL_CR_BIT)) | ||
167 | return IRQ_NONE; | ||
168 | |||
169 | if (nau7802_read_conversion(st) < 0) | ||
170 | return IRQ_HANDLED; | ||
171 | |||
172 | /* | ||
173 | * Because there is actually only one ADC for both channels, we have to | ||
174 | * wait for enough conversions to happen before getting a significant | ||
175 | * value when changing channels and the values are far apart. | ||
176 | */ | ||
177 | if (st->conversion_count < NAU7802_MIN_CONVERSIONS) | ||
178 | st->conversion_count++; | ||
179 | if (st->conversion_count >= NAU7802_MIN_CONVERSIONS) | ||
180 | complete_all(&st->value_ok); | ||
181 | |||
182 | return IRQ_HANDLED; | ||
183 | } | ||
184 | |||
185 | static int nau7802_read_irq(struct iio_dev *indio_dev, | ||
186 | struct iio_chan_spec const *chan, | ||
187 | int *val) | ||
188 | { | ||
189 | struct nau7802_state *st = iio_priv(indio_dev); | ||
190 | int ret; | ||
191 | |||
192 | INIT_COMPLETION(st->value_ok); | ||
193 | enable_irq(st->client->irq); | ||
194 | |||
195 | nau7802_sync(st); | ||
196 | |||
197 | /* read registers to ensure we flush everything */ | ||
198 | ret = nau7802_read_conversion(st); | ||
199 | if (ret < 0) | ||
200 | goto read_chan_info_failure; | ||
201 | |||
202 | /* Wait for a conversion to finish */ | ||
203 | ret = wait_for_completion_interruptible_timeout(&st->value_ok, | ||
204 | msecs_to_jiffies(1000)); | ||
205 | if (ret == 0) | ||
206 | ret = -ETIMEDOUT; | ||
207 | |||
208 | if (ret < 0) | ||
209 | goto read_chan_info_failure; | ||
210 | |||
211 | disable_irq(st->client->irq); | ||
212 | |||
213 | *val = st->last_value; | ||
214 | |||
215 | return IIO_VAL_INT; | ||
216 | |||
217 | read_chan_info_failure: | ||
218 | disable_irq(st->client->irq); | ||
219 | |||
220 | return ret; | ||
221 | } | ||
222 | |||
223 | static int nau7802_read_poll(struct iio_dev *indio_dev, | ||
224 | struct iio_chan_spec const *chan, | ||
225 | int *val) | ||
226 | { | ||
227 | struct nau7802_state *st = iio_priv(indio_dev); | ||
228 | int ret; | ||
229 | |||
230 | nau7802_sync(st); | ||
231 | |||
232 | /* read registers to ensure we flush everything */ | ||
233 | ret = nau7802_read_conversion(st); | ||
234 | if (ret < 0) | ||
235 | return ret; | ||
236 | |||
237 | /* | ||
238 | * Because there is actually only one ADC for both channels, we have to | ||
239 | * wait for enough conversions to happen before getting a significant | ||
240 | * value when changing channels and the values are far appart. | ||
241 | */ | ||
242 | do { | ||
243 | ret = i2c_smbus_read_byte_data(st->client, NAU7802_REG_PUCTRL); | ||
244 | if (ret < 0) | ||
245 | return ret; | ||
246 | |||
247 | while (!(ret & NAU7802_PUCTRL_CR_BIT)) { | ||
248 | if (st->sample_rate != NAU7802_SAMP_FREQ_320) | ||
249 | msleep(20); | ||
250 | else | ||
251 | mdelay(4); | ||
252 | ret = i2c_smbus_read_byte_data(st->client, | ||
253 | NAU7802_REG_PUCTRL); | ||
254 | if (ret < 0) | ||
255 | return ret; | ||
256 | } | ||
257 | |||
258 | ret = nau7802_read_conversion(st); | ||
259 | if (ret < 0) | ||
260 | return ret; | ||
261 | if (st->conversion_count < NAU7802_MIN_CONVERSIONS) | ||
262 | st->conversion_count++; | ||
263 | } while (st->conversion_count < NAU7802_MIN_CONVERSIONS); | ||
264 | |||
265 | *val = st->last_value; | ||
266 | |||
267 | return IIO_VAL_INT; | ||
268 | } | ||
269 | |||
270 | static int nau7802_read_raw(struct iio_dev *indio_dev, | ||
271 | struct iio_chan_spec const *chan, | ||
272 | int *val, int *val2, long mask) | ||
273 | { | ||
274 | struct nau7802_state *st = iio_priv(indio_dev); | ||
275 | int ret; | ||
276 | |||
277 | switch (mask) { | ||
278 | case IIO_CHAN_INFO_RAW: | ||
279 | mutex_lock(&st->lock); | ||
280 | /* | ||
281 | * Select the channel to use | ||
282 | * - Channel 1 is value 0 in the CHS register | ||
283 | * - Channel 2 is value 1 in the CHS register | ||
284 | */ | ||
285 | ret = i2c_smbus_read_byte_data(st->client, NAU7802_REG_CTRL2); | ||
286 | if (ret < 0) { | ||
287 | mutex_unlock(&st->lock); | ||
288 | return ret; | ||
289 | } | ||
290 | |||
291 | if (((ret & NAU7802_CTRL2_CHS_BIT) && !chan->channel) || | ||
292 | (!(ret & NAU7802_CTRL2_CHS_BIT) && | ||
293 | chan->channel)) { | ||
294 | st->conversion_count = 0; | ||
295 | ret = i2c_smbus_write_byte_data(st->client, | ||
296 | NAU7802_REG_CTRL2, | ||
297 | NAU7802_CTRL2_CHS(chan->channel) | | ||
298 | NAU7802_CTRL2_CRS(st->sample_rate)); | ||
299 | |||
300 | if (ret < 0) { | ||
301 | mutex_unlock(&st->lock); | ||
302 | return ret; | ||
303 | } | ||
304 | } | ||
305 | |||
306 | if (st->client->irq) | ||
307 | ret = nau7802_read_irq(indio_dev, chan, val); | ||
308 | else | ||
309 | ret = nau7802_read_poll(indio_dev, chan, val); | ||
310 | |||
311 | mutex_unlock(&st->lock); | ||
312 | return ret; | ||
313 | |||
314 | case IIO_CHAN_INFO_SCALE: | ||
315 | ret = i2c_smbus_read_byte_data(st->client, NAU7802_REG_CTRL1); | ||
316 | if (ret < 0) | ||
317 | return ret; | ||
318 | |||
319 | /* | ||
320 | * We have 24 bits of signed data, that means 23 bits of data | ||
321 | * plus the sign bit | ||
322 | */ | ||
323 | *val = st->vref_mv; | ||
324 | *val2 = 23 + (ret & NAU7802_CTRL1_GAINS_BITS); | ||
325 | |||
326 | return IIO_VAL_FRACTIONAL_LOG2; | ||
327 | |||
328 | case IIO_CHAN_INFO_SAMP_FREQ: | ||
329 | *val = nau7802_sample_freq_avail[st->sample_rate]; | ||
330 | *val2 = 0; | ||
331 | return IIO_VAL_INT; | ||
332 | |||
333 | default: | ||
334 | break; | ||
335 | } | ||
336 | |||
337 | return -EINVAL; | ||
338 | } | ||
339 | |||
340 | static int nau7802_write_raw(struct iio_dev *indio_dev, | ||
341 | struct iio_chan_spec const *chan, | ||
342 | int val, int val2, long mask) | ||
343 | { | ||
344 | struct nau7802_state *st = iio_priv(indio_dev); | ||
345 | int i, ret; | ||
346 | |||
347 | switch (mask) { | ||
348 | case IIO_CHAN_INFO_SCALE: | ||
349 | for (i = 0; i < ARRAY_SIZE(st->scale_avail); i++) | ||
350 | if (val2 == st->scale_avail[i]) | ||
351 | return nau7802_set_gain(st, i); | ||
352 | |||
353 | break; | ||
354 | |||
355 | case IIO_CHAN_INFO_SAMP_FREQ: | ||
356 | for (i = 0; i < ARRAY_SIZE(nau7802_sample_freq_avail); i++) | ||
357 | if (val == nau7802_sample_freq_avail[i]) { | ||
358 | mutex_lock(&st->lock); | ||
359 | st->sample_rate = i; | ||
360 | st->conversion_count = 0; | ||
361 | ret = i2c_smbus_write_byte_data(st->client, | ||
362 | NAU7802_REG_CTRL2, | ||
363 | NAU7802_CTRL2_CRS(st->sample_rate)); | ||
364 | mutex_unlock(&st->lock); | ||
365 | return ret; | ||
366 | } | ||
367 | |||
368 | break; | ||
369 | |||
370 | default: | ||
371 | break; | ||
372 | } | ||
373 | |||
374 | return -EINVAL; | ||
375 | } | ||
376 | |||
377 | static int nau7802_write_raw_get_fmt(struct iio_dev *indio_dev, | ||
378 | struct iio_chan_spec const *chan, | ||
379 | long mask) | ||
380 | { | ||
381 | return IIO_VAL_INT_PLUS_NANO; | ||
382 | } | ||
383 | |||
384 | static const struct iio_info nau7802_info = { | ||
385 | .driver_module = THIS_MODULE, | ||
386 | .read_raw = &nau7802_read_raw, | ||
387 | .write_raw = &nau7802_write_raw, | ||
388 | .write_raw_get_fmt = nau7802_write_raw_get_fmt, | ||
389 | .attrs = &nau7802_attribute_group, | ||
390 | }; | ||
391 | |||
392 | static int nau7802_probe(struct i2c_client *client, | ||
393 | const struct i2c_device_id *id) | ||
394 | { | ||
395 | struct iio_dev *indio_dev; | ||
396 | struct nau7802_state *st; | ||
397 | struct device_node *np = client->dev.of_node; | ||
398 | int i, ret; | ||
399 | u8 data; | ||
400 | u32 tmp = 0; | ||
401 | |||
402 | if (!client->dev.of_node) { | ||
403 | dev_err(&client->dev, "No device tree node available.\n"); | ||
404 | return -EINVAL; | ||
405 | } | ||
406 | |||
407 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*st)); | ||
408 | if (indio_dev == NULL) | ||
409 | return -ENOMEM; | ||
410 | |||
411 | st = iio_priv(indio_dev); | ||
412 | |||
413 | i2c_set_clientdata(client, indio_dev); | ||
414 | |||
415 | indio_dev->dev.parent = &client->dev; | ||
416 | indio_dev->name = dev_name(&client->dev); | ||
417 | indio_dev->modes = INDIO_DIRECT_MODE; | ||
418 | indio_dev->info = &nau7802_info; | ||
419 | |||
420 | st->client = client; | ||
421 | |||
422 | /* Reset the device */ | ||
423 | ret = i2c_smbus_write_byte_data(st->client, NAU7802_REG_PUCTRL, | ||
424 | NAU7802_PUCTRL_RR_BIT); | ||
425 | if (ret < 0) | ||
426 | return ret; | ||
427 | |||
428 | /* Enter normal operation mode */ | ||
429 | ret = i2c_smbus_write_byte_data(st->client, NAU7802_REG_PUCTRL, | ||
430 | NAU7802_PUCTRL_PUD_BIT); | ||
431 | if (ret < 0) | ||
432 | return ret; | ||
433 | |||
434 | /* | ||
435 | * After about 200 usecs, the device should be ready and then | ||
436 | * the Power Up bit will be set to 1. If not, wait for it. | ||
437 | */ | ||
438 | udelay(210); | ||
439 | ret = i2c_smbus_read_byte_data(st->client, NAU7802_REG_PUCTRL); | ||
440 | if (ret < 0) | ||
441 | return ret; | ||
442 | if (!(ret & NAU7802_PUCTRL_PUR_BIT)) | ||
443 | return ret; | ||
444 | |||
445 | of_property_read_u32(np, "nuvoton,vldo", &tmp); | ||
446 | st->vref_mv = tmp; | ||
447 | |||
448 | data = NAU7802_PUCTRL_PUD_BIT | NAU7802_PUCTRL_PUA_BIT | | ||
449 | NAU7802_PUCTRL_CS_BIT; | ||
450 | if (tmp >= 2400) | ||
451 | data |= NAU7802_PUCTRL_AVDDS_BIT; | ||
452 | |||
453 | ret = i2c_smbus_write_byte_data(st->client, NAU7802_REG_PUCTRL, data); | ||
454 | if (ret < 0) | ||
455 | return ret; | ||
456 | ret = i2c_smbus_write_byte_data(st->client, NAU7802_REG_ADC_CTRL, 0x30); | ||
457 | if (ret < 0) | ||
458 | return ret; | ||
459 | |||
460 | if (tmp >= 2400) { | ||
461 | data = NAU7802_CTRL1_VLDO((4500 - tmp) / 300); | ||
462 | ret = i2c_smbus_write_byte_data(st->client, NAU7802_REG_CTRL1, | ||
463 | data); | ||
464 | if (ret < 0) | ||
465 | return ret; | ||
466 | } | ||
467 | |||
468 | /* Populate available ADC input ranges */ | ||
469 | for (i = 0; i < ARRAY_SIZE(st->scale_avail); i++) | ||
470 | st->scale_avail[i] = (((u64)st->vref_mv) * 1000000000ULL) | ||
471 | >> (23 + i); | ||
472 | |||
473 | init_completion(&st->value_ok); | ||
474 | |||
475 | /* | ||
476 | * The ADC fires continuously and we can't do anything about | ||
477 | * it. So we need to have the IRQ disabled by default, and we | ||
478 | * will enable them back when we will need them.. | ||
479 | */ | ||
480 | if (client->irq) { | ||
481 | ret = request_threaded_irq(client->irq, | ||
482 | NULL, | ||
483 | nau7802_eoc_trigger, | ||
484 | IRQF_TRIGGER_HIGH | IRQF_ONESHOT, | ||
485 | client->dev.driver->name, | ||
486 | indio_dev); | ||
487 | if (ret) { | ||
488 | /* | ||
489 | * What may happen here is that our IRQ controller is | ||
490 | * not able to get level interrupt but this is required | ||
491 | * by this ADC as when going over 40 sample per second, | ||
492 | * the interrupt line may stay high between conversions. | ||
493 | * So, we continue no matter what but we switch to | ||
494 | * polling mode. | ||
495 | */ | ||
496 | dev_info(&client->dev, | ||
497 | "Failed to allocate IRQ, using polling mode\n"); | ||
498 | client->irq = 0; | ||
499 | } else | ||
500 | disable_irq(client->irq); | ||
501 | } | ||
502 | |||
503 | if (!client->irq) { | ||
504 | /* | ||
505 | * We are polling, use the fastest sample rate by | ||
506 | * default | ||
507 | */ | ||
508 | st->sample_rate = NAU7802_SAMP_FREQ_320; | ||
509 | ret = i2c_smbus_write_byte_data(st->client, NAU7802_REG_CTRL2, | ||
510 | NAU7802_CTRL2_CRS(st->sample_rate)); | ||
511 | if (ret) | ||
512 | goto error_free_irq; | ||
513 | } | ||
514 | |||
515 | /* Setup the ADC channels available on the board */ | ||
516 | indio_dev->num_channels = ARRAY_SIZE(nau7802_chan_array); | ||
517 | indio_dev->channels = nau7802_chan_array; | ||
518 | |||
519 | mutex_init(&st->lock); | ||
520 | mutex_init(&st->data_lock); | ||
521 | |||
522 | ret = iio_device_register(indio_dev); | ||
523 | if (ret < 0) { | ||
524 | dev_err(&client->dev, "Couldn't register the device.\n"); | ||
525 | goto error_device_register; | ||
526 | } | ||
527 | |||
528 | return 0; | ||
529 | |||
530 | error_device_register: | ||
531 | mutex_destroy(&st->lock); | ||
532 | mutex_destroy(&st->data_lock); | ||
533 | error_free_irq: | ||
534 | if (client->irq) | ||
535 | free_irq(client->irq, indio_dev); | ||
536 | |||
537 | return ret; | ||
538 | } | ||
539 | |||
540 | static int nau7802_remove(struct i2c_client *client) | ||
541 | { | ||
542 | struct iio_dev *indio_dev = i2c_get_clientdata(client); | ||
543 | struct nau7802_state *st = iio_priv(indio_dev); | ||
544 | |||
545 | iio_device_unregister(indio_dev); | ||
546 | mutex_destroy(&st->lock); | ||
547 | mutex_destroy(&st->data_lock); | ||
548 | if (client->irq) | ||
549 | free_irq(client->irq, indio_dev); | ||
550 | |||
551 | return 0; | ||
552 | } | ||
553 | |||
554 | static const struct i2c_device_id nau7802_i2c_id[] = { | ||
555 | { "nau7802", 0 }, | ||
556 | { } | ||
557 | }; | ||
558 | MODULE_DEVICE_TABLE(i2c, nau7802_i2c_id); | ||
559 | |||
560 | static const struct of_device_id nau7802_dt_ids[] = { | ||
561 | { .compatible = "nuvoton,nau7802" }, | ||
562 | {}, | ||
563 | }; | ||
564 | MODULE_DEVICE_TABLE(of, nau7802_dt_ids); | ||
565 | |||
566 | static struct i2c_driver nau7802_driver = { | ||
567 | .probe = nau7802_probe, | ||
568 | .remove = nau7802_remove, | ||
569 | .id_table = nau7802_i2c_id, | ||
570 | .driver = { | ||
571 | .name = "nau7802", | ||
572 | .of_match_table = of_match_ptr(nau7802_dt_ids), | ||
573 | }, | ||
574 | }; | ||
575 | |||
576 | module_i2c_driver(nau7802_driver); | ||
577 | |||
578 | MODULE_LICENSE("GPL"); | ||
579 | MODULE_DESCRIPTION("Nuvoton NAU7802 ADC Driver"); | ||
580 | MODULE_AUTHOR("Maxime Ripard <maxime.ripard@free-electrons.com>"); | ||
581 | MODULE_AUTHOR("Alexandre Belloni <alexandre.belloni@free-electrons.com>"); | ||
diff --git a/drivers/iio/adc/ti-adc081c.c b/drivers/iio/adc/ti-adc081c.c index 2826faae706c..ee5f72bffe5a 100644 --- a/drivers/iio/adc/ti-adc081c.c +++ b/drivers/iio/adc/ti-adc081c.c | |||
@@ -74,22 +74,20 @@ static int adc081c_probe(struct i2c_client *client, | |||
74 | if (!i2c_check_functionality(client->adapter, I2C_FUNC_SMBUS_WORD_DATA)) | 74 | if (!i2c_check_functionality(client->adapter, I2C_FUNC_SMBUS_WORD_DATA)) |
75 | return -ENODEV; | 75 | return -ENODEV; |
76 | 76 | ||
77 | iio = iio_device_alloc(sizeof(*adc)); | 77 | iio = devm_iio_device_alloc(&client->dev, sizeof(*adc)); |
78 | if (!iio) | 78 | if (!iio) |
79 | return -ENOMEM; | 79 | return -ENOMEM; |
80 | 80 | ||
81 | adc = iio_priv(iio); | 81 | adc = iio_priv(iio); |
82 | adc->i2c = client; | 82 | adc->i2c = client; |
83 | 83 | ||
84 | adc->ref = regulator_get(&client->dev, "vref"); | 84 | adc->ref = devm_regulator_get(&client->dev, "vref"); |
85 | if (IS_ERR(adc->ref)) { | 85 | if (IS_ERR(adc->ref)) |
86 | err = PTR_ERR(adc->ref); | 86 | return PTR_ERR(adc->ref); |
87 | goto iio_free; | ||
88 | } | ||
89 | 87 | ||
90 | err = regulator_enable(adc->ref); | 88 | err = regulator_enable(adc->ref); |
91 | if (err < 0) | 89 | if (err < 0) |
92 | goto regulator_put; | 90 | return err; |
93 | 91 | ||
94 | iio->dev.parent = &client->dev; | 92 | iio->dev.parent = &client->dev; |
95 | iio->name = dev_name(&client->dev); | 93 | iio->name = dev_name(&client->dev); |
@@ -109,10 +107,6 @@ static int adc081c_probe(struct i2c_client *client, | |||
109 | 107 | ||
110 | regulator_disable: | 108 | regulator_disable: |
111 | regulator_disable(adc->ref); | 109 | regulator_disable(adc->ref); |
112 | regulator_put: | ||
113 | regulator_put(adc->ref); | ||
114 | iio_free: | ||
115 | iio_device_free(iio); | ||
116 | 110 | ||
117 | return err; | 111 | return err; |
118 | } | 112 | } |
@@ -124,8 +118,6 @@ static int adc081c_remove(struct i2c_client *client) | |||
124 | 118 | ||
125 | iio_device_unregister(iio); | 119 | iio_device_unregister(iio); |
126 | regulator_disable(adc->ref); | 120 | regulator_disable(adc->ref); |
127 | regulator_put(adc->ref); | ||
128 | iio_device_free(iio); | ||
129 | 121 | ||
130 | return 0; | 122 | return 0; |
131 | } | 123 | } |
diff --git a/drivers/iio/adc/ti_am335x_adc.c b/drivers/iio/adc/ti_am335x_adc.c index 3ceac3e91dde..a952538a1a8b 100644 --- a/drivers/iio/adc/ti_am335x_adc.c +++ b/drivers/iio/adc/ti_am335x_adc.c | |||
@@ -216,11 +216,11 @@ static int tiadc_probe(struct platform_device *pdev) | |||
216 | return -EINVAL; | 216 | return -EINVAL; |
217 | } | 217 | } |
218 | 218 | ||
219 | indio_dev = iio_device_alloc(sizeof(struct tiadc_device)); | 219 | indio_dev = devm_iio_device_alloc(&pdev->dev, |
220 | sizeof(struct tiadc_device)); | ||
220 | if (indio_dev == NULL) { | 221 | if (indio_dev == NULL) { |
221 | dev_err(&pdev->dev, "failed to allocate iio device\n"); | 222 | dev_err(&pdev->dev, "failed to allocate iio device\n"); |
222 | err = -ENOMEM; | 223 | return -ENOMEM; |
223 | goto err_ret; | ||
224 | } | 224 | } |
225 | adc_dev = iio_priv(indio_dev); | 225 | adc_dev = iio_priv(indio_dev); |
226 | 226 | ||
@@ -241,7 +241,7 @@ static int tiadc_probe(struct platform_device *pdev) | |||
241 | 241 | ||
242 | err = tiadc_channel_init(indio_dev, adc_dev->channels); | 242 | err = tiadc_channel_init(indio_dev, adc_dev->channels); |
243 | if (err < 0) | 243 | if (err < 0) |
244 | goto err_free_device; | 244 | return err; |
245 | 245 | ||
246 | err = iio_device_register(indio_dev); | 246 | err = iio_device_register(indio_dev); |
247 | if (err) | 247 | if (err) |
@@ -253,9 +253,6 @@ static int tiadc_probe(struct platform_device *pdev) | |||
253 | 253 | ||
254 | err_free_channels: | 254 | err_free_channels: |
255 | tiadc_channels_remove(indio_dev); | 255 | tiadc_channels_remove(indio_dev); |
256 | err_free_device: | ||
257 | iio_device_free(indio_dev); | ||
258 | err_ret: | ||
259 | return err; | 256 | return err; |
260 | } | 257 | } |
261 | 258 | ||
@@ -271,8 +268,6 @@ static int tiadc_remove(struct platform_device *pdev) | |||
271 | step_en = get_adc_step_mask(adc_dev); | 268 | step_en = get_adc_step_mask(adc_dev); |
272 | am335x_tsc_se_clr(adc_dev->mfd_tscadc, step_en); | 269 | am335x_tsc_se_clr(adc_dev->mfd_tscadc, step_en); |
273 | 270 | ||
274 | iio_device_free(indio_dev); | ||
275 | |||
276 | return 0; | 271 | return 0; |
277 | } | 272 | } |
278 | 273 | ||
diff --git a/drivers/iio/adc/twl6030-gpadc.c b/drivers/iio/adc/twl6030-gpadc.c new file mode 100644 index 000000000000..0ea96c058c08 --- /dev/null +++ b/drivers/iio/adc/twl6030-gpadc.c | |||
@@ -0,0 +1,1013 @@ | |||
1 | /* | ||
2 | * TWL6030 GPADC module driver | ||
3 | * | ||
4 | * Copyright (C) 2009-2013 Texas Instruments Inc. | ||
5 | * Nishant Kamat <nskamat@ti.com> | ||
6 | * Balaji T K <balajitk@ti.com> | ||
7 | * Graeme Gregory <gg@slimlogic.co.uk> | ||
8 | * Girish S Ghongdemath <girishsg@ti.com> | ||
9 | * Ambresh K <ambresh@ti.com> | ||
10 | * Oleksandr Kozaruk <oleksandr.kozaruk@ti.com | ||
11 | * | ||
12 | * Based on twl4030-madc.c | ||
13 | * Copyright (C) 2008 Nokia Corporation | ||
14 | * Mikko Ylinen <mikko.k.ylinen@nokia.com> | ||
15 | * | ||
16 | * This program is free software; you can redistribute it and/or | ||
17 | * modify it under the terms of the GNU General Public License | ||
18 | * version 2 as published by the Free Software Foundation. | ||
19 | * | ||
20 | * This program is distributed in the hope that it will be useful, but | ||
21 | * WITHOUT ANY WARRANTY; without even the implied warranty of | ||
22 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
23 | * General Public License for more details. | ||
24 | * | ||
25 | * You should have received a copy of the GNU General Public License | ||
26 | * along with this program; if not, write to the Free Software | ||
27 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | ||
28 | * 02110-1301 USA | ||
29 | * | ||
30 | */ | ||
31 | #include <linux/init.h> | ||
32 | #include <linux/interrupt.h> | ||
33 | #include <linux/kernel.h> | ||
34 | #include <linux/module.h> | ||
35 | #include <linux/platform_device.h> | ||
36 | #include <linux/of_platform.h> | ||
37 | #include <linux/i2c/twl.h> | ||
38 | #include <linux/iio/iio.h> | ||
39 | #include <linux/iio/sysfs.h> | ||
40 | |||
41 | #define DRIVER_NAME "twl6030_gpadc" | ||
42 | |||
43 | /* | ||
44 | * twl6030 per TRM has 17 channels, and twl6032 has 19 channels | ||
45 | * 2 test network channels are not used, | ||
46 | * 2 die temperature channels are not used either, as it is not | ||
47 | * defined how to convert ADC value to temperature | ||
48 | */ | ||
49 | #define TWL6030_GPADC_USED_CHANNELS 13 | ||
50 | #define TWL6030_GPADC_MAX_CHANNELS 15 | ||
51 | #define TWL6032_GPADC_USED_CHANNELS 15 | ||
52 | #define TWL6032_GPADC_MAX_CHANNELS 19 | ||
53 | #define TWL6030_GPADC_NUM_TRIM_REGS 16 | ||
54 | |||
55 | #define TWL6030_GPADC_CTRL_P1 0x05 | ||
56 | |||
57 | #define TWL6032_GPADC_GPSELECT_ISB 0x07 | ||
58 | #define TWL6032_GPADC_CTRL_P1 0x08 | ||
59 | |||
60 | #define TWL6032_GPADC_GPCH0_LSB 0x0d | ||
61 | #define TWL6032_GPADC_GPCH0_MSB 0x0e | ||
62 | |||
63 | #define TWL6030_GPADC_CTRL_P1_SP1 BIT(3) | ||
64 | |||
65 | #define TWL6030_GPADC_GPCH0_LSB (0x29) | ||
66 | |||
67 | #define TWL6030_GPADC_RT_SW1_EOC_MASK BIT(5) | ||
68 | |||
69 | #define TWL6030_GPADC_TRIM1 0xCD | ||
70 | |||
71 | #define TWL6030_REG_TOGGLE1 0x90 | ||
72 | #define TWL6030_GPADCS BIT(1) | ||
73 | #define TWL6030_GPADCR BIT(0) | ||
74 | |||
75 | /** | ||
76 | * struct twl6030_chnl_calib - channel calibration | ||
77 | * @gain: slope coefficient for ideal curve | ||
78 | * @gain_error: gain error | ||
79 | * @offset_error: offset of the real curve | ||
80 | */ | ||
81 | struct twl6030_chnl_calib { | ||
82 | s32 gain; | ||
83 | s32 gain_error; | ||
84 | s32 offset_error; | ||
85 | }; | ||
86 | |||
87 | /** | ||
88 | * struct twl6030_ideal_code - GPADC calibration parameters | ||
89 | * GPADC is calibrated in two points: close to the beginning and | ||
90 | * to the and of the measurable input range | ||
91 | * | ||
92 | * @channel: channel number | ||
93 | * @code1: ideal code for the input at the beginning | ||
94 | * @code2: ideal code for at the end of the range | ||
95 | * @volt1: voltage input at the beginning(low voltage) | ||
96 | * @volt2: voltage input at the end(high voltage) | ||
97 | */ | ||
98 | struct twl6030_ideal_code { | ||
99 | int channel; | ||
100 | u16 code1; | ||
101 | u16 code2; | ||
102 | u16 volt1; | ||
103 | u16 volt2; | ||
104 | }; | ||
105 | |||
106 | struct twl6030_gpadc_data; | ||
107 | |||
108 | /** | ||
109 | * struct twl6030_gpadc_platform_data - platform specific data | ||
110 | * @nchannels: number of GPADC channels | ||
111 | * @iio_channels: iio channels | ||
112 | * @twl6030_ideal: pointer to calibration parameters | ||
113 | * @start_conversion: pointer to ADC start conversion function | ||
114 | * @channel_to_reg pointer to ADC function to convert channel to | ||
115 | * register address for reading conversion result | ||
116 | * @calibrate: pointer to calibration function | ||
117 | */ | ||
118 | struct twl6030_gpadc_platform_data { | ||
119 | const int nchannels; | ||
120 | const struct iio_chan_spec *iio_channels; | ||
121 | const struct twl6030_ideal_code *ideal; | ||
122 | int (*start_conversion)(int channel); | ||
123 | u8 (*channel_to_reg)(int channel); | ||
124 | int (*calibrate)(struct twl6030_gpadc_data *gpadc); | ||
125 | }; | ||
126 | |||
127 | /** | ||
128 | * struct twl6030_gpadc_data - GPADC data | ||
129 | * @dev: device pointer | ||
130 | * @lock: mutual exclusion lock for the structure | ||
131 | * @irq_complete: completion to signal end of conversion | ||
132 | * @twl6030_cal_tbl: pointer to calibration data for each | ||
133 | * channel with gain error and offset | ||
134 | * @pdata: pointer to device specific data | ||
135 | */ | ||
136 | struct twl6030_gpadc_data { | ||
137 | struct device *dev; | ||
138 | struct mutex lock; | ||
139 | struct completion irq_complete; | ||
140 | struct twl6030_chnl_calib *twl6030_cal_tbl; | ||
141 | const struct twl6030_gpadc_platform_data *pdata; | ||
142 | }; | ||
143 | |||
144 | /* | ||
145 | * channels 11, 12, 13, 15 and 16 have no calibration data | ||
146 | * calibration offset is same for channels 1, 3, 4, 5 | ||
147 | * | ||
148 | * The data is taken from GPADC_TRIM registers description. | ||
149 | * GPADC_TRIM registers keep difference between the code measured | ||
150 | * at volt1 and volt2 input voltages and corresponding code1 and code2 | ||
151 | */ | ||
152 | static const struct twl6030_ideal_code | ||
153 | twl6030_ideal[TWL6030_GPADC_USED_CHANNELS] = { | ||
154 | [0] = { /* ch 0, external, battery type, resistor value */ | ||
155 | .channel = 0, | ||
156 | .code1 = 116, | ||
157 | .code2 = 745, | ||
158 | .volt1 = 141, | ||
159 | .volt2 = 910, | ||
160 | }, | ||
161 | [1] = { /* ch 1, external, battery temperature, NTC resistor value */ | ||
162 | .channel = 1, | ||
163 | .code1 = 82, | ||
164 | .code2 = 900, | ||
165 | .volt1 = 100, | ||
166 | .volt2 = 1100, | ||
167 | }, | ||
168 | [2] = { /* ch 2, external, audio accessory/general purpose */ | ||
169 | .channel = 2, | ||
170 | .code1 = 55, | ||
171 | .code2 = 818, | ||
172 | .volt1 = 101, | ||
173 | .volt2 = 1499, | ||
174 | }, | ||
175 | [3] = { /* ch 3, external, general purpose */ | ||
176 | .channel = 3, | ||
177 | .code1 = 82, | ||
178 | .code2 = 900, | ||
179 | .volt1 = 100, | ||
180 | .volt2 = 1100, | ||
181 | }, | ||
182 | [4] = { /* ch 4, external, temperature measurement/general purpose */ | ||
183 | .channel = 4, | ||
184 | .code1 = 82, | ||
185 | .code2 = 900, | ||
186 | .volt1 = 100, | ||
187 | .volt2 = 1100, | ||
188 | }, | ||
189 | [5] = { /* ch 5, external, general purpose */ | ||
190 | .channel = 5, | ||
191 | .code1 = 82, | ||
192 | .code2 = 900, | ||
193 | .volt1 = 100, | ||
194 | .volt2 = 1100, | ||
195 | }, | ||
196 | [6] = { /* ch 6, external, general purpose */ | ||
197 | .channel = 6, | ||
198 | .code1 = 82, | ||
199 | .code2 = 900, | ||
200 | .volt1 = 100, | ||
201 | .volt2 = 1100, | ||
202 | }, | ||
203 | [7] = { /* ch 7, internal, main battery */ | ||
204 | .channel = 7, | ||
205 | .code1 = 614, | ||
206 | .code2 = 941, | ||
207 | .volt1 = 3001, | ||
208 | .volt2 = 4599, | ||
209 | }, | ||
210 | [8] = { /* ch 8, internal, backup battery */ | ||
211 | .channel = 8, | ||
212 | .code1 = 82, | ||
213 | .code2 = 688, | ||
214 | .volt1 = 501, | ||
215 | .volt2 = 4203, | ||
216 | }, | ||
217 | [9] = { /* ch 9, internal, external charger input */ | ||
218 | .channel = 9, | ||
219 | .code1 = 182, | ||
220 | .code2 = 818, | ||
221 | .volt1 = 2001, | ||
222 | .volt2 = 8996, | ||
223 | }, | ||
224 | [10] = { /* ch 10, internal, VBUS */ | ||
225 | .channel = 10, | ||
226 | .code1 = 149, | ||
227 | .code2 = 818, | ||
228 | .volt1 = 1001, | ||
229 | .volt2 = 5497, | ||
230 | }, | ||
231 | [11] = { /* ch 11, internal, VBUS charging current */ | ||
232 | .channel = 11, | ||
233 | }, | ||
234 | /* ch 12, internal, Die temperature */ | ||
235 | /* ch 13, internal, Die temperature */ | ||
236 | [12] = { /* ch 14, internal, USB ID line */ | ||
237 | .channel = 14, | ||
238 | .code1 = 48, | ||
239 | .code2 = 714, | ||
240 | .volt1 = 323, | ||
241 | .volt2 = 4800, | ||
242 | }, | ||
243 | }; | ||
244 | |||
245 | static const struct twl6030_ideal_code | ||
246 | twl6032_ideal[TWL6032_GPADC_USED_CHANNELS] = { | ||
247 | [0] = { /* ch 0, external, battery type, resistor value */ | ||
248 | .channel = 0, | ||
249 | .code1 = 1441, | ||
250 | .code2 = 3276, | ||
251 | .volt1 = 440, | ||
252 | .volt2 = 1000, | ||
253 | }, | ||
254 | [1] = { /* ch 1, external, battery temperature, NTC resistor value */ | ||
255 | .channel = 1, | ||
256 | .code1 = 1441, | ||
257 | .code2 = 3276, | ||
258 | .volt1 = 440, | ||
259 | .volt2 = 1000, | ||
260 | }, | ||
261 | [2] = { /* ch 2, external, audio accessory/general purpose */ | ||
262 | .channel = 2, | ||
263 | .code1 = 1441, | ||
264 | .code2 = 3276, | ||
265 | .volt1 = 660, | ||
266 | .volt2 = 1500, | ||
267 | }, | ||
268 | [3] = { /* ch 3, external, temperature with external diode/general | ||
269 | purpose */ | ||
270 | .channel = 3, | ||
271 | .code1 = 1441, | ||
272 | .code2 = 3276, | ||
273 | .volt1 = 440, | ||
274 | .volt2 = 1000, | ||
275 | }, | ||
276 | [4] = { /* ch 4, external, temperature measurement/general purpose */ | ||
277 | .channel = 4, | ||
278 | .code1 = 1441, | ||
279 | .code2 = 3276, | ||
280 | .volt1 = 440, | ||
281 | .volt2 = 1000, | ||
282 | }, | ||
283 | [5] = { /* ch 5, external, general purpose */ | ||
284 | .channel = 5, | ||
285 | .code1 = 1441, | ||
286 | .code2 = 3276, | ||
287 | .volt1 = 440, | ||
288 | .volt2 = 1000, | ||
289 | }, | ||
290 | [6] = { /* ch 6, external, general purpose */ | ||
291 | .channel = 6, | ||
292 | .code1 = 1441, | ||
293 | .code2 = 3276, | ||
294 | .volt1 = 440, | ||
295 | .volt2 = 1000, | ||
296 | }, | ||
297 | [7] = { /* ch7, internal, system supply */ | ||
298 | .channel = 7, | ||
299 | .code1 = 1441, | ||
300 | .code2 = 3276, | ||
301 | .volt1 = 2200, | ||
302 | .volt2 = 5000, | ||
303 | }, | ||
304 | [8] = { /* ch8, internal, backup battery */ | ||
305 | .channel = 8, | ||
306 | .code1 = 1441, | ||
307 | .code2 = 3276, | ||
308 | .volt1 = 2200, | ||
309 | .volt2 = 5000, | ||
310 | }, | ||
311 | [9] = { /* ch 9, internal, external charger input */ | ||
312 | .channel = 9, | ||
313 | .code1 = 1441, | ||
314 | .code2 = 3276, | ||
315 | .volt1 = 3960, | ||
316 | .volt2 = 9000, | ||
317 | }, | ||
318 | [10] = { /* ch10, internal, VBUS */ | ||
319 | .channel = 10, | ||
320 | .code1 = 150, | ||
321 | .code2 = 751, | ||
322 | .volt1 = 1000, | ||
323 | .volt2 = 5000, | ||
324 | }, | ||
325 | [11] = { /* ch 11, internal, VBUS DC-DC output current */ | ||
326 | .channel = 11, | ||
327 | .code1 = 1441, | ||
328 | .code2 = 3276, | ||
329 | .volt1 = 660, | ||
330 | .volt2 = 1500, | ||
331 | }, | ||
332 | /* ch 12, internal, Die temperature */ | ||
333 | /* ch 13, internal, Die temperature */ | ||
334 | [12] = { /* ch 14, internal, USB ID line */ | ||
335 | .channel = 14, | ||
336 | .code1 = 1441, | ||
337 | .code2 = 3276, | ||
338 | .volt1 = 2420, | ||
339 | .volt2 = 5500, | ||
340 | }, | ||
341 | /* ch 15, internal, test network */ | ||
342 | /* ch 16, internal, test network */ | ||
343 | [13] = { /* ch 17, internal, battery charging current */ | ||
344 | .channel = 17, | ||
345 | }, | ||
346 | [14] = { /* ch 18, internal, battery voltage */ | ||
347 | .channel = 18, | ||
348 | .code1 = 1441, | ||
349 | .code2 = 3276, | ||
350 | .volt1 = 2200, | ||
351 | .volt2 = 5000, | ||
352 | }, | ||
353 | }; | ||
354 | |||
355 | static inline int twl6030_gpadc_write(u8 reg, u8 val) | ||
356 | { | ||
357 | return twl_i2c_write_u8(TWL6030_MODULE_GPADC, val, reg); | ||
358 | } | ||
359 | |||
360 | static inline int twl6030_gpadc_read(u8 reg, u8 *val) | ||
361 | { | ||
362 | |||
363 | return twl_i2c_read(TWL6030_MODULE_GPADC, val, reg, 2); | ||
364 | } | ||
365 | |||
366 | static int twl6030_gpadc_enable_irq(u8 mask) | ||
367 | { | ||
368 | int ret; | ||
369 | |||
370 | ret = twl6030_interrupt_unmask(mask, REG_INT_MSK_LINE_B); | ||
371 | if (ret < 0) | ||
372 | return ret; | ||
373 | |||
374 | ret = twl6030_interrupt_unmask(mask, REG_INT_MSK_STS_B); | ||
375 | |||
376 | return ret; | ||
377 | } | ||
378 | |||
379 | static void twl6030_gpadc_disable_irq(u8 mask) | ||
380 | { | ||
381 | twl6030_interrupt_mask(mask, REG_INT_MSK_LINE_B); | ||
382 | twl6030_interrupt_mask(mask, REG_INT_MSK_STS_B); | ||
383 | } | ||
384 | |||
385 | static irqreturn_t twl6030_gpadc_irq_handler(int irq, void *indio_dev) | ||
386 | { | ||
387 | struct twl6030_gpadc_data *gpadc = iio_priv(indio_dev); | ||
388 | |||
389 | complete(&gpadc->irq_complete); | ||
390 | |||
391 | return IRQ_HANDLED; | ||
392 | } | ||
393 | |||
394 | static int twl6030_start_conversion(int channel) | ||
395 | { | ||
396 | return twl6030_gpadc_write(TWL6030_GPADC_CTRL_P1, | ||
397 | TWL6030_GPADC_CTRL_P1_SP1); | ||
398 | } | ||
399 | |||
400 | static int twl6032_start_conversion(int channel) | ||
401 | { | ||
402 | int ret; | ||
403 | |||
404 | ret = twl6030_gpadc_write(TWL6032_GPADC_GPSELECT_ISB, channel); | ||
405 | if (ret) | ||
406 | return ret; | ||
407 | |||
408 | return twl6030_gpadc_write(TWL6032_GPADC_CTRL_P1, | ||
409 | TWL6030_GPADC_CTRL_P1_SP1); | ||
410 | } | ||
411 | |||
412 | static u8 twl6030_channel_to_reg(int channel) | ||
413 | { | ||
414 | return TWL6030_GPADC_GPCH0_LSB + 2 * channel; | ||
415 | } | ||
416 | |||
417 | static u8 twl6032_channel_to_reg(int channel) | ||
418 | { | ||
419 | /* | ||
420 | * for any prior chosen channel, when the conversion is ready | ||
421 | * the result is avalable in GPCH0_LSB, GPCH0_MSB. | ||
422 | */ | ||
423 | |||
424 | return TWL6032_GPADC_GPCH0_LSB; | ||
425 | } | ||
426 | |||
427 | static int twl6030_gpadc_lookup(const struct twl6030_ideal_code *ideal, | ||
428 | int channel, int size) | ||
429 | { | ||
430 | int i; | ||
431 | |||
432 | for (i = 0; i < size; i++) | ||
433 | if (ideal[i].channel == channel) | ||
434 | break; | ||
435 | |||
436 | return i; | ||
437 | } | ||
438 | |||
439 | static int twl6030_channel_calibrated(const struct twl6030_gpadc_platform_data | ||
440 | *pdata, int channel) | ||
441 | { | ||
442 | const struct twl6030_ideal_code *ideal = pdata->ideal; | ||
443 | int i; | ||
444 | |||
445 | i = twl6030_gpadc_lookup(ideal, channel, pdata->nchannels); | ||
446 | /* not calibrated channels have 0 in all structure members */ | ||
447 | return pdata->ideal[i].code2; | ||
448 | } | ||
449 | |||
450 | static int twl6030_gpadc_make_correction(struct twl6030_gpadc_data *gpadc, | ||
451 | int channel, int raw_code) | ||
452 | { | ||
453 | const struct twl6030_ideal_code *ideal = gpadc->pdata->ideal; | ||
454 | int corrected_code; | ||
455 | int i; | ||
456 | |||
457 | i = twl6030_gpadc_lookup(ideal, channel, gpadc->pdata->nchannels); | ||
458 | corrected_code = ((raw_code * 1000) - | ||
459 | gpadc->twl6030_cal_tbl[i].offset_error) / | ||
460 | gpadc->twl6030_cal_tbl[i].gain_error; | ||
461 | |||
462 | return corrected_code; | ||
463 | } | ||
464 | |||
465 | static int twl6030_gpadc_get_raw(struct twl6030_gpadc_data *gpadc, | ||
466 | int channel, int *res) | ||
467 | { | ||
468 | u8 reg = gpadc->pdata->channel_to_reg(channel); | ||
469 | __le16 val; | ||
470 | int raw_code; | ||
471 | int ret; | ||
472 | |||
473 | ret = twl6030_gpadc_read(reg, (u8 *)&val); | ||
474 | if (ret) { | ||
475 | dev_dbg(gpadc->dev, "unable to read register 0x%X\n", reg); | ||
476 | return ret; | ||
477 | } | ||
478 | |||
479 | raw_code = le16_to_cpu(val); | ||
480 | dev_dbg(gpadc->dev, "GPADC raw code: %d", raw_code); | ||
481 | |||
482 | if (twl6030_channel_calibrated(gpadc->pdata, channel)) | ||
483 | *res = twl6030_gpadc_make_correction(gpadc, channel, raw_code); | ||
484 | else | ||
485 | *res = raw_code; | ||
486 | |||
487 | return ret; | ||
488 | } | ||
489 | |||
490 | static int twl6030_gpadc_get_processed(struct twl6030_gpadc_data *gpadc, | ||
491 | int channel, int *val) | ||
492 | { | ||
493 | const struct twl6030_ideal_code *ideal = gpadc->pdata->ideal; | ||
494 | int corrected_code; | ||
495 | int channel_value; | ||
496 | int i; | ||
497 | int ret; | ||
498 | |||
499 | ret = twl6030_gpadc_get_raw(gpadc, channel, &corrected_code); | ||
500 | if (ret) | ||
501 | return ret; | ||
502 | |||
503 | i = twl6030_gpadc_lookup(ideal, channel, gpadc->pdata->nchannels); | ||
504 | channel_value = corrected_code * | ||
505 | gpadc->twl6030_cal_tbl[i].gain; | ||
506 | |||
507 | /* Shift back into mV range */ | ||
508 | channel_value /= 1000; | ||
509 | |||
510 | dev_dbg(gpadc->dev, "GPADC corrected code: %d", corrected_code); | ||
511 | dev_dbg(gpadc->dev, "GPADC value: %d", channel_value); | ||
512 | |||
513 | *val = channel_value; | ||
514 | |||
515 | return ret; | ||
516 | } | ||
517 | |||
518 | static int twl6030_gpadc_read_raw(struct iio_dev *indio_dev, | ||
519 | const struct iio_chan_spec *chan, | ||
520 | int *val, int *val2, long mask) | ||
521 | { | ||
522 | struct twl6030_gpadc_data *gpadc = iio_priv(indio_dev); | ||
523 | int ret; | ||
524 | long timeout; | ||
525 | |||
526 | mutex_lock(&gpadc->lock); | ||
527 | |||
528 | ret = gpadc->pdata->start_conversion(chan->channel); | ||
529 | if (ret) { | ||
530 | dev_err(gpadc->dev, "failed to start conversion\n"); | ||
531 | goto err; | ||
532 | } | ||
533 | /* wait for conversion to complete */ | ||
534 | timeout = wait_for_completion_interruptible_timeout( | ||
535 | &gpadc->irq_complete, msecs_to_jiffies(5000)); | ||
536 | if (timeout == 0) { | ||
537 | ret = -ETIMEDOUT; | ||
538 | goto err; | ||
539 | } else if (timeout < 0) { | ||
540 | ret = -EINTR; | ||
541 | goto err; | ||
542 | } | ||
543 | |||
544 | switch (mask) { | ||
545 | case IIO_CHAN_INFO_RAW: | ||
546 | ret = twl6030_gpadc_get_raw(gpadc, chan->channel, val); | ||
547 | ret = ret ? -EIO : IIO_VAL_INT; | ||
548 | break; | ||
549 | |||
550 | case IIO_CHAN_INFO_PROCESSED: | ||
551 | ret = twl6030_gpadc_get_processed(gpadc, chan->channel, val); | ||
552 | ret = ret ? -EIO : IIO_VAL_INT; | ||
553 | break; | ||
554 | |||
555 | default: | ||
556 | break; | ||
557 | } | ||
558 | err: | ||
559 | mutex_unlock(&gpadc->lock); | ||
560 | |||
561 | return ret; | ||
562 | } | ||
563 | |||
564 | /* | ||
565 | * The GPADC channels are calibrated using a two point calibration method. | ||
566 | * The channels measured with two known values: volt1 and volt2, and | ||
567 | * ideal corresponding output codes are known: code1, code2. | ||
568 | * The difference(d1, d2) between ideal and measured codes stored in trim | ||
569 | * registers. | ||
570 | * The goal is to find offset and gain of the real curve for each calibrated | ||
571 | * channel. | ||
572 | * gain: k = 1 + ((d2 - d1) / (x2 - x1)) | ||
573 | * offset: b = d1 + (k - 1) * x1 | ||
574 | */ | ||
575 | static void twl6030_calibrate_channel(struct twl6030_gpadc_data *gpadc, | ||
576 | int channel, int d1, int d2) | ||
577 | { | ||
578 | int b, k, gain, x1, x2, i; | ||
579 | const struct twl6030_ideal_code *ideal = gpadc->pdata->ideal; | ||
580 | |||
581 | i = twl6030_gpadc_lookup(ideal, channel, gpadc->pdata->nchannels); | ||
582 | |||
583 | /* Gain */ | ||
584 | gain = ((ideal[i].volt2 - ideal[i].volt1) * 1000) / | ||
585 | (ideal[i].code2 - ideal[i].code1); | ||
586 | |||
587 | x1 = ideal[i].code1; | ||
588 | x2 = ideal[i].code2; | ||
589 | |||
590 | /* k - real curve gain */ | ||
591 | k = 1000 + (((d2 - d1) * 1000) / (x2 - x1)); | ||
592 | |||
593 | /* b - offset of the real curve gain */ | ||
594 | b = (d1 * 1000) - (k - 1000) * x1; | ||
595 | |||
596 | gpadc->twl6030_cal_tbl[i].gain = gain; | ||
597 | gpadc->twl6030_cal_tbl[i].gain_error = k; | ||
598 | gpadc->twl6030_cal_tbl[i].offset_error = b; | ||
599 | |||
600 | dev_dbg(gpadc->dev, "GPADC d1 for Chn: %d = %d\n", channel, d1); | ||
601 | dev_dbg(gpadc->dev, "GPADC d2 for Chn: %d = %d\n", channel, d2); | ||
602 | dev_dbg(gpadc->dev, "GPADC x1 for Chn: %d = %d\n", channel, x1); | ||
603 | dev_dbg(gpadc->dev, "GPADC x2 for Chn: %d = %d\n", channel, x2); | ||
604 | dev_dbg(gpadc->dev, "GPADC Gain for Chn: %d = %d\n", channel, gain); | ||
605 | dev_dbg(gpadc->dev, "GPADC k for Chn: %d = %d\n", channel, k); | ||
606 | dev_dbg(gpadc->dev, "GPADC b for Chn: %d = %d\n", channel, b); | ||
607 | } | ||
608 | |||
609 | static inline int twl6030_gpadc_get_trim_offset(s8 d) | ||
610 | { | ||
611 | /* | ||
612 | * XXX NOTE! | ||
613 | * bit 0 - sign, bit 7 - reserved, 6..1 - trim value | ||
614 | * though, the documentation states that trim value | ||
615 | * is absolute value, the correct conversion results are | ||
616 | * obtained if the value is interpreted as 2's complement. | ||
617 | */ | ||
618 | __u32 temp = ((d & 0x7f) >> 1) | ((d & 1) << 6); | ||
619 | |||
620 | return sign_extend32(temp, 6); | ||
621 | } | ||
622 | |||
623 | static int twl6030_calibration(struct twl6030_gpadc_data *gpadc) | ||
624 | { | ||
625 | int ret; | ||
626 | int chn; | ||
627 | u8 trim_regs[TWL6030_GPADC_NUM_TRIM_REGS]; | ||
628 | s8 d1, d2; | ||
629 | |||
630 | /* | ||
631 | * for calibration two measurements have been performed at | ||
632 | * factory, for some channels, during the production test and | ||
633 | * have been stored in registers. This two stored values are | ||
634 | * used to correct the measurements. The values represent | ||
635 | * offsets for the given input from the output on ideal curve. | ||
636 | */ | ||
637 | ret = twl_i2c_read(TWL6030_MODULE_ID2, trim_regs, | ||
638 | TWL6030_GPADC_TRIM1, TWL6030_GPADC_NUM_TRIM_REGS); | ||
639 | if (ret < 0) { | ||
640 | dev_err(gpadc->dev, "calibration failed\n"); | ||
641 | return ret; | ||
642 | } | ||
643 | |||
644 | for (chn = 0; chn < TWL6030_GPADC_MAX_CHANNELS; chn++) { | ||
645 | |||
646 | switch (chn) { | ||
647 | case 0: | ||
648 | d1 = trim_regs[0]; | ||
649 | d2 = trim_regs[1]; | ||
650 | break; | ||
651 | case 1: | ||
652 | case 3: | ||
653 | case 4: | ||
654 | case 5: | ||
655 | case 6: | ||
656 | d1 = trim_regs[4]; | ||
657 | d2 = trim_regs[5]; | ||
658 | break; | ||
659 | case 2: | ||
660 | d1 = trim_regs[12]; | ||
661 | d2 = trim_regs[13]; | ||
662 | break; | ||
663 | case 7: | ||
664 | d1 = trim_regs[6]; | ||
665 | d2 = trim_regs[7]; | ||
666 | break; | ||
667 | case 8: | ||
668 | d1 = trim_regs[2]; | ||
669 | d2 = trim_regs[3]; | ||
670 | break; | ||
671 | case 9: | ||
672 | d1 = trim_regs[8]; | ||
673 | d2 = trim_regs[9]; | ||
674 | break; | ||
675 | case 10: | ||
676 | d1 = trim_regs[10]; | ||
677 | d2 = trim_regs[11]; | ||
678 | break; | ||
679 | case 14: | ||
680 | d1 = trim_regs[14]; | ||
681 | d2 = trim_regs[15]; | ||
682 | break; | ||
683 | default: | ||
684 | continue; | ||
685 | } | ||
686 | |||
687 | d1 = twl6030_gpadc_get_trim_offset(d1); | ||
688 | d2 = twl6030_gpadc_get_trim_offset(d2); | ||
689 | |||
690 | twl6030_calibrate_channel(gpadc, chn, d1, d2); | ||
691 | } | ||
692 | |||
693 | return 0; | ||
694 | } | ||
695 | |||
696 | static int twl6032_get_trim_value(u8 *trim_regs, unsigned int reg0, | ||
697 | unsigned int reg1, unsigned int mask0, unsigned int mask1, | ||
698 | unsigned int shift0) | ||
699 | { | ||
700 | int val; | ||
701 | |||
702 | val = (trim_regs[reg0] & mask0) << shift0; | ||
703 | val |= (trim_regs[reg1] & mask1) >> 1; | ||
704 | if (trim_regs[reg1] & 0x01) | ||
705 | val = -val; | ||
706 | |||
707 | return val; | ||
708 | } | ||
709 | |||
710 | static int twl6032_calibration(struct twl6030_gpadc_data *gpadc) | ||
711 | { | ||
712 | int chn, d1 = 0, d2 = 0, temp; | ||
713 | u8 trim_regs[TWL6030_GPADC_NUM_TRIM_REGS]; | ||
714 | int ret; | ||
715 | |||
716 | ret = twl_i2c_read(TWL6030_MODULE_ID2, trim_regs, | ||
717 | TWL6030_GPADC_TRIM1, TWL6030_GPADC_NUM_TRIM_REGS); | ||
718 | if (ret < 0) { | ||
719 | dev_err(gpadc->dev, "calibration failed\n"); | ||
720 | return ret; | ||
721 | } | ||
722 | |||
723 | /* | ||
724 | * Loop to calculate the value needed for returning voltages from | ||
725 | * GPADC not values. | ||
726 | * | ||
727 | * gain is calculated to 3 decimal places fixed point. | ||
728 | */ | ||
729 | for (chn = 0; chn < TWL6032_GPADC_MAX_CHANNELS; chn++) { | ||
730 | |||
731 | switch (chn) { | ||
732 | case 0: | ||
733 | case 1: | ||
734 | case 2: | ||
735 | case 3: | ||
736 | case 4: | ||
737 | case 5: | ||
738 | case 6: | ||
739 | case 11: | ||
740 | case 14: | ||
741 | d1 = twl6032_get_trim_value(trim_regs, 2, 0, 0x1f, | ||
742 | 0x06, 2); | ||
743 | d2 = twl6032_get_trim_value(trim_regs, 3, 1, 0x3f, | ||
744 | 0x06, 2); | ||
745 | break; | ||
746 | case 8: | ||
747 | temp = twl6032_get_trim_value(trim_regs, 2, 0, 0x1f, | ||
748 | 0x06, 2); | ||
749 | d1 = temp + twl6032_get_trim_value(trim_regs, 7, 6, | ||
750 | 0x18, 0x1E, 1); | ||
751 | |||
752 | temp = twl6032_get_trim_value(trim_regs, 3, 1, 0x3F, | ||
753 | 0x06, 2); | ||
754 | d2 = temp + twl6032_get_trim_value(trim_regs, 9, 7, | ||
755 | 0x1F, 0x06, 2); | ||
756 | break; | ||
757 | case 9: | ||
758 | temp = twl6032_get_trim_value(trim_regs, 2, 0, 0x1f, | ||
759 | 0x06, 2); | ||
760 | d1 = temp + twl6032_get_trim_value(trim_regs, 13, 11, | ||
761 | 0x18, 0x1E, 1); | ||
762 | |||
763 | temp = twl6032_get_trim_value(trim_regs, 3, 1, 0x3f, | ||
764 | 0x06, 2); | ||
765 | d2 = temp + twl6032_get_trim_value(trim_regs, 15, 13, | ||
766 | 0x1F, 0x06, 1); | ||
767 | break; | ||
768 | case 10: | ||
769 | d1 = twl6032_get_trim_value(trim_regs, 10, 8, 0x0f, | ||
770 | 0x0E, 3); | ||
771 | d2 = twl6032_get_trim_value(trim_regs, 14, 12, 0x0f, | ||
772 | 0x0E, 3); | ||
773 | break; | ||
774 | case 7: | ||
775 | case 18: | ||
776 | temp = twl6032_get_trim_value(trim_regs, 2, 0, 0x1f, | ||
777 | 0x06, 2); | ||
778 | |||
779 | d1 = (trim_regs[4] & 0x7E) >> 1; | ||
780 | if (trim_regs[4] & 0x01) | ||
781 | d1 = -d1; | ||
782 | d1 += temp; | ||
783 | |||
784 | temp = twl6032_get_trim_value(trim_regs, 3, 1, 0x3f, | ||
785 | 0x06, 2); | ||
786 | |||
787 | d2 = (trim_regs[5] & 0xFE) >> 1; | ||
788 | if (trim_regs[5] & 0x01) | ||
789 | d2 = -d2; | ||
790 | |||
791 | d2 += temp; | ||
792 | break; | ||
793 | default: | ||
794 | /* No data for other channels */ | ||
795 | continue; | ||
796 | } | ||
797 | |||
798 | twl6030_calibrate_channel(gpadc, chn, d1, d2); | ||
799 | } | ||
800 | |||
801 | return 0; | ||
802 | } | ||
803 | |||
804 | #define TWL6030_GPADC_CHAN(chn, _type, chan_info) { \ | ||
805 | .type = _type, \ | ||
806 | .channel = chn, \ | ||
807 | .info_mask_separate = BIT(chan_info), \ | ||
808 | .indexed = 1, \ | ||
809 | } | ||
810 | |||
811 | static const struct iio_chan_spec twl6030_gpadc_iio_channels[] = { | ||
812 | TWL6030_GPADC_CHAN(0, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
813 | TWL6030_GPADC_CHAN(1, IIO_TEMP, IIO_CHAN_INFO_RAW), | ||
814 | TWL6030_GPADC_CHAN(2, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
815 | TWL6030_GPADC_CHAN(3, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
816 | TWL6030_GPADC_CHAN(4, IIO_TEMP, IIO_CHAN_INFO_RAW), | ||
817 | TWL6030_GPADC_CHAN(5, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
818 | TWL6030_GPADC_CHAN(6, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
819 | TWL6030_GPADC_CHAN(7, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
820 | TWL6030_GPADC_CHAN(8, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
821 | TWL6030_GPADC_CHAN(9, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
822 | TWL6030_GPADC_CHAN(10, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
823 | TWL6030_GPADC_CHAN(11, IIO_VOLTAGE, IIO_CHAN_INFO_RAW), | ||
824 | TWL6030_GPADC_CHAN(14, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
825 | }; | ||
826 | |||
827 | static const struct iio_chan_spec twl6032_gpadc_iio_channels[] = { | ||
828 | TWL6030_GPADC_CHAN(0, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
829 | TWL6030_GPADC_CHAN(1, IIO_TEMP, IIO_CHAN_INFO_RAW), | ||
830 | TWL6030_GPADC_CHAN(2, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
831 | TWL6030_GPADC_CHAN(3, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
832 | TWL6030_GPADC_CHAN(4, IIO_TEMP, IIO_CHAN_INFO_RAW), | ||
833 | TWL6030_GPADC_CHAN(5, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
834 | TWL6030_GPADC_CHAN(6, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
835 | TWL6030_GPADC_CHAN(7, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
836 | TWL6030_GPADC_CHAN(8, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
837 | TWL6030_GPADC_CHAN(9, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
838 | TWL6030_GPADC_CHAN(10, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
839 | TWL6030_GPADC_CHAN(11, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
840 | TWL6030_GPADC_CHAN(14, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
841 | TWL6030_GPADC_CHAN(17, IIO_VOLTAGE, IIO_CHAN_INFO_RAW), | ||
842 | TWL6030_GPADC_CHAN(18, IIO_VOLTAGE, IIO_CHAN_INFO_PROCESSED), | ||
843 | }; | ||
844 | |||
845 | static const struct iio_info twl6030_gpadc_iio_info = { | ||
846 | .read_raw = &twl6030_gpadc_read_raw, | ||
847 | .driver_module = THIS_MODULE, | ||
848 | }; | ||
849 | |||
850 | static const struct twl6030_gpadc_platform_data twl6030_pdata = { | ||
851 | .iio_channels = twl6030_gpadc_iio_channels, | ||
852 | .nchannels = TWL6030_GPADC_USED_CHANNELS, | ||
853 | .ideal = twl6030_ideal, | ||
854 | .start_conversion = twl6030_start_conversion, | ||
855 | .channel_to_reg = twl6030_channel_to_reg, | ||
856 | .calibrate = twl6030_calibration, | ||
857 | }; | ||
858 | |||
859 | static const struct twl6030_gpadc_platform_data twl6032_pdata = { | ||
860 | .iio_channels = twl6032_gpadc_iio_channels, | ||
861 | .nchannels = TWL6032_GPADC_USED_CHANNELS, | ||
862 | .ideal = twl6032_ideal, | ||
863 | .start_conversion = twl6032_start_conversion, | ||
864 | .channel_to_reg = twl6032_channel_to_reg, | ||
865 | .calibrate = twl6032_calibration, | ||
866 | }; | ||
867 | |||
868 | static const struct of_device_id of_twl6030_match_tbl[] = { | ||
869 | { | ||
870 | .compatible = "ti,twl6030-gpadc", | ||
871 | .data = &twl6030_pdata, | ||
872 | }, | ||
873 | { | ||
874 | .compatible = "ti,twl6032-gpadc", | ||
875 | .data = &twl6032_pdata, | ||
876 | }, | ||
877 | { /* end */ } | ||
878 | }; | ||
879 | |||
880 | static int twl6030_gpadc_probe(struct platform_device *pdev) | ||
881 | { | ||
882 | struct device *dev = &pdev->dev; | ||
883 | struct twl6030_gpadc_data *gpadc; | ||
884 | const struct twl6030_gpadc_platform_data *pdata; | ||
885 | const struct of_device_id *match; | ||
886 | struct iio_dev *indio_dev; | ||
887 | int irq; | ||
888 | int ret; | ||
889 | |||
890 | match = of_match_device(of_match_ptr(of_twl6030_match_tbl), dev); | ||
891 | if (!match) | ||
892 | return -EINVAL; | ||
893 | |||
894 | pdata = match->data; | ||
895 | |||
896 | indio_dev = devm_iio_device_alloc(dev, sizeof(*gpadc)); | ||
897 | if (!indio_dev) | ||
898 | return -ENOMEM; | ||
899 | |||
900 | gpadc = iio_priv(indio_dev); | ||
901 | |||
902 | gpadc->twl6030_cal_tbl = devm_kzalloc(dev, | ||
903 | sizeof(*gpadc->twl6030_cal_tbl) * | ||
904 | pdata->nchannels, GFP_KERNEL); | ||
905 | if (!gpadc->twl6030_cal_tbl) | ||
906 | return -ENOMEM; | ||
907 | |||
908 | gpadc->dev = dev; | ||
909 | gpadc->pdata = pdata; | ||
910 | |||
911 | platform_set_drvdata(pdev, indio_dev); | ||
912 | mutex_init(&gpadc->lock); | ||
913 | init_completion(&gpadc->irq_complete); | ||
914 | |||
915 | ret = pdata->calibrate(gpadc); | ||
916 | if (ret < 0) { | ||
917 | dev_err(&pdev->dev, "failed to read calibration registers\n"); | ||
918 | return ret; | ||
919 | } | ||
920 | |||
921 | irq = platform_get_irq(pdev, 0); | ||
922 | if (irq < 0) { | ||
923 | dev_err(&pdev->dev, "failed to get irq\n"); | ||
924 | return irq; | ||
925 | } | ||
926 | |||
927 | ret = devm_request_threaded_irq(dev, irq, NULL, | ||
928 | twl6030_gpadc_irq_handler, | ||
929 | IRQF_ONESHOT, "twl6030_gpadc", indio_dev); | ||
930 | |||
931 | ret = twl6030_gpadc_enable_irq(TWL6030_GPADC_RT_SW1_EOC_MASK); | ||
932 | if (ret < 0) { | ||
933 | dev_err(&pdev->dev, "failed to enable GPADC interrupt\n"); | ||
934 | return ret; | ||
935 | } | ||
936 | |||
937 | ret = twl_i2c_write_u8(TWL6030_MODULE_ID1, TWL6030_GPADCS, | ||
938 | TWL6030_REG_TOGGLE1); | ||
939 | if (ret < 0) { | ||
940 | dev_err(&pdev->dev, "failed to enable GPADC module\n"); | ||
941 | return ret; | ||
942 | } | ||
943 | |||
944 | indio_dev->name = DRIVER_NAME; | ||
945 | indio_dev->dev.parent = dev; | ||
946 | indio_dev->info = &twl6030_gpadc_iio_info; | ||
947 | indio_dev->modes = INDIO_DIRECT_MODE; | ||
948 | indio_dev->channels = pdata->iio_channels; | ||
949 | indio_dev->num_channels = pdata->nchannels; | ||
950 | |||
951 | ret = iio_device_register(indio_dev); | ||
952 | |||
953 | return ret; | ||
954 | } | ||
955 | |||
956 | static int twl6030_gpadc_remove(struct platform_device *pdev) | ||
957 | { | ||
958 | struct iio_dev *indio_dev = platform_get_drvdata(pdev); | ||
959 | |||
960 | twl6030_gpadc_disable_irq(TWL6030_GPADC_RT_SW1_EOC_MASK); | ||
961 | iio_device_unregister(indio_dev); | ||
962 | |||
963 | return 0; | ||
964 | } | ||
965 | |||
966 | #ifdef CONFIG_PM_SLEEP | ||
967 | static int twl6030_gpadc_suspend(struct device *pdev) | ||
968 | { | ||
969 | int ret; | ||
970 | |||
971 | ret = twl_i2c_write_u8(TWL6030_MODULE_ID1, TWL6030_GPADCR, | ||
972 | TWL6030_REG_TOGGLE1); | ||
973 | if (ret) | ||
974 | dev_err(pdev, "error reseting GPADC (%d)!\n", ret); | ||
975 | |||
976 | return 0; | ||
977 | }; | ||
978 | |||
979 | static int twl6030_gpadc_resume(struct device *pdev) | ||
980 | { | ||
981 | int ret; | ||
982 | |||
983 | ret = twl_i2c_write_u8(TWL6030_MODULE_ID1, TWL6030_GPADCS, | ||
984 | TWL6030_REG_TOGGLE1); | ||
985 | if (ret) | ||
986 | dev_err(pdev, "error setting GPADC (%d)!\n", ret); | ||
987 | |||
988 | return 0; | ||
989 | }; | ||
990 | #endif | ||
991 | |||
992 | static SIMPLE_DEV_PM_OPS(twl6030_gpadc_pm_ops, twl6030_gpadc_suspend, | ||
993 | twl6030_gpadc_resume); | ||
994 | |||
995 | static struct platform_driver twl6030_gpadc_driver = { | ||
996 | .probe = twl6030_gpadc_probe, | ||
997 | .remove = twl6030_gpadc_remove, | ||
998 | .driver = { | ||
999 | .name = DRIVER_NAME, | ||
1000 | .owner = THIS_MODULE, | ||
1001 | .pm = &twl6030_gpadc_pm_ops, | ||
1002 | .of_match_table = of_twl6030_match_tbl, | ||
1003 | }, | ||
1004 | }; | ||
1005 | |||
1006 | module_platform_driver(twl6030_gpadc_driver); | ||
1007 | |||
1008 | MODULE_ALIAS("platform: " DRIVER_NAME); | ||
1009 | MODULE_AUTHOR("Balaji T K <balajitk@ti.com>"); | ||
1010 | MODULE_AUTHOR("Graeme Gregory <gg@slimlogic.co.uk>"); | ||
1011 | MODULE_AUTHOR("Oleksandr Kozaruk <oleksandr.kozaruk@ti.com"); | ||
1012 | MODULE_DESCRIPTION("twl6030 ADC driver"); | ||
1013 | MODULE_LICENSE("GPL"); | ||
diff --git a/drivers/iio/adc/viperboard_adc.c b/drivers/iio/adc/viperboard_adc.c index 56ac481c73c0..09727a71e9fa 100644 --- a/drivers/iio/adc/viperboard_adc.c +++ b/drivers/iio/adc/viperboard_adc.c | |||
@@ -124,7 +124,7 @@ static int vprbrd_adc_probe(struct platform_device *pdev) | |||
124 | int ret; | 124 | int ret; |
125 | 125 | ||
126 | /* registering iio */ | 126 | /* registering iio */ |
127 | indio_dev = iio_device_alloc(sizeof(*adc)); | 127 | indio_dev = devm_iio_device_alloc(&pdev->dev, sizeof(*adc)); |
128 | if (!indio_dev) { | 128 | if (!indio_dev) { |
129 | dev_err(&pdev->dev, "failed allocating iio device\n"); | 129 | dev_err(&pdev->dev, "failed allocating iio device\n"); |
130 | return -ENOMEM; | 130 | return -ENOMEM; |
@@ -142,16 +142,12 @@ static int vprbrd_adc_probe(struct platform_device *pdev) | |||
142 | ret = iio_device_register(indio_dev); | 142 | ret = iio_device_register(indio_dev); |
143 | if (ret) { | 143 | if (ret) { |
144 | dev_err(&pdev->dev, "could not register iio (adc)"); | 144 | dev_err(&pdev->dev, "could not register iio (adc)"); |
145 | goto error; | 145 | return ret; |
146 | } | 146 | } |
147 | 147 | ||
148 | platform_set_drvdata(pdev, indio_dev); | 148 | platform_set_drvdata(pdev, indio_dev); |
149 | 149 | ||
150 | return 0; | 150 | return 0; |
151 | |||
152 | error: | ||
153 | iio_device_free(indio_dev); | ||
154 | return ret; | ||
155 | } | 151 | } |
156 | 152 | ||
157 | static int vprbrd_adc_remove(struct platform_device *pdev) | 153 | static int vprbrd_adc_remove(struct platform_device *pdev) |
@@ -159,7 +155,6 @@ static int vprbrd_adc_remove(struct platform_device *pdev) | |||
159 | struct iio_dev *indio_dev = platform_get_drvdata(pdev); | 155 | struct iio_dev *indio_dev = platform_get_drvdata(pdev); |
160 | 156 | ||
161 | iio_device_unregister(indio_dev); | 157 | iio_device_unregister(indio_dev); |
162 | iio_device_free(indio_dev); | ||
163 | 158 | ||
164 | return 0; | 159 | return 0; |
165 | } | 160 | } |
diff --git a/drivers/iio/amplifiers/Kconfig b/drivers/iio/amplifiers/Kconfig index 05d707ed7d4f..e9c5f2cd9257 100644 --- a/drivers/iio/amplifiers/Kconfig +++ b/drivers/iio/amplifiers/Kconfig | |||
@@ -1,6 +1,8 @@ | |||
1 | # | 1 | # |
2 | # Gain Amplifiers, etc. | 2 | # Gain Amplifiers, etc. |
3 | # | 3 | # |
4 | # When adding new entries keep the list in alphabetical order | ||
5 | |||
4 | menu "Amplifiers" | 6 | menu "Amplifiers" |
5 | 7 | ||
6 | config AD8366 | 8 | config AD8366 |
diff --git a/drivers/iio/amplifiers/Makefile b/drivers/iio/amplifiers/Makefile index a6ca366908e0..8da4b787898a 100644 --- a/drivers/iio/amplifiers/Makefile +++ b/drivers/iio/amplifiers/Makefile | |||
@@ -2,4 +2,5 @@ | |||
2 | # Makefile iio/amplifiers | 2 | # Makefile iio/amplifiers |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | obj-$(CONFIG_AD8366) += ad8366.o | 6 | obj-$(CONFIG_AD8366) += ad8366.o |
diff --git a/drivers/iio/amplifiers/ad8366.c b/drivers/iio/amplifiers/ad8366.c index d354554b51b3..d0a79a4bce1c 100644 --- a/drivers/iio/amplifiers/ad8366.c +++ b/drivers/iio/amplifiers/ad8366.c | |||
@@ -139,17 +139,17 @@ static int ad8366_probe(struct spi_device *spi) | |||
139 | struct ad8366_state *st; | 139 | struct ad8366_state *st; |
140 | int ret; | 140 | int ret; |
141 | 141 | ||
142 | indio_dev = iio_device_alloc(sizeof(*st)); | 142 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
143 | if (indio_dev == NULL) | 143 | if (indio_dev == NULL) |
144 | return -ENOMEM; | 144 | return -ENOMEM; |
145 | 145 | ||
146 | st = iio_priv(indio_dev); | 146 | st = iio_priv(indio_dev); |
147 | 147 | ||
148 | st->reg = regulator_get(&spi->dev, "vcc"); | 148 | st->reg = devm_regulator_get(&spi->dev, "vcc"); |
149 | if (!IS_ERR(st->reg)) { | 149 | if (!IS_ERR(st->reg)) { |
150 | ret = regulator_enable(st->reg); | 150 | ret = regulator_enable(st->reg); |
151 | if (ret) | 151 | if (ret) |
152 | goto error_put_reg; | 152 | return ret; |
153 | } | 153 | } |
154 | 154 | ||
155 | spi_set_drvdata(spi, indio_dev); | 155 | spi_set_drvdata(spi, indio_dev); |
@@ -173,11 +173,6 @@ static int ad8366_probe(struct spi_device *spi) | |||
173 | error_disable_reg: | 173 | error_disable_reg: |
174 | if (!IS_ERR(st->reg)) | 174 | if (!IS_ERR(st->reg)) |
175 | regulator_disable(st->reg); | 175 | regulator_disable(st->reg); |
176 | error_put_reg: | ||
177 | if (!IS_ERR(st->reg)) | ||
178 | regulator_put(st->reg); | ||
179 | |||
180 | iio_device_free(indio_dev); | ||
181 | 176 | ||
182 | return ret; | 177 | return ret; |
183 | } | 178 | } |
@@ -195,8 +190,6 @@ static int ad8366_remove(struct spi_device *spi) | |||
195 | regulator_put(reg); | 190 | regulator_put(reg); |
196 | } | 191 | } |
197 | 192 | ||
198 | iio_device_free(indio_dev); | ||
199 | |||
200 | return 0; | 193 | return 0; |
201 | } | 194 | } |
202 | 195 | ||
diff --git a/drivers/iio/common/Makefile b/drivers/iio/common/Makefile index c2352beb5d97..3112df0060e9 100644 --- a/drivers/iio/common/Makefile +++ b/drivers/iio/common/Makefile | |||
@@ -6,5 +6,6 @@ | |||
6 | # instead of duplicating in each module. | 6 | # instead of duplicating in each module. |
7 | # | 7 | # |
8 | 8 | ||
9 | # When adding new entries keep the list in alphabetical order | ||
9 | obj-y += hid-sensors/ | 10 | obj-y += hid-sensors/ |
10 | obj-y += st_sensors/ | 11 | obj-y += st_sensors/ |
diff --git a/drivers/iio/common/st_sensors/st_sensors_core.c b/drivers/iio/common/st_sensors/st_sensors_core.c index 865b1781df66..965ee22d3ac8 100644 --- a/drivers/iio/common/st_sensors/st_sensors_core.c +++ b/drivers/iio/common/st_sensors/st_sensors_core.c | |||
@@ -22,7 +22,7 @@ | |||
22 | 22 | ||
23 | static inline u32 st_sensors_get_unaligned_le24(const u8 *p) | 23 | static inline u32 st_sensors_get_unaligned_le24(const u8 *p) |
24 | { | 24 | { |
25 | return ((s32)((p[0] | p[1] << 8 | p[2] << 16) << 8) >> 8); | 25 | return (s32)((p[0] | p[1] << 8 | p[2] << 16) << 8) >> 8; |
26 | } | 26 | } |
27 | 27 | ||
28 | static int st_sensors_write_data_with_mask(struct iio_dev *indio_dev, | 28 | static int st_sensors_write_data_with_mask(struct iio_dev *indio_dev, |
@@ -118,7 +118,7 @@ st_sensors_match_odr_error: | |||
118 | } | 118 | } |
119 | 119 | ||
120 | static int st_sensors_set_fullscale(struct iio_dev *indio_dev, | 120 | static int st_sensors_set_fullscale(struct iio_dev *indio_dev, |
121 | unsigned int fs) | 121 | unsigned int fs) |
122 | { | 122 | { |
123 | int err, i = 0; | 123 | int err, i = 0; |
124 | struct st_sensor_data *sdata = iio_priv(indio_dev); | 124 | struct st_sensor_data *sdata = iio_priv(indio_dev); |
@@ -198,13 +198,39 @@ int st_sensors_set_axis_enable(struct iio_dev *indio_dev, u8 axis_enable) | |||
198 | } | 198 | } |
199 | EXPORT_SYMBOL(st_sensors_set_axis_enable); | 199 | EXPORT_SYMBOL(st_sensors_set_axis_enable); |
200 | 200 | ||
201 | int st_sensors_init_sensor(struct iio_dev *indio_dev) | 201 | int st_sensors_init_sensor(struct iio_dev *indio_dev, |
202 | struct st_sensors_platform_data *pdata) | ||
202 | { | 203 | { |
203 | int err; | 204 | int err; |
204 | struct st_sensor_data *sdata = iio_priv(indio_dev); | 205 | struct st_sensor_data *sdata = iio_priv(indio_dev); |
205 | 206 | ||
206 | mutex_init(&sdata->tb.buf_lock); | 207 | mutex_init(&sdata->tb.buf_lock); |
207 | 208 | ||
209 | switch (pdata->drdy_int_pin) { | ||
210 | case 1: | ||
211 | if (sdata->sensor->drdy_irq.mask_int1 == 0) { | ||
212 | dev_err(&indio_dev->dev, | ||
213 | "DRDY on INT1 not available.\n"); | ||
214 | err = -EINVAL; | ||
215 | goto init_error; | ||
216 | } | ||
217 | sdata->drdy_int_pin = 1; | ||
218 | break; | ||
219 | case 2: | ||
220 | if (sdata->sensor->drdy_irq.mask_int2 == 0) { | ||
221 | dev_err(&indio_dev->dev, | ||
222 | "DRDY on INT2 not available.\n"); | ||
223 | err = -EINVAL; | ||
224 | goto init_error; | ||
225 | } | ||
226 | sdata->drdy_int_pin = 2; | ||
227 | break; | ||
228 | default: | ||
229 | dev_err(&indio_dev->dev, "DRDY on pdata not valid.\n"); | ||
230 | err = -EINVAL; | ||
231 | goto init_error; | ||
232 | } | ||
233 | |||
208 | err = st_sensors_set_enable(indio_dev, false); | 234 | err = st_sensors_set_enable(indio_dev, false); |
209 | if (err < 0) | 235 | if (err < 0) |
210 | goto init_error; | 236 | goto init_error; |
@@ -234,6 +260,7 @@ EXPORT_SYMBOL(st_sensors_init_sensor); | |||
234 | int st_sensors_set_dataready_irq(struct iio_dev *indio_dev, bool enable) | 260 | int st_sensors_set_dataready_irq(struct iio_dev *indio_dev, bool enable) |
235 | { | 261 | { |
236 | int err; | 262 | int err; |
263 | u8 drdy_mask; | ||
237 | struct st_sensor_data *sdata = iio_priv(indio_dev); | 264 | struct st_sensor_data *sdata = iio_priv(indio_dev); |
238 | 265 | ||
239 | /* Enable/Disable the interrupt generator 1. */ | 266 | /* Enable/Disable the interrupt generator 1. */ |
@@ -245,10 +272,14 @@ int st_sensors_set_dataready_irq(struct iio_dev *indio_dev, bool enable) | |||
245 | goto st_accel_set_dataready_irq_error; | 272 | goto st_accel_set_dataready_irq_error; |
246 | } | 273 | } |
247 | 274 | ||
275 | if (sdata->drdy_int_pin == 1) | ||
276 | drdy_mask = sdata->sensor->drdy_irq.mask_int1; | ||
277 | else | ||
278 | drdy_mask = sdata->sensor->drdy_irq.mask_int2; | ||
279 | |||
248 | /* Enable/Disable the interrupt generator for data ready. */ | 280 | /* Enable/Disable the interrupt generator for data ready. */ |
249 | err = st_sensors_write_data_with_mask(indio_dev, | 281 | err = st_sensors_write_data_with_mask(indio_dev, |
250 | sdata->sensor->drdy_irq.addr, | 282 | sdata->sensor->drdy_irq.addr, drdy_mask, (int)enable); |
251 | sdata->sensor->drdy_irq.mask, (int)enable); | ||
252 | 283 | ||
253 | st_accel_set_dataready_irq_error: | 284 | st_accel_set_dataready_irq_error: |
254 | return err; | 285 | return err; |
diff --git a/drivers/iio/dac/Kconfig b/drivers/iio/dac/Kconfig index c9c33ce32d3a..3c6a78a75b78 100644 --- a/drivers/iio/dac/Kconfig +++ b/drivers/iio/dac/Kconfig | |||
@@ -1,6 +1,8 @@ | |||
1 | # | 1 | # |
2 | # DAC drivers | 2 | # DAC drivers |
3 | # | 3 | # |
4 | # When adding new entries keep the list in alphabetical order | ||
5 | |||
4 | menu "Digital to analog converters" | 6 | menu "Digital to analog converters" |
5 | 7 | ||
6 | config AD5064 | 8 | config AD5064 |
@@ -15,7 +17,7 @@ config AD5064 | |||
15 | module will be called ad5064. | 17 | module will be called ad5064. |
16 | 18 | ||
17 | config AD5360 | 19 | config AD5360 |
18 | tristate "Analog Devices Analog Devices AD5360/61/62/63/70/71/73 DAC driver" | 20 | tristate "Analog Devices AD5360/61/62/63/70/71/73 DAC driver" |
19 | depends on SPI | 21 | depends on SPI |
20 | help | 22 | help |
21 | Say yes here to build support for Analog Devices AD5360, AD5361, | 23 | Say yes here to build support for Analog Devices AD5360, AD5361, |
@@ -48,13 +50,6 @@ config AD5421 | |||
48 | To compile this driver as module choose M here: the module will be called | 50 | To compile this driver as module choose M here: the module will be called |
49 | ad5421. | 51 | ad5421. |
50 | 52 | ||
51 | config AD5624R_SPI | ||
52 | tristate "Analog Devices AD5624/44/64R DAC spi driver" | ||
53 | depends on SPI | ||
54 | help | ||
55 | Say yes here to build support for Analog Devices AD5624R, AD5644R and | ||
56 | AD5664R converters (DAC). This driver uses the common SPI interface. | ||
57 | |||
58 | config AD5446 | 53 | config AD5446 |
59 | tristate "Analog Devices AD5446 and similar single channel DACs driver" | 54 | tristate "Analog Devices AD5446 and similar single channel DACs driver" |
60 | depends on (SPI_MASTER && I2C!=m) || I2C | 55 | depends on (SPI_MASTER && I2C!=m) || I2C |
@@ -68,7 +63,7 @@ config AD5446 | |||
68 | module will be called ad5446. | 63 | module will be called ad5446. |
69 | 64 | ||
70 | config AD5449 | 65 | config AD5449 |
71 | tristate "Analog Device AD5449 and similar DACs driver" | 66 | tristate "Analog Devices AD5449 and similar DACs driver" |
72 | depends on SPI_MASTER | 67 | depends on SPI_MASTER |
73 | help | 68 | help |
74 | Say yes here to build support for Analog Devices AD5415, AD5426, AD5429, | 69 | Say yes here to build support for Analog Devices AD5415, AD5426, AD5429, |
@@ -87,6 +82,24 @@ config AD5504 | |||
87 | To compile this driver as a module, choose M here: the | 82 | To compile this driver as a module, choose M here: the |
88 | module will be called ad5504. | 83 | module will be called ad5504. |
89 | 84 | ||
85 | config AD5624R_SPI | ||
86 | tristate "Analog Devices AD5624/44/64R DAC spi driver" | ||
87 | depends on SPI | ||
88 | help | ||
89 | Say yes here to build support for Analog Devices AD5624R, AD5644R and | ||
90 | AD5664R converters (DAC). This driver uses the common SPI interface. | ||
91 | |||
92 | config AD5686 | ||
93 | tristate "Analog Devices AD5686R/AD5685R/AD5684R DAC SPI driver" | ||
94 | depends on SPI | ||
95 | help | ||
96 | Say yes here to build support for Analog Devices AD5686R, AD5685R, | ||
97 | AD5684R, AD5791 Voltage Output Digital to | ||
98 | Analog Converter. | ||
99 | |||
100 | To compile this driver as a module, choose M here: the | ||
101 | module will be called ad5686. | ||
102 | |||
90 | config AD5755 | 103 | config AD5755 |
91 | tristate "Analog Devices AD5755/AD5755-1/AD5757/AD5735/AD5737 DAC driver" | 104 | tristate "Analog Devices AD5755/AD5755-1/AD5757/AD5735/AD5737 DAC driver" |
92 | depends on SPI_MASTER | 105 | depends on SPI_MASTER |
@@ -119,19 +132,8 @@ config AD5791 | |||
119 | To compile this driver as a module, choose M here: the | 132 | To compile this driver as a module, choose M here: the |
120 | module will be called ad5791. | 133 | module will be called ad5791. |
121 | 134 | ||
122 | config AD5686 | ||
123 | tristate "Analog Devices AD5686R/AD5685R/AD5684R DAC SPI driver" | ||
124 | depends on SPI | ||
125 | help | ||
126 | Say yes here to build support for Analog Devices AD5686R, AD5685R, | ||
127 | AD5684R, AD5791 Voltage Output Digital to | ||
128 | Analog Converter. | ||
129 | |||
130 | To compile this driver as a module, choose M here: the | ||
131 | module will be called ad5686. | ||
132 | |||
133 | config AD7303 | 135 | config AD7303 |
134 | tristate "Analog Devices Analog Devices AD7303 DAC driver" | 136 | tristate "Analog Devices AD7303 DAC driver" |
135 | depends on SPI | 137 | depends on SPI |
136 | help | 138 | help |
137 | Say yes here to build support for Analog Devices AD7303 Digital to Analog | 139 | Say yes here to build support for Analog Devices AD7303 Digital to Analog |
diff --git a/drivers/iio/dac/Makefile b/drivers/iio/dac/Makefile index c8d7ab6bff01..bb84ad64463f 100644 --- a/drivers/iio/dac/Makefile +++ b/drivers/iio/dac/Makefile | |||
@@ -2,6 +2,7 @@ | |||
2 | # Makefile for industrial I/O DAC drivers | 2 | # Makefile for industrial I/O DAC drivers |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | obj-$(CONFIG_AD5360) += ad5360.o | 6 | obj-$(CONFIG_AD5360) += ad5360.o |
6 | obj-$(CONFIG_AD5380) += ad5380.o | 7 | obj-$(CONFIG_AD5380) += ad5380.o |
7 | obj-$(CONFIG_AD5421) += ad5421.o | 8 | obj-$(CONFIG_AD5421) += ad5421.o |
diff --git a/drivers/iio/dac/ad5064.c b/drivers/iio/dac/ad5064.c index aa26d50ab638..a3a52be4852c 100644 --- a/drivers/iio/dac/ad5064.c +++ b/drivers/iio/dac/ad5064.c | |||
@@ -442,7 +442,7 @@ static int ad5064_probe(struct device *dev, enum ad5064_type type, | |||
442 | unsigned int i; | 442 | unsigned int i; |
443 | int ret; | 443 | int ret; |
444 | 444 | ||
445 | indio_dev = iio_device_alloc(sizeof(*st)); | 445 | indio_dev = devm_iio_device_alloc(dev, sizeof(*st)); |
446 | if (indio_dev == NULL) | 446 | if (indio_dev == NULL) |
447 | return -ENOMEM; | 447 | return -ENOMEM; |
448 | 448 | ||
@@ -456,23 +456,23 @@ static int ad5064_probe(struct device *dev, enum ad5064_type type, | |||
456 | for (i = 0; i < ad5064_num_vref(st); ++i) | 456 | for (i = 0; i < ad5064_num_vref(st); ++i) |
457 | st->vref_reg[i].supply = ad5064_vref_name(st, i); | 457 | st->vref_reg[i].supply = ad5064_vref_name(st, i); |
458 | 458 | ||
459 | ret = regulator_bulk_get(dev, ad5064_num_vref(st), | 459 | ret = devm_regulator_bulk_get(dev, ad5064_num_vref(st), |
460 | st->vref_reg); | 460 | st->vref_reg); |
461 | if (ret) { | 461 | if (ret) { |
462 | if (!st->chip_info->internal_vref) | 462 | if (!st->chip_info->internal_vref) |
463 | goto error_free; | 463 | return ret; |
464 | st->use_internal_vref = true; | 464 | st->use_internal_vref = true; |
465 | ret = ad5064_write(st, AD5064_CMD_CONFIG, 0, | 465 | ret = ad5064_write(st, AD5064_CMD_CONFIG, 0, |
466 | AD5064_CONFIG_INT_VREF_ENABLE, 0); | 466 | AD5064_CONFIG_INT_VREF_ENABLE, 0); |
467 | if (ret) { | 467 | if (ret) { |
468 | dev_err(dev, "Failed to enable internal vref: %d\n", | 468 | dev_err(dev, "Failed to enable internal vref: %d\n", |
469 | ret); | 469 | ret); |
470 | goto error_free; | 470 | return ret; |
471 | } | 471 | } |
472 | } else { | 472 | } else { |
473 | ret = regulator_bulk_enable(ad5064_num_vref(st), st->vref_reg); | 473 | ret = regulator_bulk_enable(ad5064_num_vref(st), st->vref_reg); |
474 | if (ret) | 474 | if (ret) |
475 | goto error_free_reg; | 475 | return ret; |
476 | } | 476 | } |
477 | 477 | ||
478 | indio_dev->dev.parent = dev; | 478 | indio_dev->dev.parent = dev; |
@@ -498,11 +498,6 @@ static int ad5064_probe(struct device *dev, enum ad5064_type type, | |||
498 | error_disable_reg: | 498 | error_disable_reg: |
499 | if (!st->use_internal_vref) | 499 | if (!st->use_internal_vref) |
500 | regulator_bulk_disable(ad5064_num_vref(st), st->vref_reg); | 500 | regulator_bulk_disable(ad5064_num_vref(st), st->vref_reg); |
501 | error_free_reg: | ||
502 | if (!st->use_internal_vref) | ||
503 | regulator_bulk_free(ad5064_num_vref(st), st->vref_reg); | ||
504 | error_free: | ||
505 | iio_device_free(indio_dev); | ||
506 | 501 | ||
507 | return ret; | 502 | return ret; |
508 | } | 503 | } |
@@ -514,12 +509,8 @@ static int ad5064_remove(struct device *dev) | |||
514 | 509 | ||
515 | iio_device_unregister(indio_dev); | 510 | iio_device_unregister(indio_dev); |
516 | 511 | ||
517 | if (!st->use_internal_vref) { | 512 | if (!st->use_internal_vref) |
518 | regulator_bulk_disable(ad5064_num_vref(st), st->vref_reg); | 513 | regulator_bulk_disable(ad5064_num_vref(st), st->vref_reg); |
519 | regulator_bulk_free(ad5064_num_vref(st), st->vref_reg); | ||
520 | } | ||
521 | |||
522 | iio_device_free(indio_dev); | ||
523 | 514 | ||
524 | return 0; | 515 | return 0; |
525 | } | 516 | } |
diff --git a/drivers/iio/dac/ad5360.c b/drivers/iio/dac/ad5360.c index 80923af424f2..d2da71ece740 100644 --- a/drivers/iio/dac/ad5360.c +++ b/drivers/iio/dac/ad5360.c | |||
@@ -459,7 +459,7 @@ static int ad5360_probe(struct spi_device *spi) | |||
459 | unsigned int i; | 459 | unsigned int i; |
460 | int ret; | 460 | int ret; |
461 | 461 | ||
462 | indio_dev = iio_device_alloc(sizeof(*st)); | 462 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
463 | if (indio_dev == NULL) { | 463 | if (indio_dev == NULL) { |
464 | dev_err(&spi->dev, "Failed to allocate iio device\n"); | 464 | dev_err(&spi->dev, "Failed to allocate iio device\n"); |
465 | return -ENOMEM; | 465 | return -ENOMEM; |
@@ -480,13 +480,13 @@ static int ad5360_probe(struct spi_device *spi) | |||
480 | ret = ad5360_alloc_channels(indio_dev); | 480 | ret = ad5360_alloc_channels(indio_dev); |
481 | if (ret) { | 481 | if (ret) { |
482 | dev_err(&spi->dev, "Failed to allocate channel spec: %d\n", ret); | 482 | dev_err(&spi->dev, "Failed to allocate channel spec: %d\n", ret); |
483 | goto error_free; | 483 | return ret; |
484 | } | 484 | } |
485 | 485 | ||
486 | for (i = 0; i < st->chip_info->num_vrefs; ++i) | 486 | for (i = 0; i < st->chip_info->num_vrefs; ++i) |
487 | st->vref_reg[i].supply = ad5360_vref_name[i]; | 487 | st->vref_reg[i].supply = ad5360_vref_name[i]; |
488 | 488 | ||
489 | ret = regulator_bulk_get(&st->spi->dev, st->chip_info->num_vrefs, | 489 | ret = devm_regulator_bulk_get(&st->spi->dev, st->chip_info->num_vrefs, |
490 | st->vref_reg); | 490 | st->vref_reg); |
491 | if (ret) { | 491 | if (ret) { |
492 | dev_err(&spi->dev, "Failed to request vref regulators: %d\n", ret); | 492 | dev_err(&spi->dev, "Failed to request vref regulators: %d\n", ret); |
@@ -496,7 +496,7 @@ static int ad5360_probe(struct spi_device *spi) | |||
496 | ret = regulator_bulk_enable(st->chip_info->num_vrefs, st->vref_reg); | 496 | ret = regulator_bulk_enable(st->chip_info->num_vrefs, st->vref_reg); |
497 | if (ret) { | 497 | if (ret) { |
498 | dev_err(&spi->dev, "Failed to enable vref regulators: %d\n", ret); | 498 | dev_err(&spi->dev, "Failed to enable vref regulators: %d\n", ret); |
499 | goto error_free_reg; | 499 | goto error_free_channels; |
500 | } | 500 | } |
501 | 501 | ||
502 | ret = iio_device_register(indio_dev); | 502 | ret = iio_device_register(indio_dev); |
@@ -509,12 +509,8 @@ static int ad5360_probe(struct spi_device *spi) | |||
509 | 509 | ||
510 | error_disable_reg: | 510 | error_disable_reg: |
511 | regulator_bulk_disable(st->chip_info->num_vrefs, st->vref_reg); | 511 | regulator_bulk_disable(st->chip_info->num_vrefs, st->vref_reg); |
512 | error_free_reg: | ||
513 | regulator_bulk_free(st->chip_info->num_vrefs, st->vref_reg); | ||
514 | error_free_channels: | 512 | error_free_channels: |
515 | kfree(indio_dev->channels); | 513 | kfree(indio_dev->channels); |
516 | error_free: | ||
517 | iio_device_free(indio_dev); | ||
518 | 514 | ||
519 | return ret; | 515 | return ret; |
520 | } | 516 | } |
@@ -529,9 +525,6 @@ static int ad5360_remove(struct spi_device *spi) | |||
529 | kfree(indio_dev->channels); | 525 | kfree(indio_dev->channels); |
530 | 526 | ||
531 | regulator_bulk_disable(st->chip_info->num_vrefs, st->vref_reg); | 527 | regulator_bulk_disable(st->chip_info->num_vrefs, st->vref_reg); |
532 | regulator_bulk_free(st->chip_info->num_vrefs, st->vref_reg); | ||
533 | |||
534 | iio_device_free(indio_dev); | ||
535 | 528 | ||
536 | return 0; | 529 | return 0; |
537 | } | 530 | } |
diff --git a/drivers/iio/dac/ad5380.c b/drivers/iio/dac/ad5380.c index bf2db02215c2..1c44ae3920e2 100644 --- a/drivers/iio/dac/ad5380.c +++ b/drivers/iio/dac/ad5380.c | |||
@@ -369,11 +369,10 @@ static int ad5380_probe(struct device *dev, struct regmap *regmap, | |||
369 | unsigned int ctrl = 0; | 369 | unsigned int ctrl = 0; |
370 | int ret; | 370 | int ret; |
371 | 371 | ||
372 | indio_dev = iio_device_alloc(sizeof(*st)); | 372 | indio_dev = devm_iio_device_alloc(dev, sizeof(*st)); |
373 | if (indio_dev == NULL) { | 373 | if (indio_dev == NULL) { |
374 | dev_err(dev, "Failed to allocate iio device\n"); | 374 | dev_err(dev, "Failed to allocate iio device\n"); |
375 | ret = -ENOMEM; | 375 | return -ENOMEM; |
376 | goto error_out; | ||
377 | } | 376 | } |
378 | 377 | ||
379 | st = iio_priv(indio_dev); | 378 | st = iio_priv(indio_dev); |
@@ -391,13 +390,13 @@ static int ad5380_probe(struct device *dev, struct regmap *regmap, | |||
391 | ret = ad5380_alloc_channels(indio_dev); | 390 | ret = ad5380_alloc_channels(indio_dev); |
392 | if (ret) { | 391 | if (ret) { |
393 | dev_err(dev, "Failed to allocate channel spec: %d\n", ret); | 392 | dev_err(dev, "Failed to allocate channel spec: %d\n", ret); |
394 | goto error_free; | 393 | return ret; |
395 | } | 394 | } |
396 | 395 | ||
397 | if (st->chip_info->int_vref == 2500000) | 396 | if (st->chip_info->int_vref == 2500000) |
398 | ctrl |= AD5380_CTRL_INT_VREF_2V5; | 397 | ctrl |= AD5380_CTRL_INT_VREF_2V5; |
399 | 398 | ||
400 | st->vref_reg = regulator_get(dev, "vref"); | 399 | st->vref_reg = devm_regulator_get(dev, "vref"); |
401 | if (!IS_ERR(st->vref_reg)) { | 400 | if (!IS_ERR(st->vref_reg)) { |
402 | ret = regulator_enable(st->vref_reg); | 401 | ret = regulator_enable(st->vref_reg); |
403 | if (ret) { | 402 | if (ret) { |
@@ -434,13 +433,7 @@ error_disable_reg: | |||
434 | if (!IS_ERR(st->vref_reg)) | 433 | if (!IS_ERR(st->vref_reg)) |
435 | regulator_disable(st->vref_reg); | 434 | regulator_disable(st->vref_reg); |
436 | error_free_reg: | 435 | error_free_reg: |
437 | if (!IS_ERR(st->vref_reg)) | ||
438 | regulator_put(st->vref_reg); | ||
439 | |||
440 | kfree(indio_dev->channels); | 436 | kfree(indio_dev->channels); |
441 | error_free: | ||
442 | iio_device_free(indio_dev); | ||
443 | error_out: | ||
444 | 437 | ||
445 | return ret; | 438 | return ret; |
446 | } | 439 | } |
@@ -456,11 +449,8 @@ static int ad5380_remove(struct device *dev) | |||
456 | 449 | ||
457 | if (!IS_ERR(st->vref_reg)) { | 450 | if (!IS_ERR(st->vref_reg)) { |
458 | regulator_disable(st->vref_reg); | 451 | regulator_disable(st->vref_reg); |
459 | regulator_put(st->vref_reg); | ||
460 | } | 452 | } |
461 | 453 | ||
462 | iio_device_free(indio_dev); | ||
463 | |||
464 | return 0; | 454 | return 0; |
465 | } | 455 | } |
466 | 456 | ||
diff --git a/drivers/iio/dac/ad5421.c b/drivers/iio/dac/ad5421.c index 98f24407c3ce..1f78b14abb7d 100644 --- a/drivers/iio/dac/ad5421.c +++ b/drivers/iio/dac/ad5421.c | |||
@@ -451,7 +451,7 @@ static int ad5421_probe(struct spi_device *spi) | |||
451 | struct ad5421_state *st; | 451 | struct ad5421_state *st; |
452 | int ret; | 452 | int ret; |
453 | 453 | ||
454 | indio_dev = iio_device_alloc(sizeof(*st)); | 454 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
455 | if (indio_dev == NULL) { | 455 | if (indio_dev == NULL) { |
456 | dev_err(&spi->dev, "Failed to allocate iio device\n"); | 456 | dev_err(&spi->dev, "Failed to allocate iio device\n"); |
457 | return -ENOMEM; | 457 | return -ENOMEM; |
@@ -484,31 +484,23 @@ static int ad5421_probe(struct spi_device *spi) | |||
484 | ad5421_update_ctrl(indio_dev, 0, 0); | 484 | ad5421_update_ctrl(indio_dev, 0, 0); |
485 | 485 | ||
486 | if (spi->irq) { | 486 | if (spi->irq) { |
487 | ret = request_threaded_irq(spi->irq, | 487 | ret = devm_request_threaded_irq(&spi->dev, spi->irq, |
488 | NULL, | 488 | NULL, |
489 | ad5421_fault_handler, | 489 | ad5421_fault_handler, |
490 | IRQF_TRIGGER_HIGH | IRQF_ONESHOT, | 490 | IRQF_TRIGGER_HIGH | IRQF_ONESHOT, |
491 | "ad5421 fault", | 491 | "ad5421 fault", |
492 | indio_dev); | 492 | indio_dev); |
493 | if (ret) | 493 | if (ret) |
494 | goto error_free; | 494 | return ret; |
495 | } | 495 | } |
496 | 496 | ||
497 | ret = iio_device_register(indio_dev); | 497 | ret = iio_device_register(indio_dev); |
498 | if (ret) { | 498 | if (ret) { |
499 | dev_err(&spi->dev, "Failed to register iio device: %d\n", ret); | 499 | dev_err(&spi->dev, "Failed to register iio device: %d\n", ret); |
500 | goto error_free_irq; | 500 | return ret; |
501 | } | 501 | } |
502 | 502 | ||
503 | return 0; | 503 | return 0; |
504 | |||
505 | error_free_irq: | ||
506 | if (spi->irq) | ||
507 | free_irq(spi->irq, indio_dev); | ||
508 | error_free: | ||
509 | iio_device_free(indio_dev); | ||
510 | |||
511 | return ret; | ||
512 | } | 504 | } |
513 | 505 | ||
514 | static int ad5421_remove(struct spi_device *spi) | 506 | static int ad5421_remove(struct spi_device *spi) |
@@ -516,9 +508,6 @@ static int ad5421_remove(struct spi_device *spi) | |||
516 | struct iio_dev *indio_dev = spi_get_drvdata(spi); | 508 | struct iio_dev *indio_dev = spi_get_drvdata(spi); |
517 | 509 | ||
518 | iio_device_unregister(indio_dev); | 510 | iio_device_unregister(indio_dev); |
519 | if (spi->irq) | ||
520 | free_irq(spi->irq, indio_dev); | ||
521 | iio_device_free(indio_dev); | ||
522 | 511 | ||
523 | return 0; | 512 | return 0; |
524 | } | 513 | } |
diff --git a/drivers/iio/dac/ad5446.c b/drivers/iio/dac/ad5446.c index cae8f6056ac3..96e9ed4c2d01 100644 --- a/drivers/iio/dac/ad5446.c +++ b/drivers/iio/dac/ad5446.c | |||
@@ -220,11 +220,11 @@ static int ad5446_probe(struct device *dev, const char *name, | |||
220 | struct regulator *reg; | 220 | struct regulator *reg; |
221 | int ret, voltage_uv = 0; | 221 | int ret, voltage_uv = 0; |
222 | 222 | ||
223 | reg = regulator_get(dev, "vcc"); | 223 | reg = devm_regulator_get(dev, "vcc"); |
224 | if (!IS_ERR(reg)) { | 224 | if (!IS_ERR(reg)) { |
225 | ret = regulator_enable(reg); | 225 | ret = regulator_enable(reg); |
226 | if (ret) | 226 | if (ret) |
227 | goto error_put_reg; | 227 | return ret; |
228 | 228 | ||
229 | ret = regulator_get_voltage(reg); | 229 | ret = regulator_get_voltage(reg); |
230 | if (ret < 0) | 230 | if (ret < 0) |
@@ -233,7 +233,7 @@ static int ad5446_probe(struct device *dev, const char *name, | |||
233 | voltage_uv = ret; | 233 | voltage_uv = ret; |
234 | } | 234 | } |
235 | 235 | ||
236 | indio_dev = iio_device_alloc(sizeof(*st)); | 236 | indio_dev = devm_iio_device_alloc(dev, sizeof(*st)); |
237 | if (indio_dev == NULL) { | 237 | if (indio_dev == NULL) { |
238 | ret = -ENOMEM; | 238 | ret = -ENOMEM; |
239 | goto error_disable_reg; | 239 | goto error_disable_reg; |
@@ -264,19 +264,13 @@ static int ad5446_probe(struct device *dev, const char *name, | |||
264 | 264 | ||
265 | ret = iio_device_register(indio_dev); | 265 | ret = iio_device_register(indio_dev); |
266 | if (ret) | 266 | if (ret) |
267 | goto error_free_device; | 267 | goto error_disable_reg; |
268 | 268 | ||
269 | return 0; | 269 | return 0; |
270 | 270 | ||
271 | error_free_device: | ||
272 | iio_device_free(indio_dev); | ||
273 | error_disable_reg: | 271 | error_disable_reg: |
274 | if (!IS_ERR(reg)) | 272 | if (!IS_ERR(reg)) |
275 | regulator_disable(reg); | 273 | regulator_disable(reg); |
276 | error_put_reg: | ||
277 | if (!IS_ERR(reg)) | ||
278 | regulator_put(reg); | ||
279 | |||
280 | return ret; | 274 | return ret; |
281 | } | 275 | } |
282 | 276 | ||
@@ -286,11 +280,8 @@ static int ad5446_remove(struct device *dev) | |||
286 | struct ad5446_state *st = iio_priv(indio_dev); | 280 | struct ad5446_state *st = iio_priv(indio_dev); |
287 | 281 | ||
288 | iio_device_unregister(indio_dev); | 282 | iio_device_unregister(indio_dev); |
289 | if (!IS_ERR(st->reg)) { | 283 | if (!IS_ERR(st->reg)) |
290 | regulator_disable(st->reg); | 284 | regulator_disable(st->reg); |
291 | regulator_put(st->reg); | ||
292 | } | ||
293 | iio_device_free(indio_dev); | ||
294 | 285 | ||
295 | return 0; | 286 | return 0; |
296 | } | 287 | } |
diff --git a/drivers/iio/dac/ad5449.c b/drivers/iio/dac/ad5449.c index ba1c914b0399..fff7d0762c0c 100644 --- a/drivers/iio/dac/ad5449.c +++ b/drivers/iio/dac/ad5449.c | |||
@@ -275,7 +275,7 @@ static int ad5449_spi_probe(struct spi_device *spi) | |||
275 | unsigned int i; | 275 | unsigned int i; |
276 | int ret; | 276 | int ret; |
277 | 277 | ||
278 | indio_dev = iio_device_alloc(sizeof(*st)); | 278 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
279 | if (indio_dev == NULL) | 279 | if (indio_dev == NULL) |
280 | return -ENOMEM; | 280 | return -ENOMEM; |
281 | 281 | ||
@@ -288,14 +288,14 @@ static int ad5449_spi_probe(struct spi_device *spi) | |||
288 | for (i = 0; i < st->chip_info->num_channels; ++i) | 288 | for (i = 0; i < st->chip_info->num_channels; ++i) |
289 | st->vref_reg[i].supply = ad5449_vref_name(st, i); | 289 | st->vref_reg[i].supply = ad5449_vref_name(st, i); |
290 | 290 | ||
291 | ret = regulator_bulk_get(&spi->dev, st->chip_info->num_channels, | 291 | ret = devm_regulator_bulk_get(&spi->dev, st->chip_info->num_channels, |
292 | st->vref_reg); | 292 | st->vref_reg); |
293 | if (ret) | 293 | if (ret) |
294 | goto error_free; | 294 | return ret; |
295 | 295 | ||
296 | ret = regulator_bulk_enable(st->chip_info->num_channels, st->vref_reg); | 296 | ret = regulator_bulk_enable(st->chip_info->num_channels, st->vref_reg); |
297 | if (ret) | 297 | if (ret) |
298 | goto error_free_reg; | 298 | return ret; |
299 | 299 | ||
300 | indio_dev->dev.parent = &spi->dev; | 300 | indio_dev->dev.parent = &spi->dev; |
301 | indio_dev->name = id->name; | 301 | indio_dev->name = id->name; |
@@ -325,10 +325,6 @@ static int ad5449_spi_probe(struct spi_device *spi) | |||
325 | 325 | ||
326 | error_disable_reg: | 326 | error_disable_reg: |
327 | regulator_bulk_disable(st->chip_info->num_channels, st->vref_reg); | 327 | regulator_bulk_disable(st->chip_info->num_channels, st->vref_reg); |
328 | error_free_reg: | ||
329 | regulator_bulk_free(st->chip_info->num_channels, st->vref_reg); | ||
330 | error_free: | ||
331 | iio_device_free(indio_dev); | ||
332 | 328 | ||
333 | return ret; | 329 | return ret; |
334 | } | 330 | } |
@@ -341,9 +337,6 @@ static int ad5449_spi_remove(struct spi_device *spi) | |||
341 | iio_device_unregister(indio_dev); | 337 | iio_device_unregister(indio_dev); |
342 | 338 | ||
343 | regulator_bulk_disable(st->chip_info->num_channels, st->vref_reg); | 339 | regulator_bulk_disable(st->chip_info->num_channels, st->vref_reg); |
344 | regulator_bulk_free(st->chip_info->num_channels, st->vref_reg); | ||
345 | |||
346 | iio_device_free(indio_dev); | ||
347 | 340 | ||
348 | return 0; | 341 | return 0; |
349 | } | 342 | } |
diff --git a/drivers/iio/dac/ad5504.c b/drivers/iio/dac/ad5504.c index 139206e84cb7..caffb16bc05c 100644 --- a/drivers/iio/dac/ad5504.c +++ b/drivers/iio/dac/ad5504.c | |||
@@ -281,16 +281,14 @@ static int ad5504_probe(struct spi_device *spi) | |||
281 | struct regulator *reg; | 281 | struct regulator *reg; |
282 | int ret, voltage_uv = 0; | 282 | int ret, voltage_uv = 0; |
283 | 283 | ||
284 | indio_dev = iio_device_alloc(sizeof(*st)); | 284 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
285 | if (indio_dev == NULL) { | 285 | if (!indio_dev) |
286 | ret = -ENOMEM; | 286 | return -ENOMEM; |
287 | goto error_ret; | 287 | reg = devm_regulator_get(&spi->dev, "vcc"); |
288 | } | ||
289 | reg = regulator_get(&spi->dev, "vcc"); | ||
290 | if (!IS_ERR(reg)) { | 288 | if (!IS_ERR(reg)) { |
291 | ret = regulator_enable(reg); | 289 | ret = regulator_enable(reg); |
292 | if (ret) | 290 | if (ret) |
293 | goto error_put_reg; | 291 | return ret; |
294 | 292 | ||
295 | ret = regulator_get_voltage(reg); | 293 | ret = regulator_get_voltage(reg); |
296 | if (ret < 0) | 294 | if (ret < 0) |
@@ -321,7 +319,7 @@ static int ad5504_probe(struct spi_device *spi) | |||
321 | indio_dev->modes = INDIO_DIRECT_MODE; | 319 | indio_dev->modes = INDIO_DIRECT_MODE; |
322 | 320 | ||
323 | if (spi->irq) { | 321 | if (spi->irq) { |
324 | ret = request_threaded_irq(spi->irq, | 322 | ret = devm_request_threaded_irq(&spi->dev, spi->irq, |
325 | NULL, | 323 | NULL, |
326 | &ad5504_event_handler, | 324 | &ad5504_event_handler, |
327 | IRQF_TRIGGER_FALLING | IRQF_ONESHOT, | 325 | IRQF_TRIGGER_FALLING | IRQF_ONESHOT, |
@@ -333,22 +331,14 @@ static int ad5504_probe(struct spi_device *spi) | |||
333 | 331 | ||
334 | ret = iio_device_register(indio_dev); | 332 | ret = iio_device_register(indio_dev); |
335 | if (ret) | 333 | if (ret) |
336 | goto error_free_irq; | 334 | goto error_disable_reg; |
337 | 335 | ||
338 | return 0; | 336 | return 0; |
339 | 337 | ||
340 | error_free_irq: | ||
341 | if (spi->irq) | ||
342 | free_irq(spi->irq, indio_dev); | ||
343 | error_disable_reg: | 338 | error_disable_reg: |
344 | if (!IS_ERR(reg)) | 339 | if (!IS_ERR(reg)) |
345 | regulator_disable(reg); | 340 | regulator_disable(reg); |
346 | error_put_reg: | ||
347 | if (!IS_ERR(reg)) | ||
348 | regulator_put(reg); | ||
349 | 341 | ||
350 | iio_device_free(indio_dev); | ||
351 | error_ret: | ||
352 | return ret; | 342 | return ret; |
353 | } | 343 | } |
354 | 344 | ||
@@ -358,14 +348,9 @@ static int ad5504_remove(struct spi_device *spi) | |||
358 | struct ad5504_state *st = iio_priv(indio_dev); | 348 | struct ad5504_state *st = iio_priv(indio_dev); |
359 | 349 | ||
360 | iio_device_unregister(indio_dev); | 350 | iio_device_unregister(indio_dev); |
361 | if (spi->irq) | ||
362 | free_irq(spi->irq, indio_dev); | ||
363 | 351 | ||
364 | if (!IS_ERR(st->reg)) { | 352 | if (!IS_ERR(st->reg)) |
365 | regulator_disable(st->reg); | 353 | regulator_disable(st->reg); |
366 | regulator_put(st->reg); | ||
367 | } | ||
368 | iio_device_free(indio_dev); | ||
369 | 354 | ||
370 | return 0; | 355 | return 0; |
371 | } | 356 | } |
diff --git a/drivers/iio/dac/ad5624r_spi.c b/drivers/iio/dac/ad5624r_spi.c index bb298aaff321..714af757cd56 100644 --- a/drivers/iio/dac/ad5624r_spi.c +++ b/drivers/iio/dac/ad5624r_spi.c | |||
@@ -226,17 +226,15 @@ static int ad5624r_probe(struct spi_device *spi) | |||
226 | struct iio_dev *indio_dev; | 226 | struct iio_dev *indio_dev; |
227 | int ret, voltage_uv = 0; | 227 | int ret, voltage_uv = 0; |
228 | 228 | ||
229 | indio_dev = iio_device_alloc(sizeof(*st)); | 229 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
230 | if (indio_dev == NULL) { | 230 | if (!indio_dev) |
231 | ret = -ENOMEM; | 231 | return -ENOMEM; |
232 | goto error_ret; | ||
233 | } | ||
234 | st = iio_priv(indio_dev); | 232 | st = iio_priv(indio_dev); |
235 | st->reg = regulator_get(&spi->dev, "vcc"); | 233 | st->reg = devm_regulator_get(&spi->dev, "vcc"); |
236 | if (!IS_ERR(st->reg)) { | 234 | if (!IS_ERR(st->reg)) { |
237 | ret = regulator_enable(st->reg); | 235 | ret = regulator_enable(st->reg); |
238 | if (ret) | 236 | if (ret) |
239 | goto error_put_reg; | 237 | return ret; |
240 | 238 | ||
241 | ret = regulator_get_voltage(st->reg); | 239 | ret = regulator_get_voltage(st->reg); |
242 | if (ret < 0) | 240 | if (ret < 0) |
@@ -277,11 +275,6 @@ static int ad5624r_probe(struct spi_device *spi) | |||
277 | error_disable_reg: | 275 | error_disable_reg: |
278 | if (!IS_ERR(st->reg)) | 276 | if (!IS_ERR(st->reg)) |
279 | regulator_disable(st->reg); | 277 | regulator_disable(st->reg); |
280 | error_put_reg: | ||
281 | if (!IS_ERR(st->reg)) | ||
282 | regulator_put(st->reg); | ||
283 | iio_device_free(indio_dev); | ||
284 | error_ret: | ||
285 | 278 | ||
286 | return ret; | 279 | return ret; |
287 | } | 280 | } |
@@ -292,11 +285,8 @@ static int ad5624r_remove(struct spi_device *spi) | |||
292 | struct ad5624r_state *st = iio_priv(indio_dev); | 285 | struct ad5624r_state *st = iio_priv(indio_dev); |
293 | 286 | ||
294 | iio_device_unregister(indio_dev); | 287 | iio_device_unregister(indio_dev); |
295 | if (!IS_ERR(st->reg)) { | 288 | if (!IS_ERR(st->reg)) |
296 | regulator_disable(st->reg); | 289 | regulator_disable(st->reg); |
297 | regulator_put(st->reg); | ||
298 | } | ||
299 | iio_device_free(indio_dev); | ||
300 | 290 | ||
301 | return 0; | 291 | return 0; |
302 | } | 292 | } |
diff --git a/drivers/iio/dac/ad5686.c b/drivers/iio/dac/ad5686.c index 06439b1af9b6..57825ead7db2 100644 --- a/drivers/iio/dac/ad5686.c +++ b/drivers/iio/dac/ad5686.c | |||
@@ -314,18 +314,18 @@ static int ad5686_probe(struct spi_device *spi) | |||
314 | struct iio_dev *indio_dev; | 314 | struct iio_dev *indio_dev; |
315 | int ret, regdone = 0, voltage_uv = 0; | 315 | int ret, regdone = 0, voltage_uv = 0; |
316 | 316 | ||
317 | indio_dev = iio_device_alloc(sizeof(*st)); | 317 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
318 | if (indio_dev == NULL) | 318 | if (indio_dev == NULL) |
319 | return -ENOMEM; | 319 | return -ENOMEM; |
320 | 320 | ||
321 | st = iio_priv(indio_dev); | 321 | st = iio_priv(indio_dev); |
322 | spi_set_drvdata(spi, indio_dev); | 322 | spi_set_drvdata(spi, indio_dev); |
323 | 323 | ||
324 | st->reg = regulator_get(&spi->dev, "vcc"); | 324 | st->reg = devm_regulator_get(&spi->dev, "vcc"); |
325 | if (!IS_ERR(st->reg)) { | 325 | if (!IS_ERR(st->reg)) { |
326 | ret = regulator_enable(st->reg); | 326 | ret = regulator_enable(st->reg); |
327 | if (ret) | 327 | if (ret) |
328 | goto error_put_reg; | 328 | return ret; |
329 | 329 | ||
330 | ret = regulator_get_voltage(st->reg); | 330 | ret = regulator_get_voltage(st->reg); |
331 | if (ret < 0) | 331 | if (ret < 0) |
@@ -369,12 +369,6 @@ static int ad5686_probe(struct spi_device *spi) | |||
369 | error_disable_reg: | 369 | error_disable_reg: |
370 | if (!IS_ERR(st->reg)) | 370 | if (!IS_ERR(st->reg)) |
371 | regulator_disable(st->reg); | 371 | regulator_disable(st->reg); |
372 | error_put_reg: | ||
373 | if (!IS_ERR(st->reg)) | ||
374 | regulator_put(st->reg); | ||
375 | |||
376 | iio_device_free(indio_dev); | ||
377 | |||
378 | return ret; | 372 | return ret; |
379 | } | 373 | } |
380 | 374 | ||
@@ -384,11 +378,8 @@ static int ad5686_remove(struct spi_device *spi) | |||
384 | struct ad5686_state *st = iio_priv(indio_dev); | 378 | struct ad5686_state *st = iio_priv(indio_dev); |
385 | 379 | ||
386 | iio_device_unregister(indio_dev); | 380 | iio_device_unregister(indio_dev); |
387 | if (!IS_ERR(st->reg)) { | 381 | if (!IS_ERR(st->reg)) |
388 | regulator_disable(st->reg); | 382 | regulator_disable(st->reg); |
389 | regulator_put(st->reg); | ||
390 | } | ||
391 | iio_device_free(indio_dev); | ||
392 | 383 | ||
393 | return 0; | 384 | return 0; |
394 | } | 385 | } |
diff --git a/drivers/iio/dac/ad5755.c b/drivers/iio/dac/ad5755.c index 12bb315e55f8..36a4361aece1 100644 --- a/drivers/iio/dac/ad5755.c +++ b/drivers/iio/dac/ad5755.c | |||
@@ -565,7 +565,7 @@ static int ad5755_probe(struct spi_device *spi) | |||
565 | struct ad5755_state *st; | 565 | struct ad5755_state *st; |
566 | int ret; | 566 | int ret; |
567 | 567 | ||
568 | indio_dev = iio_device_alloc(sizeof(*st)); | 568 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
569 | if (indio_dev == NULL) { | 569 | if (indio_dev == NULL) { |
570 | dev_err(&spi->dev, "Failed to allocate iio device\n"); | 570 | dev_err(&spi->dev, "Failed to allocate iio device\n"); |
571 | return -ENOMEM; | 571 | return -ENOMEM; |
@@ -589,24 +589,19 @@ static int ad5755_probe(struct spi_device *spi) | |||
589 | 589 | ||
590 | ret = ad5755_init_channels(indio_dev, pdata); | 590 | ret = ad5755_init_channels(indio_dev, pdata); |
591 | if (ret) | 591 | if (ret) |
592 | goto error_free; | 592 | return ret; |
593 | 593 | ||
594 | ret = ad5755_setup_pdata(indio_dev, pdata); | 594 | ret = ad5755_setup_pdata(indio_dev, pdata); |
595 | if (ret) | 595 | if (ret) |
596 | goto error_free; | 596 | return ret; |
597 | 597 | ||
598 | ret = iio_device_register(indio_dev); | 598 | ret = iio_device_register(indio_dev); |
599 | if (ret) { | 599 | if (ret) { |
600 | dev_err(&spi->dev, "Failed to register iio device: %d\n", ret); | 600 | dev_err(&spi->dev, "Failed to register iio device: %d\n", ret); |
601 | goto error_free; | 601 | return ret; |
602 | } | 602 | } |
603 | 603 | ||
604 | return 0; | 604 | return 0; |
605 | |||
606 | error_free: | ||
607 | iio_device_free(indio_dev); | ||
608 | |||
609 | return ret; | ||
610 | } | 605 | } |
611 | 606 | ||
612 | static int ad5755_remove(struct spi_device *spi) | 607 | static int ad5755_remove(struct spi_device *spi) |
@@ -614,7 +609,6 @@ static int ad5755_remove(struct spi_device *spi) | |||
614 | struct iio_dev *indio_dev = spi_get_drvdata(spi); | 609 | struct iio_dev *indio_dev = spi_get_drvdata(spi); |
615 | 610 | ||
616 | iio_device_unregister(indio_dev); | 611 | iio_device_unregister(indio_dev); |
617 | iio_device_free(indio_dev); | ||
618 | 612 | ||
619 | return 0; | 613 | return 0; |
620 | } | 614 | } |
diff --git a/drivers/iio/dac/ad5764.c b/drivers/iio/dac/ad5764.c index 7a53f7d70dac..df7e028d9db5 100644 --- a/drivers/iio/dac/ad5764.c +++ b/drivers/iio/dac/ad5764.c | |||
@@ -275,7 +275,7 @@ static int ad5764_probe(struct spi_device *spi) | |||
275 | struct ad5764_state *st; | 275 | struct ad5764_state *st; |
276 | int ret; | 276 | int ret; |
277 | 277 | ||
278 | indio_dev = iio_device_alloc(sizeof(*st)); | 278 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
279 | if (indio_dev == NULL) { | 279 | if (indio_dev == NULL) { |
280 | dev_err(&spi->dev, "Failed to allocate iio device\n"); | 280 | dev_err(&spi->dev, "Failed to allocate iio device\n"); |
281 | return -ENOMEM; | 281 | return -ENOMEM; |
@@ -298,12 +298,12 @@ static int ad5764_probe(struct spi_device *spi) | |||
298 | st->vref_reg[0].supply = "vrefAB"; | 298 | st->vref_reg[0].supply = "vrefAB"; |
299 | st->vref_reg[1].supply = "vrefCD"; | 299 | st->vref_reg[1].supply = "vrefCD"; |
300 | 300 | ||
301 | ret = regulator_bulk_get(&st->spi->dev, | 301 | ret = devm_regulator_bulk_get(&st->spi->dev, |
302 | ARRAY_SIZE(st->vref_reg), st->vref_reg); | 302 | ARRAY_SIZE(st->vref_reg), st->vref_reg); |
303 | if (ret) { | 303 | if (ret) { |
304 | dev_err(&spi->dev, "Failed to request vref regulators: %d\n", | 304 | dev_err(&spi->dev, "Failed to request vref regulators: %d\n", |
305 | ret); | 305 | ret); |
306 | goto error_free; | 306 | return ret; |
307 | } | 307 | } |
308 | 308 | ||
309 | ret = regulator_bulk_enable(ARRAY_SIZE(st->vref_reg), | 309 | ret = regulator_bulk_enable(ARRAY_SIZE(st->vref_reg), |
@@ -311,7 +311,7 @@ static int ad5764_probe(struct spi_device *spi) | |||
311 | if (ret) { | 311 | if (ret) { |
312 | dev_err(&spi->dev, "Failed to enable vref regulators: %d\n", | 312 | dev_err(&spi->dev, "Failed to enable vref regulators: %d\n", |
313 | ret); | 313 | ret); |
314 | goto error_free_reg; | 314 | return ret; |
315 | } | 315 | } |
316 | } | 316 | } |
317 | 317 | ||
@@ -326,12 +326,6 @@ static int ad5764_probe(struct spi_device *spi) | |||
326 | error_disable_reg: | 326 | error_disable_reg: |
327 | if (st->chip_info->int_vref == 0) | 327 | if (st->chip_info->int_vref == 0) |
328 | regulator_bulk_disable(ARRAY_SIZE(st->vref_reg), st->vref_reg); | 328 | regulator_bulk_disable(ARRAY_SIZE(st->vref_reg), st->vref_reg); |
329 | error_free_reg: | ||
330 | if (st->chip_info->int_vref == 0) | ||
331 | regulator_bulk_free(ARRAY_SIZE(st->vref_reg), st->vref_reg); | ||
332 | error_free: | ||
333 | iio_device_free(indio_dev); | ||
334 | |||
335 | return ret; | 329 | return ret; |
336 | } | 330 | } |
337 | 331 | ||
@@ -342,12 +336,8 @@ static int ad5764_remove(struct spi_device *spi) | |||
342 | 336 | ||
343 | iio_device_unregister(indio_dev); | 337 | iio_device_unregister(indio_dev); |
344 | 338 | ||
345 | if (st->chip_info->int_vref == 0) { | 339 | if (st->chip_info->int_vref == 0) |
346 | regulator_bulk_disable(ARRAY_SIZE(st->vref_reg), st->vref_reg); | 340 | regulator_bulk_disable(ARRAY_SIZE(st->vref_reg), st->vref_reg); |
347 | regulator_bulk_free(ARRAY_SIZE(st->vref_reg), st->vref_reg); | ||
348 | } | ||
349 | |||
350 | iio_device_free(indio_dev); | ||
351 | 341 | ||
352 | return 0; | 342 | return 0; |
353 | } | 343 | } |
diff --git a/drivers/iio/dac/ad5791.c b/drivers/iio/dac/ad5791.c index 97c1e5d780df..ce7458963309 100644 --- a/drivers/iio/dac/ad5791.c +++ b/drivers/iio/dac/ad5791.c | |||
@@ -349,17 +349,15 @@ static int ad5791_probe(struct spi_device *spi) | |||
349 | struct ad5791_state *st; | 349 | struct ad5791_state *st; |
350 | int ret, pos_voltage_uv = 0, neg_voltage_uv = 0; | 350 | int ret, pos_voltage_uv = 0, neg_voltage_uv = 0; |
351 | 351 | ||
352 | indio_dev = iio_device_alloc(sizeof(*st)); | 352 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
353 | if (indio_dev == NULL) { | 353 | if (!indio_dev) |
354 | ret = -ENOMEM; | 354 | return -ENOMEM; |
355 | goto error_ret; | ||
356 | } | ||
357 | st = iio_priv(indio_dev); | 355 | st = iio_priv(indio_dev); |
358 | st->reg_vdd = regulator_get(&spi->dev, "vdd"); | 356 | st->reg_vdd = devm_regulator_get(&spi->dev, "vdd"); |
359 | if (!IS_ERR(st->reg_vdd)) { | 357 | if (!IS_ERR(st->reg_vdd)) { |
360 | ret = regulator_enable(st->reg_vdd); | 358 | ret = regulator_enable(st->reg_vdd); |
361 | if (ret) | 359 | if (ret) |
362 | goto error_put_reg_pos; | 360 | return ret; |
363 | 361 | ||
364 | ret = regulator_get_voltage(st->reg_vdd); | 362 | ret = regulator_get_voltage(st->reg_vdd); |
365 | if (ret < 0) | 363 | if (ret < 0) |
@@ -368,11 +366,11 @@ static int ad5791_probe(struct spi_device *spi) | |||
368 | pos_voltage_uv = ret; | 366 | pos_voltage_uv = ret; |
369 | } | 367 | } |
370 | 368 | ||
371 | st->reg_vss = regulator_get(&spi->dev, "vss"); | 369 | st->reg_vss = devm_regulator_get(&spi->dev, "vss"); |
372 | if (!IS_ERR(st->reg_vss)) { | 370 | if (!IS_ERR(st->reg_vss)) { |
373 | ret = regulator_enable(st->reg_vss); | 371 | ret = regulator_enable(st->reg_vss); |
374 | if (ret) | 372 | if (ret) |
375 | goto error_put_reg_neg; | 373 | goto error_disable_reg_pos; |
376 | 374 | ||
377 | ret = regulator_get_voltage(st->reg_vss); | 375 | ret = regulator_get_voltage(st->reg_vss); |
378 | if (ret < 0) | 376 | if (ret < 0) |
@@ -428,19 +426,9 @@ static int ad5791_probe(struct spi_device *spi) | |||
428 | error_disable_reg_neg: | 426 | error_disable_reg_neg: |
429 | if (!IS_ERR(st->reg_vss)) | 427 | if (!IS_ERR(st->reg_vss)) |
430 | regulator_disable(st->reg_vss); | 428 | regulator_disable(st->reg_vss); |
431 | error_put_reg_neg: | ||
432 | if (!IS_ERR(st->reg_vss)) | ||
433 | regulator_put(st->reg_vss); | ||
434 | |||
435 | error_disable_reg_pos: | 429 | error_disable_reg_pos: |
436 | if (!IS_ERR(st->reg_vdd)) | 430 | if (!IS_ERR(st->reg_vdd)) |
437 | regulator_disable(st->reg_vdd); | 431 | regulator_disable(st->reg_vdd); |
438 | error_put_reg_pos: | ||
439 | if (!IS_ERR(st->reg_vdd)) | ||
440 | regulator_put(st->reg_vdd); | ||
441 | iio_device_free(indio_dev); | ||
442 | error_ret: | ||
443 | |||
444 | return ret; | 432 | return ret; |
445 | } | 433 | } |
446 | 434 | ||
@@ -450,16 +438,11 @@ static int ad5791_remove(struct spi_device *spi) | |||
450 | struct ad5791_state *st = iio_priv(indio_dev); | 438 | struct ad5791_state *st = iio_priv(indio_dev); |
451 | 439 | ||
452 | iio_device_unregister(indio_dev); | 440 | iio_device_unregister(indio_dev); |
453 | if (!IS_ERR(st->reg_vdd)) { | 441 | if (!IS_ERR(st->reg_vdd)) |
454 | regulator_disable(st->reg_vdd); | 442 | regulator_disable(st->reg_vdd); |
455 | regulator_put(st->reg_vdd); | ||
456 | } | ||
457 | 443 | ||
458 | if (!IS_ERR(st->reg_vss)) { | 444 | if (!IS_ERR(st->reg_vss)) |
459 | regulator_disable(st->reg_vss); | 445 | regulator_disable(st->reg_vss); |
460 | regulator_put(st->reg_vss); | ||
461 | } | ||
462 | iio_device_free(indio_dev); | ||
463 | 446 | ||
464 | return 0; | 447 | return 0; |
465 | } | 448 | } |
diff --git a/drivers/iio/dac/ad7303.c b/drivers/iio/dac/ad7303.c index d546f50f9258..ed2d276477bd 100644 --- a/drivers/iio/dac/ad7303.c +++ b/drivers/iio/dac/ad7303.c | |||
@@ -203,7 +203,7 @@ static int ad7303_probe(struct spi_device *spi) | |||
203 | bool ext_ref; | 203 | bool ext_ref; |
204 | int ret; | 204 | int ret; |
205 | 205 | ||
206 | indio_dev = iio_device_alloc(sizeof(*st)); | 206 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
207 | if (indio_dev == NULL) | 207 | if (indio_dev == NULL) |
208 | return -ENOMEM; | 208 | return -ENOMEM; |
209 | 209 | ||
@@ -212,15 +212,13 @@ static int ad7303_probe(struct spi_device *spi) | |||
212 | 212 | ||
213 | st->spi = spi; | 213 | st->spi = spi; |
214 | 214 | ||
215 | st->vdd_reg = regulator_get(&spi->dev, "Vdd"); | 215 | st->vdd_reg = devm_regulator_get(&spi->dev, "Vdd"); |
216 | if (IS_ERR(st->vdd_reg)) { | 216 | if (IS_ERR(st->vdd_reg)) |
217 | ret = PTR_ERR(st->vdd_reg); | 217 | return PTR_ERR(st->vdd_reg); |
218 | goto err_free; | ||
219 | } | ||
220 | 218 | ||
221 | ret = regulator_enable(st->vdd_reg); | 219 | ret = regulator_enable(st->vdd_reg); |
222 | if (ret) | 220 | if (ret) |
223 | goto err_put_vdd_reg; | 221 | return ret; |
224 | 222 | ||
225 | if (spi->dev.of_node) { | 223 | if (spi->dev.of_node) { |
226 | ext_ref = of_property_read_bool(spi->dev.of_node, | 224 | ext_ref = of_property_read_bool(spi->dev.of_node, |
@@ -234,7 +232,7 @@ static int ad7303_probe(struct spi_device *spi) | |||
234 | } | 232 | } |
235 | 233 | ||
236 | if (ext_ref) { | 234 | if (ext_ref) { |
237 | st->vref_reg = regulator_get(&spi->dev, "REF"); | 235 | st->vref_reg = devm_regulator_get(&spi->dev, "REF"); |
238 | if (IS_ERR(st->vref_reg)) { | 236 | if (IS_ERR(st->vref_reg)) { |
239 | ret = PTR_ERR(st->vref_reg); | 237 | ret = PTR_ERR(st->vref_reg); |
240 | goto err_disable_vdd_reg; | 238 | goto err_disable_vdd_reg; |
@@ -242,7 +240,7 @@ static int ad7303_probe(struct spi_device *spi) | |||
242 | 240 | ||
243 | ret = regulator_enable(st->vref_reg); | 241 | ret = regulator_enable(st->vref_reg); |
244 | if (ret) | 242 | if (ret) |
245 | goto err_put_vref_reg; | 243 | goto err_disable_vdd_reg; |
246 | 244 | ||
247 | st->config |= AD7303_CFG_EXTERNAL_VREF; | 245 | st->config |= AD7303_CFG_EXTERNAL_VREF; |
248 | } | 246 | } |
@@ -263,16 +261,8 @@ static int ad7303_probe(struct spi_device *spi) | |||
263 | err_disable_vref_reg: | 261 | err_disable_vref_reg: |
264 | if (st->vref_reg) | 262 | if (st->vref_reg) |
265 | regulator_disable(st->vref_reg); | 263 | regulator_disable(st->vref_reg); |
266 | err_put_vref_reg: | ||
267 | if (st->vref_reg) | ||
268 | regulator_put(st->vref_reg); | ||
269 | err_disable_vdd_reg: | 264 | err_disable_vdd_reg: |
270 | regulator_disable(st->vdd_reg); | 265 | regulator_disable(st->vdd_reg); |
271 | err_put_vdd_reg: | ||
272 | regulator_put(st->vdd_reg); | ||
273 | err_free: | ||
274 | iio_device_free(indio_dev); | ||
275 | |||
276 | return ret; | 266 | return ret; |
277 | } | 267 | } |
278 | 268 | ||
@@ -283,14 +273,9 @@ static int ad7303_remove(struct spi_device *spi) | |||
283 | 273 | ||
284 | iio_device_unregister(indio_dev); | 274 | iio_device_unregister(indio_dev); |
285 | 275 | ||
286 | if (st->vref_reg) { | 276 | if (st->vref_reg) |
287 | regulator_disable(st->vref_reg); | 277 | regulator_disable(st->vref_reg); |
288 | regulator_put(st->vref_reg); | ||
289 | } | ||
290 | regulator_disable(st->vdd_reg); | 278 | regulator_disable(st->vdd_reg); |
291 | regulator_put(st->vdd_reg); | ||
292 | |||
293 | iio_device_free(indio_dev); | ||
294 | 279 | ||
295 | return 0; | 280 | return 0; |
296 | } | 281 | } |
diff --git a/drivers/iio/dac/max517.c b/drivers/iio/dac/max517.c index ebfaa4156246..83adcbf1a205 100644 --- a/drivers/iio/dac/max517.c +++ b/drivers/iio/dac/max517.c | |||
@@ -164,11 +164,9 @@ static int max517_probe(struct i2c_client *client, | |||
164 | struct max517_platform_data *platform_data = client->dev.platform_data; | 164 | struct max517_platform_data *platform_data = client->dev.platform_data; |
165 | int err; | 165 | int err; |
166 | 166 | ||
167 | indio_dev = iio_device_alloc(sizeof(*data)); | 167 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*data)); |
168 | if (indio_dev == NULL) { | 168 | if (!indio_dev) |
169 | err = -ENOMEM; | 169 | return -ENOMEM; |
170 | goto exit; | ||
171 | } | ||
172 | data = iio_priv(indio_dev); | 170 | data = iio_priv(indio_dev); |
173 | i2c_set_clientdata(client, indio_dev); | 171 | i2c_set_clientdata(client, indio_dev); |
174 | data->client = client; | 172 | data->client = client; |
@@ -198,23 +196,16 @@ static int max517_probe(struct i2c_client *client, | |||
198 | 196 | ||
199 | err = iio_device_register(indio_dev); | 197 | err = iio_device_register(indio_dev); |
200 | if (err) | 198 | if (err) |
201 | goto exit_free_device; | 199 | return err; |
202 | 200 | ||
203 | dev_info(&client->dev, "DAC registered\n"); | 201 | dev_info(&client->dev, "DAC registered\n"); |
204 | 202 | ||
205 | return 0; | 203 | return 0; |
206 | |||
207 | exit_free_device: | ||
208 | iio_device_free(indio_dev); | ||
209 | exit: | ||
210 | return err; | ||
211 | } | 204 | } |
212 | 205 | ||
213 | static int max517_remove(struct i2c_client *client) | 206 | static int max517_remove(struct i2c_client *client) |
214 | { | 207 | { |
215 | iio_device_unregister(i2c_get_clientdata(client)); | 208 | iio_device_unregister(i2c_get_clientdata(client)); |
216 | iio_device_free(i2c_get_clientdata(client)); | ||
217 | |||
218 | return 0; | 209 | return 0; |
219 | } | 210 | } |
220 | 211 | ||
diff --git a/drivers/iio/dac/mcp4725.c b/drivers/iio/dac/mcp4725.c index a612ec766d96..1f4a48e6a82c 100644 --- a/drivers/iio/dac/mcp4725.c +++ b/drivers/iio/dac/mcp4725.c | |||
@@ -12,14 +12,13 @@ | |||
12 | * driver for the Microchip I2C 12-bit digital-to-analog converter (DAC) | 12 | * driver for the Microchip I2C 12-bit digital-to-analog converter (DAC) |
13 | * (7-bit I2C slave address 0x60, the three LSBs can be configured in | 13 | * (7-bit I2C slave address 0x60, the three LSBs can be configured in |
14 | * hardware) | 14 | * hardware) |
15 | * | ||
16 | * writing the DAC value to EEPROM is not supported | ||
17 | */ | 15 | */ |
18 | 16 | ||
19 | #include <linux/module.h> | 17 | #include <linux/module.h> |
20 | #include <linux/init.h> | 18 | #include <linux/init.h> |
21 | #include <linux/i2c.h> | 19 | #include <linux/i2c.h> |
22 | #include <linux/err.h> | 20 | #include <linux/err.h> |
21 | #include <linux/delay.h> | ||
23 | 22 | ||
24 | #include <linux/iio/iio.h> | 23 | #include <linux/iio/iio.h> |
25 | #include <linux/iio/sysfs.h> | 24 | #include <linux/iio/sysfs.h> |
@@ -32,15 +31,19 @@ struct mcp4725_data { | |||
32 | struct i2c_client *client; | 31 | struct i2c_client *client; |
33 | u16 vref_mv; | 32 | u16 vref_mv; |
34 | u16 dac_value; | 33 | u16 dac_value; |
34 | bool powerdown; | ||
35 | unsigned powerdown_mode; | ||
35 | }; | 36 | }; |
36 | 37 | ||
37 | #ifdef CONFIG_PM_SLEEP | ||
38 | static int mcp4725_suspend(struct device *dev) | 38 | static int mcp4725_suspend(struct device *dev) |
39 | { | 39 | { |
40 | struct iio_dev *indio_dev = dev_to_iio_dev(dev); | ||
41 | struct mcp4725_data *data = iio_priv(indio_dev); | ||
40 | u8 outbuf[2]; | 42 | u8 outbuf[2]; |
41 | 43 | ||
42 | outbuf[0] = 0x3 << 4; /* power-down bits, 500 kOhm resistor */ | 44 | outbuf[0] = (data->powerdown_mode + 1) << 4; |
43 | outbuf[1] = 0; | 45 | outbuf[1] = 0; |
46 | data->powerdown = true; | ||
44 | 47 | ||
45 | return i2c_master_send(to_i2c_client(dev), outbuf, 2); | 48 | return i2c_master_send(to_i2c_client(dev), outbuf, 2); |
46 | } | 49 | } |
@@ -54,16 +57,150 @@ static int mcp4725_resume(struct device *dev) | |||
54 | /* restore previous DAC value */ | 57 | /* restore previous DAC value */ |
55 | outbuf[0] = (data->dac_value >> 8) & 0xf; | 58 | outbuf[0] = (data->dac_value >> 8) & 0xf; |
56 | outbuf[1] = data->dac_value & 0xff; | 59 | outbuf[1] = data->dac_value & 0xff; |
60 | data->powerdown = false; | ||
57 | 61 | ||
58 | return i2c_master_send(to_i2c_client(dev), outbuf, 2); | 62 | return i2c_master_send(to_i2c_client(dev), outbuf, 2); |
59 | } | 63 | } |
60 | 64 | ||
65 | #ifdef CONFIG_PM_SLEEP | ||
61 | static SIMPLE_DEV_PM_OPS(mcp4725_pm_ops, mcp4725_suspend, mcp4725_resume); | 66 | static SIMPLE_DEV_PM_OPS(mcp4725_pm_ops, mcp4725_suspend, mcp4725_resume); |
62 | #define MCP4725_PM_OPS (&mcp4725_pm_ops) | 67 | #define MCP4725_PM_OPS (&mcp4725_pm_ops) |
63 | #else | 68 | #else |
64 | #define MCP4725_PM_OPS NULL | 69 | #define MCP4725_PM_OPS NULL |
65 | #endif | 70 | #endif |
66 | 71 | ||
72 | static ssize_t mcp4725_store_eeprom(struct device *dev, | ||
73 | struct device_attribute *attr, const char *buf, size_t len) | ||
74 | { | ||
75 | struct iio_dev *indio_dev = dev_to_iio_dev(dev); | ||
76 | struct mcp4725_data *data = iio_priv(indio_dev); | ||
77 | int tries = 20; | ||
78 | u8 inoutbuf[3]; | ||
79 | bool state; | ||
80 | int ret; | ||
81 | |||
82 | ret = strtobool(buf, &state); | ||
83 | if (ret < 0) | ||
84 | return ret; | ||
85 | |||
86 | if (!state) | ||
87 | return 0; | ||
88 | |||
89 | inoutbuf[0] = 0x60; /* write EEPROM */ | ||
90 | inoutbuf[1] = data->dac_value >> 4; | ||
91 | inoutbuf[2] = (data->dac_value & 0xf) << 4; | ||
92 | |||
93 | ret = i2c_master_send(data->client, inoutbuf, 3); | ||
94 | if (ret < 0) | ||
95 | return ret; | ||
96 | else if (ret != 3) | ||
97 | return -EIO; | ||
98 | |||
99 | /* wait for write complete, takes up to 50ms */ | ||
100 | while (tries--) { | ||
101 | msleep(20); | ||
102 | ret = i2c_master_recv(data->client, inoutbuf, 3); | ||
103 | if (ret < 0) | ||
104 | return ret; | ||
105 | else if (ret != 3) | ||
106 | return -EIO; | ||
107 | |||
108 | if (inoutbuf[0] & 0x80) | ||
109 | break; | ||
110 | } | ||
111 | |||
112 | if (tries < 0) { | ||
113 | dev_err(&data->client->dev, | ||
114 | "mcp4725_store_eeprom() failed, incomplete\n"); | ||
115 | return -EIO; | ||
116 | } | ||
117 | |||
118 | return len; | ||
119 | } | ||
120 | |||
121 | static IIO_DEVICE_ATTR(store_eeprom, S_IWUSR, NULL, mcp4725_store_eeprom, 0); | ||
122 | |||
123 | static struct attribute *mcp4725_attributes[] = { | ||
124 | &iio_dev_attr_store_eeprom.dev_attr.attr, | ||
125 | NULL, | ||
126 | }; | ||
127 | |||
128 | static const struct attribute_group mcp4725_attribute_group = { | ||
129 | .attrs = mcp4725_attributes, | ||
130 | }; | ||
131 | |||
132 | static const char * const mcp4725_powerdown_modes[] = { | ||
133 | "1kohm_to_gnd", | ||
134 | "100kohm_to_gnd", | ||
135 | "500kohm_to_gnd" | ||
136 | }; | ||
137 | |||
138 | static int mcp4725_get_powerdown_mode(struct iio_dev *indio_dev, | ||
139 | const struct iio_chan_spec *chan) | ||
140 | { | ||
141 | struct mcp4725_data *data = iio_priv(indio_dev); | ||
142 | |||
143 | return data->powerdown_mode; | ||
144 | } | ||
145 | |||
146 | static int mcp4725_set_powerdown_mode(struct iio_dev *indio_dev, | ||
147 | const struct iio_chan_spec *chan, unsigned mode) | ||
148 | { | ||
149 | struct mcp4725_data *data = iio_priv(indio_dev); | ||
150 | |||
151 | data->powerdown_mode = mode; | ||
152 | |||
153 | return 0; | ||
154 | } | ||
155 | |||
156 | static ssize_t mcp4725_read_powerdown(struct iio_dev *indio_dev, | ||
157 | uintptr_t private, const struct iio_chan_spec *chan, char *buf) | ||
158 | { | ||
159 | struct mcp4725_data *data = iio_priv(indio_dev); | ||
160 | |||
161 | return sprintf(buf, "%d\n", data->powerdown); | ||
162 | } | ||
163 | |||
164 | static ssize_t mcp4725_write_powerdown(struct iio_dev *indio_dev, | ||
165 | uintptr_t private, const struct iio_chan_spec *chan, | ||
166 | const char *buf, size_t len) | ||
167 | { | ||
168 | struct mcp4725_data *data = iio_priv(indio_dev); | ||
169 | bool state; | ||
170 | int ret; | ||
171 | |||
172 | ret = strtobool(buf, &state); | ||
173 | if (ret) | ||
174 | return ret; | ||
175 | |||
176 | if (state) | ||
177 | ret = mcp4725_suspend(&data->client->dev); | ||
178 | else | ||
179 | ret = mcp4725_resume(&data->client->dev); | ||
180 | if (ret < 0) | ||
181 | return ret; | ||
182 | |||
183 | return len; | ||
184 | } | ||
185 | |||
186 | static const struct iio_enum mcp4725_powerdown_mode_enum = { | ||
187 | .items = mcp4725_powerdown_modes, | ||
188 | .num_items = ARRAY_SIZE(mcp4725_powerdown_modes), | ||
189 | .get = mcp4725_get_powerdown_mode, | ||
190 | .set = mcp4725_set_powerdown_mode, | ||
191 | }; | ||
192 | |||
193 | static const struct iio_chan_spec_ext_info mcp4725_ext_info[] = { | ||
194 | { | ||
195 | .name = "powerdown", | ||
196 | .read = mcp4725_read_powerdown, | ||
197 | .write = mcp4725_write_powerdown, | ||
198 | }, | ||
199 | IIO_ENUM("powerdown_mode", false, &mcp4725_powerdown_mode_enum), | ||
200 | IIO_ENUM_AVAILABLE("powerdown_mode", &mcp4725_powerdown_mode_enum), | ||
201 | { }, | ||
202 | }; | ||
203 | |||
67 | static const struct iio_chan_spec mcp4725_channel = { | 204 | static const struct iio_chan_spec mcp4725_channel = { |
68 | .type = IIO_VOLTAGE, | 205 | .type = IIO_VOLTAGE, |
69 | .indexed = 1, | 206 | .indexed = 1, |
@@ -72,6 +209,7 @@ static const struct iio_chan_spec mcp4725_channel = { | |||
72 | .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), | 209 | .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), |
73 | .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE), | 210 | .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE), |
74 | .scan_type = IIO_ST('u', 12, 16, 0), | 211 | .scan_type = IIO_ST('u', 12, 16, 0), |
212 | .ext_info = mcp4725_ext_info, | ||
75 | }; | 213 | }; |
76 | 214 | ||
77 | static int mcp4725_set_value(struct iio_dev *indio_dev, int val) | 215 | static int mcp4725_set_value(struct iio_dev *indio_dev, int val) |
@@ -138,6 +276,7 @@ static int mcp4725_write_raw(struct iio_dev *indio_dev, | |||
138 | static const struct iio_info mcp4725_info = { | 276 | static const struct iio_info mcp4725_info = { |
139 | .read_raw = mcp4725_read_raw, | 277 | .read_raw = mcp4725_read_raw, |
140 | .write_raw = mcp4725_write_raw, | 278 | .write_raw = mcp4725_write_raw, |
279 | .attrs = &mcp4725_attribute_group, | ||
141 | .driver_module = THIS_MODULE, | 280 | .driver_module = THIS_MODULE, |
142 | }; | 281 | }; |
143 | 282 | ||
@@ -148,19 +287,17 @@ static int mcp4725_probe(struct i2c_client *client, | |||
148 | struct iio_dev *indio_dev; | 287 | struct iio_dev *indio_dev; |
149 | struct mcp4725_platform_data *platform_data = client->dev.platform_data; | 288 | struct mcp4725_platform_data *platform_data = client->dev.platform_data; |
150 | u8 inbuf[3]; | 289 | u8 inbuf[3]; |
290 | u8 pd; | ||
151 | int err; | 291 | int err; |
152 | 292 | ||
153 | if (!platform_data || !platform_data->vref_mv) { | 293 | if (!platform_data || !platform_data->vref_mv) { |
154 | dev_err(&client->dev, "invalid platform data"); | 294 | dev_err(&client->dev, "invalid platform data"); |
155 | err = -EINVAL; | 295 | return -EINVAL; |
156 | goto exit; | ||
157 | } | 296 | } |
158 | 297 | ||
159 | indio_dev = iio_device_alloc(sizeof(*data)); | 298 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*data)); |
160 | if (indio_dev == NULL) { | 299 | if (indio_dev == NULL) |
161 | err = -ENOMEM; | 300 | return -ENOMEM; |
162 | goto exit; | ||
163 | } | ||
164 | data = iio_priv(indio_dev); | 301 | data = iio_priv(indio_dev); |
165 | i2c_set_clientdata(client, indio_dev); | 302 | i2c_set_clientdata(client, indio_dev); |
166 | data->client = client; | 303 | data->client = client; |
@@ -177,31 +314,25 @@ static int mcp4725_probe(struct i2c_client *client, | |||
177 | err = i2c_master_recv(client, inbuf, 3); | 314 | err = i2c_master_recv(client, inbuf, 3); |
178 | if (err < 0) { | 315 | if (err < 0) { |
179 | dev_err(&client->dev, "failed to read DAC value"); | 316 | dev_err(&client->dev, "failed to read DAC value"); |
180 | goto exit_free_device; | 317 | return err; |
181 | } | 318 | } |
319 | pd = (inbuf[0] >> 1) & 0x3; | ||
320 | data->powerdown = pd > 0 ? true : false; | ||
321 | data->powerdown_mode = pd ? pd-1 : 2; /* 500kohm_to_gnd */ | ||
182 | data->dac_value = (inbuf[1] << 4) | (inbuf[2] >> 4); | 322 | data->dac_value = (inbuf[1] << 4) | (inbuf[2] >> 4); |
183 | 323 | ||
184 | err = iio_device_register(indio_dev); | 324 | err = iio_device_register(indio_dev); |
185 | if (err) | 325 | if (err) |
186 | goto exit_free_device; | 326 | return err; |
187 | 327 | ||
188 | dev_info(&client->dev, "MCP4725 DAC registered\n"); | 328 | dev_info(&client->dev, "MCP4725 DAC registered\n"); |
189 | 329 | ||
190 | return 0; | 330 | return 0; |
191 | |||
192 | exit_free_device: | ||
193 | iio_device_free(indio_dev); | ||
194 | exit: | ||
195 | return err; | ||
196 | } | 331 | } |
197 | 332 | ||
198 | static int mcp4725_remove(struct i2c_client *client) | 333 | static int mcp4725_remove(struct i2c_client *client) |
199 | { | 334 | { |
200 | struct iio_dev *indio_dev = i2c_get_clientdata(client); | 335 | iio_device_unregister(i2c_get_clientdata(client)); |
201 | |||
202 | iio_device_unregister(indio_dev); | ||
203 | iio_device_free(indio_dev); | ||
204 | |||
205 | return 0; | 336 | return 0; |
206 | } | 337 | } |
207 | 338 | ||
diff --git a/drivers/iio/frequency/Kconfig b/drivers/iio/frequency/Kconfig index 6aaa33ef4544..dc5e0b72882f 100644 --- a/drivers/iio/frequency/Kconfig +++ b/drivers/iio/frequency/Kconfig | |||
@@ -4,6 +4,7 @@ | |||
4 | # Clock Distribution device drivers | 4 | # Clock Distribution device drivers |
5 | # Phase-Locked Loop (PLL) frequency synthesizers | 5 | # Phase-Locked Loop (PLL) frequency synthesizers |
6 | # | 6 | # |
7 | # When adding new entries keep the list in alphabetical order | ||
7 | 8 | ||
8 | menu "Frequency Synthesizers DDS/PLL" | 9 | menu "Frequency Synthesizers DDS/PLL" |
9 | 10 | ||
diff --git a/drivers/iio/frequency/Makefile b/drivers/iio/frequency/Makefile index 00d26e5d1dc2..2bca03f3e2e3 100644 --- a/drivers/iio/frequency/Makefile +++ b/drivers/iio/frequency/Makefile | |||
@@ -2,5 +2,6 @@ | |||
2 | # Makefile iio/frequency | 2 | # Makefile iio/frequency |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | obj-$(CONFIG_AD9523) += ad9523.o | 6 | obj-$(CONFIG_AD9523) += ad9523.o |
6 | obj-$(CONFIG_ADF4350) += adf4350.o | 7 | obj-$(CONFIG_ADF4350) += adf4350.o |
diff --git a/drivers/iio/frequency/ad9523.c b/drivers/iio/frequency/ad9523.c index 92276deeb026..7c5245d9f99c 100644 --- a/drivers/iio/frequency/ad9523.c +++ b/drivers/iio/frequency/ad9523.c | |||
@@ -961,17 +961,17 @@ static int ad9523_probe(struct spi_device *spi) | |||
961 | return -EINVAL; | 961 | return -EINVAL; |
962 | } | 962 | } |
963 | 963 | ||
964 | indio_dev = iio_device_alloc(sizeof(*st)); | 964 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
965 | if (indio_dev == NULL) | 965 | if (indio_dev == NULL) |
966 | return -ENOMEM; | 966 | return -ENOMEM; |
967 | 967 | ||
968 | st = iio_priv(indio_dev); | 968 | st = iio_priv(indio_dev); |
969 | 969 | ||
970 | st->reg = regulator_get(&spi->dev, "vcc"); | 970 | st->reg = devm_regulator_get(&spi->dev, "vcc"); |
971 | if (!IS_ERR(st->reg)) { | 971 | if (!IS_ERR(st->reg)) { |
972 | ret = regulator_enable(st->reg); | 972 | ret = regulator_enable(st->reg); |
973 | if (ret) | 973 | if (ret) |
974 | goto error_put_reg; | 974 | return ret; |
975 | } | 975 | } |
976 | 976 | ||
977 | spi_set_drvdata(spi, indio_dev); | 977 | spi_set_drvdata(spi, indio_dev); |
@@ -1001,11 +1001,6 @@ static int ad9523_probe(struct spi_device *spi) | |||
1001 | error_disable_reg: | 1001 | error_disable_reg: |
1002 | if (!IS_ERR(st->reg)) | 1002 | if (!IS_ERR(st->reg)) |
1003 | regulator_disable(st->reg); | 1003 | regulator_disable(st->reg); |
1004 | error_put_reg: | ||
1005 | if (!IS_ERR(st->reg)) | ||
1006 | regulator_put(st->reg); | ||
1007 | |||
1008 | iio_device_free(indio_dev); | ||
1009 | 1004 | ||
1010 | return ret; | 1005 | return ret; |
1011 | } | 1006 | } |
@@ -1017,12 +1012,8 @@ static int ad9523_remove(struct spi_device *spi) | |||
1017 | 1012 | ||
1018 | iio_device_unregister(indio_dev); | 1013 | iio_device_unregister(indio_dev); |
1019 | 1014 | ||
1020 | if (!IS_ERR(st->reg)) { | 1015 | if (!IS_ERR(st->reg)) |
1021 | regulator_disable(st->reg); | 1016 | regulator_disable(st->reg); |
1022 | regulator_put(st->reg); | ||
1023 | } | ||
1024 | |||
1025 | iio_device_free(indio_dev); | ||
1026 | 1017 | ||
1027 | return 0; | 1018 | return 0; |
1028 | } | 1019 | } |
diff --git a/drivers/iio/frequency/adf4350.c b/drivers/iio/frequency/adf4350.c index a4157cdb314d..a7b30be86ae0 100644 --- a/drivers/iio/frequency/adf4350.c +++ b/drivers/iio/frequency/adf4350.c | |||
@@ -515,7 +515,7 @@ static int adf4350_probe(struct spi_device *spi) | |||
515 | } | 515 | } |
516 | 516 | ||
517 | if (!pdata->clkin) { | 517 | if (!pdata->clkin) { |
518 | clk = clk_get(&spi->dev, "clkin"); | 518 | clk = devm_clk_get(&spi->dev, "clkin"); |
519 | if (IS_ERR(clk)) | 519 | if (IS_ERR(clk)) |
520 | return -EPROBE_DEFER; | 520 | return -EPROBE_DEFER; |
521 | 521 | ||
@@ -524,17 +524,17 @@ static int adf4350_probe(struct spi_device *spi) | |||
524 | return ret; | 524 | return ret; |
525 | } | 525 | } |
526 | 526 | ||
527 | indio_dev = iio_device_alloc(sizeof(*st)); | 527 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
528 | if (indio_dev == NULL) | 528 | if (indio_dev == NULL) |
529 | return -ENOMEM; | 529 | return -ENOMEM; |
530 | 530 | ||
531 | st = iio_priv(indio_dev); | 531 | st = iio_priv(indio_dev); |
532 | 532 | ||
533 | st->reg = regulator_get(&spi->dev, "vcc"); | 533 | st->reg = devm_regulator_get(&spi->dev, "vcc"); |
534 | if (!IS_ERR(st->reg)) { | 534 | if (!IS_ERR(st->reg)) { |
535 | ret = regulator_enable(st->reg); | 535 | ret = regulator_enable(st->reg); |
536 | if (ret) | 536 | if (ret) |
537 | goto error_put_reg; | 537 | goto error_disable_clk; |
538 | } | 538 | } |
539 | 539 | ||
540 | spi_set_drvdata(spi, indio_dev); | 540 | spi_set_drvdata(spi, indio_dev); |
@@ -564,7 +564,8 @@ static int adf4350_probe(struct spi_device *spi) | |||
564 | memset(st->regs_hw, 0xFF, sizeof(st->regs_hw)); | 564 | memset(st->regs_hw, 0xFF, sizeof(st->regs_hw)); |
565 | 565 | ||
566 | if (gpio_is_valid(pdata->gpio_lock_detect)) { | 566 | if (gpio_is_valid(pdata->gpio_lock_detect)) { |
567 | ret = gpio_request(pdata->gpio_lock_detect, indio_dev->name); | 567 | ret = devm_gpio_request(&spi->dev, pdata->gpio_lock_detect, |
568 | indio_dev->name); | ||
568 | if (ret) { | 569 | if (ret) { |
569 | dev_err(&spi->dev, "fail to request lock detect GPIO-%d", | 570 | dev_err(&spi->dev, "fail to request lock detect GPIO-%d", |
570 | pdata->gpio_lock_detect); | 571 | pdata->gpio_lock_detect); |
@@ -576,29 +577,21 @@ static int adf4350_probe(struct spi_device *spi) | |||
576 | if (pdata->power_up_frequency) { | 577 | if (pdata->power_up_frequency) { |
577 | ret = adf4350_set_freq(st, pdata->power_up_frequency); | 578 | ret = adf4350_set_freq(st, pdata->power_up_frequency); |
578 | if (ret) | 579 | if (ret) |
579 | goto error_free_gpio; | 580 | goto error_disable_reg; |
580 | } | 581 | } |
581 | 582 | ||
582 | ret = iio_device_register(indio_dev); | 583 | ret = iio_device_register(indio_dev); |
583 | if (ret) | 584 | if (ret) |
584 | goto error_free_gpio; | 585 | goto error_disable_reg; |
585 | 586 | ||
586 | return 0; | 587 | return 0; |
587 | 588 | ||
588 | error_free_gpio: | ||
589 | if (gpio_is_valid(pdata->gpio_lock_detect)) | ||
590 | gpio_free(pdata->gpio_lock_detect); | ||
591 | |||
592 | error_disable_reg: | 589 | error_disable_reg: |
593 | if (!IS_ERR(st->reg)) | 590 | if (!IS_ERR(st->reg)) |
594 | regulator_disable(st->reg); | 591 | regulator_disable(st->reg); |
595 | error_put_reg: | 592 | error_disable_clk: |
596 | if (!IS_ERR(st->reg)) | ||
597 | regulator_put(st->reg); | ||
598 | |||
599 | if (clk) | 593 | if (clk) |
600 | clk_disable_unprepare(clk); | 594 | clk_disable_unprepare(clk); |
601 | iio_device_free(indio_dev); | ||
602 | 595 | ||
603 | return ret; | 596 | return ret; |
604 | } | 597 | } |
@@ -619,14 +612,8 @@ static int adf4350_remove(struct spi_device *spi) | |||
619 | 612 | ||
620 | if (!IS_ERR(reg)) { | 613 | if (!IS_ERR(reg)) { |
621 | regulator_disable(reg); | 614 | regulator_disable(reg); |
622 | regulator_put(reg); | ||
623 | } | 615 | } |
624 | 616 | ||
625 | if (gpio_is_valid(st->pdata->gpio_lock_detect)) | ||
626 | gpio_free(st->pdata->gpio_lock_detect); | ||
627 | |||
628 | iio_device_free(indio_dev); | ||
629 | |||
630 | return 0; | 617 | return 0; |
631 | } | 618 | } |
632 | 619 | ||
diff --git a/drivers/iio/gyro/Kconfig b/drivers/iio/gyro/Kconfig index 8498e9dcda68..41c64a43bcab 100644 --- a/drivers/iio/gyro/Kconfig +++ b/drivers/iio/gyro/Kconfig | |||
@@ -1,6 +1,8 @@ | |||
1 | # | 1 | # |
2 | # IIO Digital Gyroscope Sensor drivers configuration | 2 | # IIO Digital Gyroscope Sensor drivers configuration |
3 | # | 3 | # |
4 | # When adding new entries keep the list in alphabetical order | ||
5 | |||
4 | menu "Digital gyroscope sensors" | 6 | menu "Digital gyroscope sensors" |
5 | 7 | ||
6 | config ADIS16080 | 8 | config ADIS16080 |
@@ -26,6 +28,18 @@ config ADIS16136 | |||
26 | Say yes here to build support for the Analog Devices ADIS16133, ADIS16135, | 28 | Say yes here to build support for the Analog Devices ADIS16133, ADIS16135, |
27 | ADIS16136 gyroscope devices. | 29 | ADIS16136 gyroscope devices. |
28 | 30 | ||
31 | config ADIS16260 | ||
32 | tristate "Analog Devices ADIS16260 Digital Gyroscope Sensor SPI driver" | ||
33 | depends on SPI | ||
34 | select IIO_ADIS_LIB | ||
35 | select IIO_ADIS_LIB_BUFFER if IIO_BUFFER | ||
36 | help | ||
37 | Say yes here to build support for Analog Devices ADIS16260 ADIS16265 | ||
38 | ADIS16250 ADIS16255 and ADIS16251 programmable digital gyroscope sensors. | ||
39 | |||
40 | This driver can also be built as a module. If so, the module | ||
41 | will be called adis16260. | ||
42 | |||
29 | config ADXRS450 | 43 | config ADXRS450 |
30 | tristate "Analog Devices ADXRS450/3 Digital Output Gyroscope SPI driver" | 44 | tristate "Analog Devices ADXRS450/3 Digital Output Gyroscope SPI driver" |
31 | depends on SPI | 45 | depends on SPI |
@@ -58,8 +72,8 @@ config IIO_ST_GYRO_3AXIS | |||
58 | Say yes here to build support for STMicroelectronics gyroscopes: | 72 | Say yes here to build support for STMicroelectronics gyroscopes: |
59 | L3G4200D, LSM330DL, L3GD20, L3GD20H, LSM330DLC, L3G4IS, LSM330. | 73 | L3G4200D, LSM330DL, L3GD20, L3GD20H, LSM330DLC, L3G4IS, LSM330. |
60 | 74 | ||
61 | This driver can also be built as a module. If so, will be created | 75 | This driver can also be built as a module. If so, these modules |
62 | these modules: | 76 | will be created: |
63 | - st_gyro (core functions for the driver [it is mandatory]); | 77 | - st_gyro (core functions for the driver [it is mandatory]); |
64 | - st_gyro_i2c (necessary for the I2C devices [optional*]); | 78 | - st_gyro_i2c (necessary for the I2C devices [optional*]); |
65 | - st_gyro_spi (necessary for the SPI devices [optional*]); | 79 | - st_gyro_spi (necessary for the SPI devices [optional*]); |
diff --git a/drivers/iio/gyro/Makefile b/drivers/iio/gyro/Makefile index e9dc034aa18b..2f2752a4ea83 100644 --- a/drivers/iio/gyro/Makefile +++ b/drivers/iio/gyro/Makefile | |||
@@ -2,9 +2,11 @@ | |||
2 | # Makefile for industrial I/O gyroscope sensor drivers | 2 | # Makefile for industrial I/O gyroscope sensor drivers |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | obj-$(CONFIG_ADIS16080) += adis16080.o | 6 | obj-$(CONFIG_ADIS16080) += adis16080.o |
6 | obj-$(CONFIG_ADIS16130) += adis16130.o | 7 | obj-$(CONFIG_ADIS16130) += adis16130.o |
7 | obj-$(CONFIG_ADIS16136) += adis16136.o | 8 | obj-$(CONFIG_ADIS16136) += adis16136.o |
9 | obj-$(CONFIG_ADIS16260) += adis16260.o | ||
8 | obj-$(CONFIG_ADXRS450) += adxrs450.o | 10 | obj-$(CONFIG_ADXRS450) += adxrs450.o |
9 | 11 | ||
10 | obj-$(CONFIG_HID_SENSOR_GYRO_3D) += hid-sensor-gyro-3d.o | 12 | obj-$(CONFIG_HID_SENSOR_GYRO_3D) += hid-sensor-gyro-3d.o |
diff --git a/drivers/iio/gyro/adis16080.c b/drivers/iio/gyro/adis16080.c index e1bb5f994a54..e9ec022ae225 100644 --- a/drivers/iio/gyro/adis16080.c +++ b/drivers/iio/gyro/adis16080.c | |||
@@ -192,16 +192,13 @@ static const struct adis16080_chip_info adis16080_chip_info[] = { | |||
192 | static int adis16080_probe(struct spi_device *spi) | 192 | static int adis16080_probe(struct spi_device *spi) |
193 | { | 193 | { |
194 | const struct spi_device_id *id = spi_get_device_id(spi); | 194 | const struct spi_device_id *id = spi_get_device_id(spi); |
195 | int ret; | ||
196 | struct adis16080_state *st; | 195 | struct adis16080_state *st; |
197 | struct iio_dev *indio_dev; | 196 | struct iio_dev *indio_dev; |
198 | 197 | ||
199 | /* setup the industrialio driver allocated elements */ | 198 | /* setup the industrialio driver allocated elements */ |
200 | indio_dev = iio_device_alloc(sizeof(*st)); | 199 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
201 | if (indio_dev == NULL) { | 200 | if (!indio_dev) |
202 | ret = -ENOMEM; | 201 | return -ENOMEM; |
203 | goto error_ret; | ||
204 | } | ||
205 | st = iio_priv(indio_dev); | 202 | st = iio_priv(indio_dev); |
206 | /* this is only used for removal purposes */ | 203 | /* this is only used for removal purposes */ |
207 | spi_set_drvdata(spi, indio_dev); | 204 | spi_set_drvdata(spi, indio_dev); |
@@ -217,22 +214,12 @@ static int adis16080_probe(struct spi_device *spi) | |||
217 | indio_dev->info = &adis16080_info; | 214 | indio_dev->info = &adis16080_info; |
218 | indio_dev->modes = INDIO_DIRECT_MODE; | 215 | indio_dev->modes = INDIO_DIRECT_MODE; |
219 | 216 | ||
220 | ret = iio_device_register(indio_dev); | 217 | return iio_device_register(indio_dev); |
221 | if (ret) | ||
222 | goto error_free_dev; | ||
223 | return 0; | ||
224 | |||
225 | error_free_dev: | ||
226 | iio_device_free(indio_dev); | ||
227 | error_ret: | ||
228 | return ret; | ||
229 | } | 218 | } |
230 | 219 | ||
231 | static int adis16080_remove(struct spi_device *spi) | 220 | static int adis16080_remove(struct spi_device *spi) |
232 | { | 221 | { |
233 | iio_device_unregister(spi_get_drvdata(spi)); | 222 | iio_device_unregister(spi_get_drvdata(spi)); |
234 | iio_device_free(spi_get_drvdata(spi)); | ||
235 | |||
236 | return 0; | 223 | return 0; |
237 | } | 224 | } |
238 | 225 | ||
diff --git a/drivers/iio/gyro/adis16130.c b/drivers/iio/gyro/adis16130.c index 129acdf801a4..ac66fc184042 100644 --- a/drivers/iio/gyro/adis16130.c +++ b/drivers/iio/gyro/adis16130.c | |||
@@ -148,16 +148,13 @@ static const struct iio_info adis16130_info = { | |||
148 | 148 | ||
149 | static int adis16130_probe(struct spi_device *spi) | 149 | static int adis16130_probe(struct spi_device *spi) |
150 | { | 150 | { |
151 | int ret; | ||
152 | struct adis16130_state *st; | 151 | struct adis16130_state *st; |
153 | struct iio_dev *indio_dev; | 152 | struct iio_dev *indio_dev; |
154 | 153 | ||
155 | /* setup the industrialio driver allocated elements */ | 154 | /* setup the industrialio driver allocated elements */ |
156 | indio_dev = iio_device_alloc(sizeof(*st)); | 155 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
157 | if (indio_dev == NULL) { | 156 | if (!indio_dev) |
158 | ret = -ENOMEM; | 157 | return -ENOMEM; |
159 | goto error_ret; | ||
160 | } | ||
161 | st = iio_priv(indio_dev); | 158 | st = iio_priv(indio_dev); |
162 | /* this is only used for removal purposes */ | 159 | /* this is only used for removal purposes */ |
163 | spi_set_drvdata(spi, indio_dev); | 160 | spi_set_drvdata(spi, indio_dev); |
@@ -170,24 +167,12 @@ static int adis16130_probe(struct spi_device *spi) | |||
170 | indio_dev->info = &adis16130_info; | 167 | indio_dev->info = &adis16130_info; |
171 | indio_dev->modes = INDIO_DIRECT_MODE; | 168 | indio_dev->modes = INDIO_DIRECT_MODE; |
172 | 169 | ||
173 | ret = iio_device_register(indio_dev); | 170 | return iio_device_register(indio_dev); |
174 | if (ret) | ||
175 | goto error_free_dev; | ||
176 | |||
177 | return 0; | ||
178 | |||
179 | error_free_dev: | ||
180 | iio_device_free(indio_dev); | ||
181 | |||
182 | error_ret: | ||
183 | return ret; | ||
184 | } | 171 | } |
185 | 172 | ||
186 | static int adis16130_remove(struct spi_device *spi) | 173 | static int adis16130_remove(struct spi_device *spi) |
187 | { | 174 | { |
188 | iio_device_unregister(spi_get_drvdata(spi)); | 175 | iio_device_unregister(spi_get_drvdata(spi)); |
189 | iio_device_free(spi_get_drvdata(spi)); | ||
190 | |||
191 | return 0; | 176 | return 0; |
192 | } | 177 | } |
193 | 178 | ||
diff --git a/drivers/iio/gyro/adis16136.c b/drivers/iio/gyro/adis16136.c index 058e6d5c955f..591bd555e1f3 100644 --- a/drivers/iio/gyro/adis16136.c +++ b/drivers/iio/gyro/adis16136.c | |||
@@ -497,7 +497,7 @@ static int adis16136_probe(struct spi_device *spi) | |||
497 | struct iio_dev *indio_dev; | 497 | struct iio_dev *indio_dev; |
498 | int ret; | 498 | int ret; |
499 | 499 | ||
500 | indio_dev = iio_device_alloc(sizeof(*adis16136)); | 500 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*adis16136)); |
501 | if (indio_dev == NULL) | 501 | if (indio_dev == NULL) |
502 | return -ENOMEM; | 502 | return -ENOMEM; |
503 | 503 | ||
@@ -515,11 +515,11 @@ static int adis16136_probe(struct spi_device *spi) | |||
515 | 515 | ||
516 | ret = adis_init(&adis16136->adis, indio_dev, spi, &adis16136_data); | 516 | ret = adis_init(&adis16136->adis, indio_dev, spi, &adis16136_data); |
517 | if (ret) | 517 | if (ret) |
518 | goto error_free_dev; | 518 | return ret; |
519 | 519 | ||
520 | ret = adis_setup_buffer_and_trigger(&adis16136->adis, indio_dev, NULL); | 520 | ret = adis_setup_buffer_and_trigger(&adis16136->adis, indio_dev, NULL); |
521 | if (ret) | 521 | if (ret) |
522 | goto error_free_dev; | 522 | return ret; |
523 | 523 | ||
524 | ret = adis16136_initial_setup(indio_dev); | 524 | ret = adis16136_initial_setup(indio_dev); |
525 | if (ret) | 525 | if (ret) |
@@ -537,8 +537,6 @@ error_stop_device: | |||
537 | adis16136_stop_device(indio_dev); | 537 | adis16136_stop_device(indio_dev); |
538 | error_cleanup_buffer: | 538 | error_cleanup_buffer: |
539 | adis_cleanup_buffer_and_trigger(&adis16136->adis, indio_dev); | 539 | adis_cleanup_buffer_and_trigger(&adis16136->adis, indio_dev); |
540 | error_free_dev: | ||
541 | iio_device_free(indio_dev); | ||
542 | return ret; | 540 | return ret; |
543 | } | 541 | } |
544 | 542 | ||
@@ -552,8 +550,6 @@ static int adis16136_remove(struct spi_device *spi) | |||
552 | 550 | ||
553 | adis_cleanup_buffer_and_trigger(&adis16136->adis, indio_dev); | 551 | adis_cleanup_buffer_and_trigger(&adis16136->adis, indio_dev); |
554 | 552 | ||
555 | iio_device_free(indio_dev); | ||
556 | |||
557 | return 0; | 553 | return 0; |
558 | } | 554 | } |
559 | 555 | ||
diff --git a/drivers/iio/gyro/adis16260.c b/drivers/iio/gyro/adis16260.c new file mode 100644 index 000000000000..06541162fc02 --- /dev/null +++ b/drivers/iio/gyro/adis16260.c | |||
@@ -0,0 +1,422 @@ | |||
1 | /* | ||
2 | * ADIS16260/ADIS16265 Programmable Digital Gyroscope Sensor Driver | ||
3 | * | ||
4 | * Copyright 2010 Analog Devices Inc. | ||
5 | * | ||
6 | * Licensed under the GPL-2 or later. | ||
7 | */ | ||
8 | |||
9 | #include <linux/interrupt.h> | ||
10 | #include <linux/mutex.h> | ||
11 | #include <linux/device.h> | ||
12 | #include <linux/kernel.h> | ||
13 | #include <linux/spi/spi.h> | ||
14 | #include <linux/sysfs.h> | ||
15 | #include <linux/module.h> | ||
16 | |||
17 | #include <linux/iio/iio.h> | ||
18 | #include <linux/iio/sysfs.h> | ||
19 | #include <linux/iio/buffer.h> | ||
20 | #include <linux/iio/imu/adis.h> | ||
21 | |||
22 | #define ADIS16260_STARTUP_DELAY 220 /* ms */ | ||
23 | |||
24 | #define ADIS16260_FLASH_CNT 0x00 /* Flash memory write count */ | ||
25 | #define ADIS16260_SUPPLY_OUT 0x02 /* Power supply measurement */ | ||
26 | #define ADIS16260_GYRO_OUT 0x04 /* X-axis gyroscope output */ | ||
27 | #define ADIS16260_AUX_ADC 0x0A /* analog input channel measurement */ | ||
28 | #define ADIS16260_TEMP_OUT 0x0C /* internal temperature measurement */ | ||
29 | #define ADIS16260_ANGL_OUT 0x0E /* angle displacement */ | ||
30 | #define ADIS16260_GYRO_OFF 0x14 /* Calibration, offset/bias adjustment */ | ||
31 | #define ADIS16260_GYRO_SCALE 0x16 /* Calibration, scale adjustment */ | ||
32 | #define ADIS16260_ALM_MAG1 0x20 /* Alarm 1 magnitude/polarity setting */ | ||
33 | #define ADIS16260_ALM_MAG2 0x22 /* Alarm 2 magnitude/polarity setting */ | ||
34 | #define ADIS16260_ALM_SMPL1 0x24 /* Alarm 1 dynamic rate of change setting */ | ||
35 | #define ADIS16260_ALM_SMPL2 0x26 /* Alarm 2 dynamic rate of change setting */ | ||
36 | #define ADIS16260_ALM_CTRL 0x28 /* Alarm control */ | ||
37 | #define ADIS16260_AUX_DAC 0x30 /* Auxiliary DAC data */ | ||
38 | #define ADIS16260_GPIO_CTRL 0x32 /* Control, digital I/O line */ | ||
39 | #define ADIS16260_MSC_CTRL 0x34 /* Control, data ready, self-test settings */ | ||
40 | #define ADIS16260_SMPL_PRD 0x36 /* Control, internal sample rate */ | ||
41 | #define ADIS16260_SENS_AVG 0x38 /* Control, dynamic range, filtering */ | ||
42 | #define ADIS16260_SLP_CNT 0x3A /* Control, sleep mode initiation */ | ||
43 | #define ADIS16260_DIAG_STAT 0x3C /* Diagnostic, error flags */ | ||
44 | #define ADIS16260_GLOB_CMD 0x3E /* Control, global commands */ | ||
45 | #define ADIS16260_LOT_ID1 0x52 /* Lot Identification Code 1 */ | ||
46 | #define ADIS16260_LOT_ID2 0x54 /* Lot Identification Code 2 */ | ||
47 | #define ADIS16260_PROD_ID 0x56 /* Product identifier; | ||
48 | * convert to decimal = 16,265/16,260 */ | ||
49 | #define ADIS16260_SERIAL_NUM 0x58 /* Serial number */ | ||
50 | |||
51 | #define ADIS16260_ERROR_ACTIVE (1<<14) | ||
52 | #define ADIS16260_NEW_DATA (1<<15) | ||
53 | |||
54 | /* MSC_CTRL */ | ||
55 | #define ADIS16260_MSC_CTRL_MEM_TEST (1<<11) | ||
56 | /* Internal self-test enable */ | ||
57 | #define ADIS16260_MSC_CTRL_INT_SELF_TEST (1<<10) | ||
58 | #define ADIS16260_MSC_CTRL_NEG_SELF_TEST (1<<9) | ||
59 | #define ADIS16260_MSC_CTRL_POS_SELF_TEST (1<<8) | ||
60 | #define ADIS16260_MSC_CTRL_DATA_RDY_EN (1<<2) | ||
61 | #define ADIS16260_MSC_CTRL_DATA_RDY_POL_HIGH (1<<1) | ||
62 | #define ADIS16260_MSC_CTRL_DATA_RDY_DIO2 (1<<0) | ||
63 | |||
64 | /* SMPL_PRD */ | ||
65 | /* Time base (tB): 0 = 1.953 ms, 1 = 60.54 ms */ | ||
66 | #define ADIS16260_SMPL_PRD_TIME_BASE (1<<7) | ||
67 | #define ADIS16260_SMPL_PRD_DIV_MASK 0x7F | ||
68 | |||
69 | /* SLP_CNT */ | ||
70 | #define ADIS16260_SLP_CNT_POWER_OFF 0x80 | ||
71 | |||
72 | /* DIAG_STAT */ | ||
73 | #define ADIS16260_DIAG_STAT_ALARM2 (1<<9) | ||
74 | #define ADIS16260_DIAG_STAT_ALARM1 (1<<8) | ||
75 | #define ADIS16260_DIAG_STAT_FLASH_CHK_BIT 6 | ||
76 | #define ADIS16260_DIAG_STAT_SELF_TEST_BIT 5 | ||
77 | #define ADIS16260_DIAG_STAT_OVERFLOW_BIT 4 | ||
78 | #define ADIS16260_DIAG_STAT_SPI_FAIL_BIT 3 | ||
79 | #define ADIS16260_DIAG_STAT_FLASH_UPT_BIT 2 | ||
80 | #define ADIS16260_DIAG_STAT_POWER_HIGH_BIT 1 | ||
81 | #define ADIS16260_DIAG_STAT_POWER_LOW_BIT 0 | ||
82 | |||
83 | /* GLOB_CMD */ | ||
84 | #define ADIS16260_GLOB_CMD_SW_RESET (1<<7) | ||
85 | #define ADIS16260_GLOB_CMD_FLASH_UPD (1<<3) | ||
86 | #define ADIS16260_GLOB_CMD_DAC_LATCH (1<<2) | ||
87 | #define ADIS16260_GLOB_CMD_FAC_CALIB (1<<1) | ||
88 | #define ADIS16260_GLOB_CMD_AUTO_NULL (1<<0) | ||
89 | |||
90 | #define ADIS16260_SPI_SLOW (u32)(300 * 1000) | ||
91 | #define ADIS16260_SPI_BURST (u32)(1000 * 1000) | ||
92 | #define ADIS16260_SPI_FAST (u32)(2000 * 1000) | ||
93 | |||
94 | /* At the moment triggers are only used for ring buffer | ||
95 | * filling. This may change! | ||
96 | */ | ||
97 | |||
98 | #define ADIS16260_SCAN_GYRO 0 | ||
99 | #define ADIS16260_SCAN_SUPPLY 1 | ||
100 | #define ADIS16260_SCAN_AUX_ADC 2 | ||
101 | #define ADIS16260_SCAN_TEMP 3 | ||
102 | #define ADIS16260_SCAN_ANGL 4 | ||
103 | |||
104 | static ssize_t adis16260_read_frequency(struct device *dev, | ||
105 | struct device_attribute *attr, | ||
106 | char *buf) | ||
107 | { | ||
108 | struct iio_dev *indio_dev = dev_to_iio_dev(dev); | ||
109 | struct adis *adis = iio_priv(indio_dev); | ||
110 | int ret, len = 0; | ||
111 | u16 t; | ||
112 | int sps; | ||
113 | ret = adis_read_reg_16(adis, ADIS16260_SMPL_PRD, &t); | ||
114 | if (ret) | ||
115 | return ret; | ||
116 | |||
117 | if (spi_get_device_id(adis->spi)->driver_data) /* If an adis16251 */ | ||
118 | sps = (t & ADIS16260_SMPL_PRD_TIME_BASE) ? 8 : 256; | ||
119 | else | ||
120 | sps = (t & ADIS16260_SMPL_PRD_TIME_BASE) ? 66 : 2048; | ||
121 | sps /= (t & ADIS16260_SMPL_PRD_DIV_MASK) + 1; | ||
122 | len = sprintf(buf, "%d\n", sps); | ||
123 | return len; | ||
124 | } | ||
125 | |||
126 | static ssize_t adis16260_write_frequency(struct device *dev, | ||
127 | struct device_attribute *attr, | ||
128 | const char *buf, | ||
129 | size_t len) | ||
130 | { | ||
131 | struct iio_dev *indio_dev = dev_to_iio_dev(dev); | ||
132 | struct adis *adis = iio_priv(indio_dev); | ||
133 | unsigned int val; | ||
134 | int ret; | ||
135 | u8 t; | ||
136 | |||
137 | ret = kstrtouint(buf, 10, &val); | ||
138 | if (ret) | ||
139 | return ret; | ||
140 | |||
141 | mutex_lock(&indio_dev->mlock); | ||
142 | if (spi_get_device_id(adis->spi)->driver_data) | ||
143 | t = 256 / val; | ||
144 | else | ||
145 | t = 2048 / val; | ||
146 | |||
147 | if (t > ADIS16260_SMPL_PRD_DIV_MASK) | ||
148 | t = ADIS16260_SMPL_PRD_DIV_MASK; | ||
149 | else if (t > 0) | ||
150 | t--; | ||
151 | |||
152 | if (t >= 0x0A) | ||
153 | adis->spi->max_speed_hz = ADIS16260_SPI_SLOW; | ||
154 | else | ||
155 | adis->spi->max_speed_hz = ADIS16260_SPI_FAST; | ||
156 | ret = adis_write_reg_8(adis, ADIS16260_SMPL_PRD, t); | ||
157 | |||
158 | mutex_unlock(&indio_dev->mlock); | ||
159 | |||
160 | return ret ? ret : len; | ||
161 | } | ||
162 | |||
163 | /* Power down the device */ | ||
164 | static int adis16260_stop_device(struct iio_dev *indio_dev) | ||
165 | { | ||
166 | struct adis *adis = iio_priv(indio_dev); | ||
167 | int ret; | ||
168 | u16 val = ADIS16260_SLP_CNT_POWER_OFF; | ||
169 | |||
170 | ret = adis_write_reg_16(adis, ADIS16260_SLP_CNT, val); | ||
171 | if (ret) | ||
172 | dev_err(&indio_dev->dev, "problem with turning device off: SLP_CNT"); | ||
173 | |||
174 | return ret; | ||
175 | } | ||
176 | |||
177 | static IIO_DEV_ATTR_SAMP_FREQ(S_IWUSR | S_IRUGO, | ||
178 | adis16260_read_frequency, | ||
179 | adis16260_write_frequency); | ||
180 | |||
181 | static const struct iio_chan_spec adis16260_channels[] = { | ||
182 | ADIS_GYRO_CHAN(X, ADIS16260_GYRO_OUT, ADIS16260_SCAN_GYRO, | ||
183 | BIT(IIO_CHAN_INFO_CALIBBIAS) | | ||
184 | BIT(IIO_CHAN_INFO_CALIBSCALE), 14), | ||
185 | ADIS_INCLI_CHAN(X, ADIS16260_ANGL_OUT, ADIS16260_SCAN_ANGL, 0, 14), | ||
186 | ADIS_TEMP_CHAN(ADIS16260_TEMP_OUT, ADIS16260_SCAN_TEMP, 12), | ||
187 | ADIS_SUPPLY_CHAN(ADIS16260_SUPPLY_OUT, ADIS16260_SCAN_SUPPLY, 12), | ||
188 | ADIS_AUX_ADC_CHAN(ADIS16260_AUX_ADC, ADIS16260_SCAN_AUX_ADC, 12), | ||
189 | IIO_CHAN_SOFT_TIMESTAMP(5), | ||
190 | }; | ||
191 | |||
192 | static const u8 adis16260_addresses[][2] = { | ||
193 | [ADIS16260_SCAN_GYRO] = { ADIS16260_GYRO_OFF, ADIS16260_GYRO_SCALE }, | ||
194 | }; | ||
195 | |||
196 | static int adis16260_read_raw(struct iio_dev *indio_dev, | ||
197 | struct iio_chan_spec const *chan, | ||
198 | int *val, int *val2, | ||
199 | long mask) | ||
200 | { | ||
201 | struct adis *adis = iio_priv(indio_dev); | ||
202 | int ret; | ||
203 | u8 addr; | ||
204 | s16 val16; | ||
205 | |||
206 | switch (mask) { | ||
207 | case IIO_CHAN_INFO_RAW: | ||
208 | return adis_single_conversion(indio_dev, chan, | ||
209 | ADIS16260_ERROR_ACTIVE, val); | ||
210 | case IIO_CHAN_INFO_SCALE: | ||
211 | switch (chan->type) { | ||
212 | case IIO_ANGL_VEL: | ||
213 | *val = 0; | ||
214 | if (spi_get_device_id(adis->spi)->driver_data) { | ||
215 | /* 0.01832 degree / sec */ | ||
216 | *val2 = IIO_DEGREE_TO_RAD(18320); | ||
217 | } else { | ||
218 | /* 0.07326 degree / sec */ | ||
219 | *val2 = IIO_DEGREE_TO_RAD(73260); | ||
220 | } | ||
221 | return IIO_VAL_INT_PLUS_MICRO; | ||
222 | case IIO_INCLI: | ||
223 | *val = 0; | ||
224 | *val2 = IIO_DEGREE_TO_RAD(36630); | ||
225 | return IIO_VAL_INT_PLUS_MICRO; | ||
226 | case IIO_VOLTAGE: | ||
227 | if (chan->channel == 0) { | ||
228 | *val = 1; | ||
229 | *val2 = 831500; /* 1.8315 mV */ | ||
230 | } else { | ||
231 | *val = 0; | ||
232 | *val2 = 610500; /* 610.5 uV */ | ||
233 | } | ||
234 | return IIO_VAL_INT_PLUS_MICRO; | ||
235 | case IIO_TEMP: | ||
236 | *val = 145; | ||
237 | *val2 = 300000; /* 0.1453 C */ | ||
238 | return IIO_VAL_INT_PLUS_MICRO; | ||
239 | default: | ||
240 | return -EINVAL; | ||
241 | } | ||
242 | break; | ||
243 | case IIO_CHAN_INFO_OFFSET: | ||
244 | *val = 250000 / 1453; /* 25 C = 0x00 */ | ||
245 | return IIO_VAL_INT; | ||
246 | case IIO_CHAN_INFO_CALIBBIAS: | ||
247 | addr = adis16260_addresses[chan->scan_index][0]; | ||
248 | ret = adis_read_reg_16(adis, addr, &val16); | ||
249 | if (ret) | ||
250 | return ret; | ||
251 | |||
252 | *val = sign_extend32(val16, 11); | ||
253 | return IIO_VAL_INT; | ||
254 | case IIO_CHAN_INFO_CALIBSCALE: | ||
255 | addr = adis16260_addresses[chan->scan_index][1]; | ||
256 | ret = adis_read_reg_16(adis, addr, &val16); | ||
257 | if (ret) | ||
258 | return ret; | ||
259 | |||
260 | *val = val16; | ||
261 | return IIO_VAL_INT; | ||
262 | } | ||
263 | return -EINVAL; | ||
264 | } | ||
265 | |||
266 | static int adis16260_write_raw(struct iio_dev *indio_dev, | ||
267 | struct iio_chan_spec const *chan, | ||
268 | int val, | ||
269 | int val2, | ||
270 | long mask) | ||
271 | { | ||
272 | struct adis *adis = iio_priv(indio_dev); | ||
273 | u8 addr; | ||
274 | |||
275 | switch (mask) { | ||
276 | case IIO_CHAN_INFO_CALIBBIAS: | ||
277 | if (val < -2048 || val >= 2048) | ||
278 | return -EINVAL; | ||
279 | |||
280 | addr = adis16260_addresses[chan->scan_index][0]; | ||
281 | return adis_write_reg_16(adis, addr, val); | ||
282 | case IIO_CHAN_INFO_CALIBSCALE: | ||
283 | if (val < 0 || val >= 4096) | ||
284 | return -EINVAL; | ||
285 | |||
286 | addr = adis16260_addresses[chan->scan_index][1]; | ||
287 | return adis_write_reg_16(adis, addr, val); | ||
288 | } | ||
289 | return -EINVAL; | ||
290 | } | ||
291 | |||
292 | static struct attribute *adis16260_attributes[] = { | ||
293 | &iio_dev_attr_sampling_frequency.dev_attr.attr, | ||
294 | NULL | ||
295 | }; | ||
296 | |||
297 | static const struct attribute_group adis16260_attribute_group = { | ||
298 | .attrs = adis16260_attributes, | ||
299 | }; | ||
300 | |||
301 | static const struct iio_info adis16260_info = { | ||
302 | .attrs = &adis16260_attribute_group, | ||
303 | .read_raw = &adis16260_read_raw, | ||
304 | .write_raw = &adis16260_write_raw, | ||
305 | .update_scan_mode = adis_update_scan_mode, | ||
306 | .driver_module = THIS_MODULE, | ||
307 | }; | ||
308 | |||
309 | static const char * const adis1620_status_error_msgs[] = { | ||
310 | [ADIS16260_DIAG_STAT_FLASH_CHK_BIT] = "Flash checksum error", | ||
311 | [ADIS16260_DIAG_STAT_SELF_TEST_BIT] = "Self test error", | ||
312 | [ADIS16260_DIAG_STAT_OVERFLOW_BIT] = "Sensor overrange", | ||
313 | [ADIS16260_DIAG_STAT_SPI_FAIL_BIT] = "SPI failure", | ||
314 | [ADIS16260_DIAG_STAT_FLASH_UPT_BIT] = "Flash update failed", | ||
315 | [ADIS16260_DIAG_STAT_POWER_HIGH_BIT] = "Power supply above 5.25", | ||
316 | [ADIS16260_DIAG_STAT_POWER_LOW_BIT] = "Power supply below 4.75", | ||
317 | }; | ||
318 | |||
319 | static const struct adis_data adis16260_data = { | ||
320 | .write_delay = 30, | ||
321 | .read_delay = 30, | ||
322 | .msc_ctrl_reg = ADIS16260_MSC_CTRL, | ||
323 | .glob_cmd_reg = ADIS16260_GLOB_CMD, | ||
324 | .diag_stat_reg = ADIS16260_DIAG_STAT, | ||
325 | |||
326 | .self_test_mask = ADIS16260_MSC_CTRL_MEM_TEST, | ||
327 | .startup_delay = ADIS16260_STARTUP_DELAY, | ||
328 | |||
329 | .status_error_msgs = adis1620_status_error_msgs, | ||
330 | .status_error_mask = BIT(ADIS16260_DIAG_STAT_FLASH_CHK_BIT) | | ||
331 | BIT(ADIS16260_DIAG_STAT_SELF_TEST_BIT) | | ||
332 | BIT(ADIS16260_DIAG_STAT_OVERFLOW_BIT) | | ||
333 | BIT(ADIS16260_DIAG_STAT_SPI_FAIL_BIT) | | ||
334 | BIT(ADIS16260_DIAG_STAT_FLASH_UPT_BIT) | | ||
335 | BIT(ADIS16260_DIAG_STAT_POWER_HIGH_BIT) | | ||
336 | BIT(ADIS16260_DIAG_STAT_POWER_LOW_BIT), | ||
337 | }; | ||
338 | |||
339 | static int adis16260_probe(struct spi_device *spi) | ||
340 | { | ||
341 | struct iio_dev *indio_dev; | ||
342 | struct adis *adis; | ||
343 | int ret; | ||
344 | |||
345 | /* setup the industrialio driver allocated elements */ | ||
346 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*adis)); | ||
347 | if (!indio_dev) | ||
348 | return -ENOMEM; | ||
349 | adis = iio_priv(indio_dev); | ||
350 | /* this is only used for removal purposes */ | ||
351 | spi_set_drvdata(spi, indio_dev); | ||
352 | |||
353 | indio_dev->name = spi_get_device_id(spi)->name; | ||
354 | indio_dev->dev.parent = &spi->dev; | ||
355 | indio_dev->info = &adis16260_info; | ||
356 | indio_dev->channels = adis16260_channels; | ||
357 | indio_dev->num_channels = ARRAY_SIZE(adis16260_channels); | ||
358 | indio_dev->modes = INDIO_DIRECT_MODE; | ||
359 | |||
360 | ret = adis_init(adis, indio_dev, spi, &adis16260_data); | ||
361 | if (ret) | ||
362 | return ret; | ||
363 | |||
364 | ret = adis_setup_buffer_and_trigger(adis, indio_dev, NULL); | ||
365 | if (ret) | ||
366 | return ret; | ||
367 | |||
368 | /* Get the device into a sane initial state */ | ||
369 | ret = adis_initial_startup(adis); | ||
370 | if (ret) | ||
371 | goto error_cleanup_buffer_trigger; | ||
372 | ret = iio_device_register(indio_dev); | ||
373 | if (ret) | ||
374 | goto error_cleanup_buffer_trigger; | ||
375 | |||
376 | return 0; | ||
377 | |||
378 | error_cleanup_buffer_trigger: | ||
379 | adis_cleanup_buffer_and_trigger(adis, indio_dev); | ||
380 | return ret; | ||
381 | } | ||
382 | |||
383 | static int adis16260_remove(struct spi_device *spi) | ||
384 | { | ||
385 | struct iio_dev *indio_dev = spi_get_drvdata(spi); | ||
386 | struct adis *adis = iio_priv(indio_dev); | ||
387 | |||
388 | iio_device_unregister(indio_dev); | ||
389 | adis16260_stop_device(indio_dev); | ||
390 | adis_cleanup_buffer_and_trigger(adis, indio_dev); | ||
391 | |||
392 | return 0; | ||
393 | } | ||
394 | |||
395 | /* | ||
396 | * These parts do not need to be differentiated until someone adds | ||
397 | * support for the on chip filtering. | ||
398 | */ | ||
399 | static const struct spi_device_id adis16260_id[] = { | ||
400 | {"adis16260", 0}, | ||
401 | {"adis16265", 0}, | ||
402 | {"adis16250", 0}, | ||
403 | {"adis16255", 0}, | ||
404 | {"adis16251", 1}, | ||
405 | {} | ||
406 | }; | ||
407 | MODULE_DEVICE_TABLE(spi, adis16260_id); | ||
408 | |||
409 | static struct spi_driver adis16260_driver = { | ||
410 | .driver = { | ||
411 | .name = "adis16260", | ||
412 | .owner = THIS_MODULE, | ||
413 | }, | ||
414 | .probe = adis16260_probe, | ||
415 | .remove = adis16260_remove, | ||
416 | .id_table = adis16260_id, | ||
417 | }; | ||
418 | module_spi_driver(adis16260_driver); | ||
419 | |||
420 | MODULE_AUTHOR("Barry Song <21cnbao@gmail.com>"); | ||
421 | MODULE_DESCRIPTION("Analog Devices ADIS16260/5 Digital Gyroscope Sensor"); | ||
422 | MODULE_LICENSE("GPL v2"); | ||
diff --git a/drivers/iio/gyro/adxrs450.c b/drivers/iio/gyro/adxrs450.c index 8bd72b490b7f..6dab2995f0f2 100644 --- a/drivers/iio/gyro/adxrs450.c +++ b/drivers/iio/gyro/adxrs450.c | |||
@@ -426,11 +426,9 @@ static int adxrs450_probe(struct spi_device *spi) | |||
426 | struct iio_dev *indio_dev; | 426 | struct iio_dev *indio_dev; |
427 | 427 | ||
428 | /* setup the industrialio driver allocated elements */ | 428 | /* setup the industrialio driver allocated elements */ |
429 | indio_dev = iio_device_alloc(sizeof(*st)); | 429 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
430 | if (indio_dev == NULL) { | 430 | if (!indio_dev) |
431 | ret = -ENOMEM; | 431 | return -ENOMEM; |
432 | goto error_ret; | ||
433 | } | ||
434 | st = iio_priv(indio_dev); | 432 | st = iio_priv(indio_dev); |
435 | st->us = spi; | 433 | st->us = spi; |
436 | mutex_init(&st->buf_lock); | 434 | mutex_init(&st->buf_lock); |
@@ -447,7 +445,7 @@ static int adxrs450_probe(struct spi_device *spi) | |||
447 | 445 | ||
448 | ret = iio_device_register(indio_dev); | 446 | ret = iio_device_register(indio_dev); |
449 | if (ret) | 447 | if (ret) |
450 | goto error_free_dev; | 448 | return ret; |
451 | 449 | ||
452 | /* Get the device into a sane initial state */ | 450 | /* Get the device into a sane initial state */ |
453 | ret = adxrs450_initial_setup(indio_dev); | 451 | ret = adxrs450_initial_setup(indio_dev); |
@@ -456,17 +454,12 @@ static int adxrs450_probe(struct spi_device *spi) | |||
456 | return 0; | 454 | return 0; |
457 | error_initial: | 455 | error_initial: |
458 | iio_device_unregister(indio_dev); | 456 | iio_device_unregister(indio_dev); |
459 | error_free_dev: | ||
460 | iio_device_free(indio_dev); | ||
461 | |||
462 | error_ret: | ||
463 | return ret; | 457 | return ret; |
464 | } | 458 | } |
465 | 459 | ||
466 | static int adxrs450_remove(struct spi_device *spi) | 460 | static int adxrs450_remove(struct spi_device *spi) |
467 | { | 461 | { |
468 | iio_device_unregister(spi_get_drvdata(spi)); | 462 | iio_device_unregister(spi_get_drvdata(spi)); |
469 | iio_device_free(spi_get_drvdata(spi)); | ||
470 | 463 | ||
471 | return 0; | 464 | return 0; |
472 | } | 465 | } |
diff --git a/drivers/iio/gyro/hid-sensor-gyro-3d.c b/drivers/iio/gyro/hid-sensor-gyro-3d.c index bc943dd47da5..c688d974d3e3 100644 --- a/drivers/iio/gyro/hid-sensor-gyro-3d.c +++ b/drivers/iio/gyro/hid-sensor-gyro-3d.c | |||
@@ -30,10 +30,6 @@ | |||
30 | #include <linux/iio/triggered_buffer.h> | 30 | #include <linux/iio/triggered_buffer.h> |
31 | #include "../common/hid-sensors/hid-sensor-trigger.h" | 31 | #include "../common/hid-sensors/hid-sensor-trigger.h" |
32 | 32 | ||
33 | /*Format: HID-SENSOR-usage_id_in_hex*/ | ||
34 | /*Usage ID from spec for Gyro-3D: 0x200076*/ | ||
35 | #define DRIVER_NAME "HID-SENSOR-200076" | ||
36 | |||
37 | enum gyro_3d_channel { | 33 | enum gyro_3d_channel { |
38 | CHANNEL_SCAN_INDEX_X, | 34 | CHANNEL_SCAN_INDEX_X, |
39 | CHANNEL_SCAN_INDEX_Y, | 35 | CHANNEL_SCAN_INDEX_Y, |
@@ -179,18 +175,10 @@ static int gyro_3d_write_raw(struct iio_dev *indio_dev, | |||
179 | return ret; | 175 | return ret; |
180 | } | 176 | } |
181 | 177 | ||
182 | static int gyro_3d_write_raw_get_fmt(struct iio_dev *indio_dev, | ||
183 | struct iio_chan_spec const *chan, | ||
184 | long mask) | ||
185 | { | ||
186 | return IIO_VAL_INT_PLUS_MICRO; | ||
187 | } | ||
188 | |||
189 | static const struct iio_info gyro_3d_info = { | 178 | static const struct iio_info gyro_3d_info = { |
190 | .driver_module = THIS_MODULE, | 179 | .driver_module = THIS_MODULE, |
191 | .read_raw = &gyro_3d_read_raw, | 180 | .read_raw = &gyro_3d_read_raw, |
192 | .write_raw = &gyro_3d_write_raw, | 181 | .write_raw = &gyro_3d_write_raw, |
193 | .write_raw_get_fmt = &gyro_3d_write_raw_get_fmt, | ||
194 | }; | 182 | }; |
195 | 183 | ||
196 | /* Function to push data to buffer */ | 184 | /* Function to push data to buffer */ |
@@ -286,11 +274,9 @@ static int hid_gyro_3d_probe(struct platform_device *pdev) | |||
286 | struct hid_sensor_hub_device *hsdev = pdev->dev.platform_data; | 274 | struct hid_sensor_hub_device *hsdev = pdev->dev.platform_data; |
287 | struct iio_chan_spec *channels; | 275 | struct iio_chan_spec *channels; |
288 | 276 | ||
289 | indio_dev = iio_device_alloc(sizeof(struct gyro_3d_state)); | 277 | indio_dev = devm_iio_device_alloc(&pdev->dev, sizeof(*gyro_state)); |
290 | if (indio_dev == NULL) { | 278 | if (!indio_dev) |
291 | ret = -ENOMEM; | 279 | return -ENOMEM; |
292 | goto error_ret; | ||
293 | } | ||
294 | platform_set_drvdata(pdev, indio_dev); | 280 | platform_set_drvdata(pdev, indio_dev); |
295 | 281 | ||
296 | gyro_state = iio_priv(indio_dev); | 282 | gyro_state = iio_priv(indio_dev); |
@@ -302,15 +288,14 @@ static int hid_gyro_3d_probe(struct platform_device *pdev) | |||
302 | &gyro_state->common_attributes); | 288 | &gyro_state->common_attributes); |
303 | if (ret) { | 289 | if (ret) { |
304 | dev_err(&pdev->dev, "failed to setup common attributes\n"); | 290 | dev_err(&pdev->dev, "failed to setup common attributes\n"); |
305 | goto error_free_dev; | 291 | return ret; |
306 | } | 292 | } |
307 | 293 | ||
308 | channels = kmemdup(gyro_3d_channels, sizeof(gyro_3d_channels), | 294 | channels = kmemdup(gyro_3d_channels, sizeof(gyro_3d_channels), |
309 | GFP_KERNEL); | 295 | GFP_KERNEL); |
310 | if (!channels) { | 296 | if (!channels) { |
311 | ret = -ENOMEM; | ||
312 | dev_err(&pdev->dev, "failed to duplicate channels\n"); | 297 | dev_err(&pdev->dev, "failed to duplicate channels\n"); |
313 | goto error_free_dev; | 298 | return -ENOMEM; |
314 | } | 299 | } |
315 | 300 | ||
316 | ret = gyro_3d_parse_report(pdev, hsdev, channels, | 301 | ret = gyro_3d_parse_report(pdev, hsdev, channels, |
@@ -367,9 +352,6 @@ error_unreg_buffer_funcs: | |||
367 | iio_triggered_buffer_cleanup(indio_dev); | 352 | iio_triggered_buffer_cleanup(indio_dev); |
368 | error_free_dev_mem: | 353 | error_free_dev_mem: |
369 | kfree(indio_dev->channels); | 354 | kfree(indio_dev->channels); |
370 | error_free_dev: | ||
371 | iio_device_free(indio_dev); | ||
372 | error_ret: | ||
373 | return ret; | 355 | return ret; |
374 | } | 356 | } |
375 | 357 | ||
@@ -384,14 +366,23 @@ static int hid_gyro_3d_remove(struct platform_device *pdev) | |||
384 | hid_sensor_remove_trigger(indio_dev); | 366 | hid_sensor_remove_trigger(indio_dev); |
385 | iio_triggered_buffer_cleanup(indio_dev); | 367 | iio_triggered_buffer_cleanup(indio_dev); |
386 | kfree(indio_dev->channels); | 368 | kfree(indio_dev->channels); |
387 | iio_device_free(indio_dev); | ||
388 | 369 | ||
389 | return 0; | 370 | return 0; |
390 | } | 371 | } |
391 | 372 | ||
373 | static struct platform_device_id hid_gyro_3d_ids[] = { | ||
374 | { | ||
375 | /* Format: HID-SENSOR-usage_id_in_hex_lowercase */ | ||
376 | .name = "HID-SENSOR-200076", | ||
377 | }, | ||
378 | { /* sentinel */ } | ||
379 | }; | ||
380 | MODULE_DEVICE_TABLE(platform, hid_gyro_3d_ids); | ||
381 | |||
392 | static struct platform_driver hid_gyro_3d_platform_driver = { | 382 | static struct platform_driver hid_gyro_3d_platform_driver = { |
383 | .id_table = hid_gyro_3d_ids, | ||
393 | .driver = { | 384 | .driver = { |
394 | .name = DRIVER_NAME, | 385 | .name = KBUILD_MODNAME, |
395 | .owner = THIS_MODULE, | 386 | .owner = THIS_MODULE, |
396 | }, | 387 | }, |
397 | .probe = hid_gyro_3d_probe, | 388 | .probe = hid_gyro_3d_probe, |
diff --git a/drivers/iio/gyro/itg3200_core.c b/drivers/iio/gyro/itg3200_core.c index d66605d2629d..4d3f3b92b361 100644 --- a/drivers/iio/gyro/itg3200_core.c +++ b/drivers/iio/gyro/itg3200_core.c | |||
@@ -309,11 +309,9 @@ static int itg3200_probe(struct i2c_client *client, | |||
309 | 309 | ||
310 | dev_dbg(&client->dev, "probe I2C dev with IRQ %i", client->irq); | 310 | dev_dbg(&client->dev, "probe I2C dev with IRQ %i", client->irq); |
311 | 311 | ||
312 | indio_dev = iio_device_alloc(sizeof(*st)); | 312 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*st)); |
313 | if (indio_dev == NULL) { | 313 | if (!indio_dev) |
314 | ret = -ENOMEM; | 314 | return -ENOMEM; |
315 | goto error_ret; | ||
316 | } | ||
317 | 315 | ||
318 | st = iio_priv(indio_dev); | 316 | st = iio_priv(indio_dev); |
319 | 317 | ||
@@ -330,7 +328,7 @@ static int itg3200_probe(struct i2c_client *client, | |||
330 | 328 | ||
331 | ret = itg3200_buffer_configure(indio_dev); | 329 | ret = itg3200_buffer_configure(indio_dev); |
332 | if (ret) | 330 | if (ret) |
333 | goto error_free_dev; | 331 | return ret; |
334 | 332 | ||
335 | if (client->irq) { | 333 | if (client->irq) { |
336 | ret = itg3200_probe_trigger(indio_dev); | 334 | ret = itg3200_probe_trigger(indio_dev); |
@@ -353,9 +351,6 @@ error_remove_trigger: | |||
353 | itg3200_remove_trigger(indio_dev); | 351 | itg3200_remove_trigger(indio_dev); |
354 | error_unconfigure_buffer: | 352 | error_unconfigure_buffer: |
355 | itg3200_buffer_unconfigure(indio_dev); | 353 | itg3200_buffer_unconfigure(indio_dev); |
356 | error_free_dev: | ||
357 | iio_device_free(indio_dev); | ||
358 | error_ret: | ||
359 | return ret; | 354 | return ret; |
360 | } | 355 | } |
361 | 356 | ||
@@ -370,8 +365,6 @@ static int itg3200_remove(struct i2c_client *client) | |||
370 | 365 | ||
371 | itg3200_buffer_unconfigure(indio_dev); | 366 | itg3200_buffer_unconfigure(indio_dev); |
372 | 367 | ||
373 | iio_device_free(indio_dev); | ||
374 | |||
375 | return 0; | 368 | return 0; |
376 | } | 369 | } |
377 | 370 | ||
diff --git a/drivers/iio/gyro/st_gyro.h b/drivers/iio/gyro/st_gyro.h index 3ad9907bb154..f8f2bf84a5a2 100644 --- a/drivers/iio/gyro/st_gyro.h +++ b/drivers/iio/gyro/st_gyro.h | |||
@@ -23,7 +23,16 @@ | |||
23 | #define L3G4IS_GYRO_DEV_NAME "l3g4is_ui" | 23 | #define L3G4IS_GYRO_DEV_NAME "l3g4is_ui" |
24 | #define LSM330_GYRO_DEV_NAME "lsm330_gyro" | 24 | #define LSM330_GYRO_DEV_NAME "lsm330_gyro" |
25 | 25 | ||
26 | int st_gyro_common_probe(struct iio_dev *indio_dev); | 26 | /** |
27 | * struct st_sensors_platform_data - gyro platform data | ||
28 | * @drdy_int_pin: DRDY on gyros is available only on INT2 pin. | ||
29 | */ | ||
30 | static const struct st_sensors_platform_data gyro_pdata = { | ||
31 | .drdy_int_pin = 2, | ||
32 | }; | ||
33 | |||
34 | int st_gyro_common_probe(struct iio_dev *indio_dev, | ||
35 | struct st_sensors_platform_data *pdata); | ||
27 | void st_gyro_common_remove(struct iio_dev *indio_dev); | 36 | void st_gyro_common_remove(struct iio_dev *indio_dev); |
28 | 37 | ||
29 | #ifdef CONFIG_IIO_BUFFER | 38 | #ifdef CONFIG_IIO_BUFFER |
diff --git a/drivers/iio/gyro/st_gyro_core.c b/drivers/iio/gyro/st_gyro_core.c index f9ed3488c314..e13c2b0bf3d1 100644 --- a/drivers/iio/gyro/st_gyro_core.c +++ b/drivers/iio/gyro/st_gyro_core.c | |||
@@ -60,7 +60,7 @@ | |||
60 | #define ST_GYRO_1_BDU_ADDR 0x23 | 60 | #define ST_GYRO_1_BDU_ADDR 0x23 |
61 | #define ST_GYRO_1_BDU_MASK 0x80 | 61 | #define ST_GYRO_1_BDU_MASK 0x80 |
62 | #define ST_GYRO_1_DRDY_IRQ_ADDR 0x22 | 62 | #define ST_GYRO_1_DRDY_IRQ_ADDR 0x22 |
63 | #define ST_GYRO_1_DRDY_IRQ_MASK 0x08 | 63 | #define ST_GYRO_1_DRDY_IRQ_INT2_MASK 0x08 |
64 | #define ST_GYRO_1_MULTIREAD_BIT true | 64 | #define ST_GYRO_1_MULTIREAD_BIT true |
65 | 65 | ||
66 | /* CUSTOM VALUES FOR SENSOR 2 */ | 66 | /* CUSTOM VALUES FOR SENSOR 2 */ |
@@ -84,7 +84,7 @@ | |||
84 | #define ST_GYRO_2_BDU_ADDR 0x23 | 84 | #define ST_GYRO_2_BDU_ADDR 0x23 |
85 | #define ST_GYRO_2_BDU_MASK 0x80 | 85 | #define ST_GYRO_2_BDU_MASK 0x80 |
86 | #define ST_GYRO_2_DRDY_IRQ_ADDR 0x22 | 86 | #define ST_GYRO_2_DRDY_IRQ_ADDR 0x22 |
87 | #define ST_GYRO_2_DRDY_IRQ_MASK 0x08 | 87 | #define ST_GYRO_2_DRDY_IRQ_INT2_MASK 0x08 |
88 | #define ST_GYRO_2_MULTIREAD_BIT true | 88 | #define ST_GYRO_2_MULTIREAD_BIT true |
89 | 89 | ||
90 | static const struct iio_chan_spec st_gyro_16bit_channels[] = { | 90 | static const struct iio_chan_spec st_gyro_16bit_channels[] = { |
@@ -158,7 +158,7 @@ static const struct st_sensors st_gyro_sensors[] = { | |||
158 | }, | 158 | }, |
159 | .drdy_irq = { | 159 | .drdy_irq = { |
160 | .addr = ST_GYRO_1_DRDY_IRQ_ADDR, | 160 | .addr = ST_GYRO_1_DRDY_IRQ_ADDR, |
161 | .mask = ST_GYRO_1_DRDY_IRQ_MASK, | 161 | .mask_int2 = ST_GYRO_1_DRDY_IRQ_INT2_MASK, |
162 | }, | 162 | }, |
163 | .multi_read_bit = ST_GYRO_1_MULTIREAD_BIT, | 163 | .multi_read_bit = ST_GYRO_1_MULTIREAD_BIT, |
164 | .bootime = 2, | 164 | .bootime = 2, |
@@ -221,7 +221,7 @@ static const struct st_sensors st_gyro_sensors[] = { | |||
221 | }, | 221 | }, |
222 | .drdy_irq = { | 222 | .drdy_irq = { |
223 | .addr = ST_GYRO_2_DRDY_IRQ_ADDR, | 223 | .addr = ST_GYRO_2_DRDY_IRQ_ADDR, |
224 | .mask = ST_GYRO_2_DRDY_IRQ_MASK, | 224 | .mask_int2 = ST_GYRO_2_DRDY_IRQ_INT2_MASK, |
225 | }, | 225 | }, |
226 | .multi_read_bit = ST_GYRO_2_MULTIREAD_BIT, | 226 | .multi_read_bit = ST_GYRO_2_MULTIREAD_BIT, |
227 | .bootime = 2, | 227 | .bootime = 2, |
@@ -302,7 +302,8 @@ static const struct iio_trigger_ops st_gyro_trigger_ops = { | |||
302 | #define ST_GYRO_TRIGGER_OPS NULL | 302 | #define ST_GYRO_TRIGGER_OPS NULL |
303 | #endif | 303 | #endif |
304 | 304 | ||
305 | int st_gyro_common_probe(struct iio_dev *indio_dev) | 305 | int st_gyro_common_probe(struct iio_dev *indio_dev, |
306 | struct st_sensors_platform_data *pdata) | ||
306 | { | 307 | { |
307 | int err; | 308 | int err; |
308 | struct st_sensor_data *gdata = iio_priv(indio_dev); | 309 | struct st_sensor_data *gdata = iio_priv(indio_dev); |
@@ -324,7 +325,7 @@ int st_gyro_common_probe(struct iio_dev *indio_dev) | |||
324 | &gdata->sensor->fs.fs_avl[0]; | 325 | &gdata->sensor->fs.fs_avl[0]; |
325 | gdata->odr = gdata->sensor->odr.odr_avl[0].hz; | 326 | gdata->odr = gdata->sensor->odr.odr_avl[0].hz; |
326 | 327 | ||
327 | err = st_sensors_init_sensor(indio_dev); | 328 | err = st_sensors_init_sensor(indio_dev, pdata); |
328 | if (err < 0) | 329 | if (err < 0) |
329 | goto st_gyro_common_probe_error; | 330 | goto st_gyro_common_probe_error; |
330 | 331 | ||
@@ -365,7 +366,6 @@ void st_gyro_common_remove(struct iio_dev *indio_dev) | |||
365 | st_sensors_deallocate_trigger(indio_dev); | 366 | st_sensors_deallocate_trigger(indio_dev); |
366 | st_gyro_deallocate_ring(indio_dev); | 367 | st_gyro_deallocate_ring(indio_dev); |
367 | } | 368 | } |
368 | iio_device_free(indio_dev); | ||
369 | } | 369 | } |
370 | EXPORT_SYMBOL(st_gyro_common_remove); | 370 | EXPORT_SYMBOL(st_gyro_common_remove); |
371 | 371 | ||
diff --git a/drivers/iio/gyro/st_gyro_i2c.c b/drivers/iio/gyro/st_gyro_i2c.c index 8a310500573d..16b8b8d70bf1 100644 --- a/drivers/iio/gyro/st_gyro_i2c.c +++ b/drivers/iio/gyro/st_gyro_i2c.c | |||
@@ -25,27 +25,21 @@ static int st_gyro_i2c_probe(struct i2c_client *client, | |||
25 | struct st_sensor_data *gdata; | 25 | struct st_sensor_data *gdata; |
26 | int err; | 26 | int err; |
27 | 27 | ||
28 | indio_dev = iio_device_alloc(sizeof(*gdata)); | 28 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*gdata)); |
29 | if (indio_dev == NULL) { | 29 | if (!indio_dev) |
30 | err = -ENOMEM; | 30 | return -ENOMEM; |
31 | goto iio_device_alloc_error; | ||
32 | } | ||
33 | 31 | ||
34 | gdata = iio_priv(indio_dev); | 32 | gdata = iio_priv(indio_dev); |
35 | gdata->dev = &client->dev; | 33 | gdata->dev = &client->dev; |
36 | 34 | ||
37 | st_sensors_i2c_configure(indio_dev, client, gdata); | 35 | st_sensors_i2c_configure(indio_dev, client, gdata); |
38 | 36 | ||
39 | err = st_gyro_common_probe(indio_dev); | 37 | err = st_gyro_common_probe(indio_dev, |
38 | (struct st_sensors_platform_data *)&gyro_pdata); | ||
40 | if (err < 0) | 39 | if (err < 0) |
41 | goto st_gyro_common_probe_error; | 40 | return err; |
42 | 41 | ||
43 | return 0; | 42 | return 0; |
44 | |||
45 | st_gyro_common_probe_error: | ||
46 | iio_device_free(indio_dev); | ||
47 | iio_device_alloc_error: | ||
48 | return err; | ||
49 | } | 43 | } |
50 | 44 | ||
51 | static int st_gyro_i2c_remove(struct i2c_client *client) | 45 | static int st_gyro_i2c_remove(struct i2c_client *client) |
diff --git a/drivers/iio/gyro/st_gyro_spi.c b/drivers/iio/gyro/st_gyro_spi.c index f3540390eb22..94763e25caf9 100644 --- a/drivers/iio/gyro/st_gyro_spi.c +++ b/drivers/iio/gyro/st_gyro_spi.c | |||
@@ -24,27 +24,21 @@ static int st_gyro_spi_probe(struct spi_device *spi) | |||
24 | struct st_sensor_data *gdata; | 24 | struct st_sensor_data *gdata; |
25 | int err; | 25 | int err; |
26 | 26 | ||
27 | indio_dev = iio_device_alloc(sizeof(*gdata)); | 27 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*gdata)); |
28 | if (indio_dev == NULL) { | 28 | if (!indio_dev) |
29 | err = -ENOMEM; | 29 | return -ENOMEM; |
30 | goto iio_device_alloc_error; | ||
31 | } | ||
32 | 30 | ||
33 | gdata = iio_priv(indio_dev); | 31 | gdata = iio_priv(indio_dev); |
34 | gdata->dev = &spi->dev; | 32 | gdata->dev = &spi->dev; |
35 | 33 | ||
36 | st_sensors_spi_configure(indio_dev, spi, gdata); | 34 | st_sensors_spi_configure(indio_dev, spi, gdata); |
37 | 35 | ||
38 | err = st_gyro_common_probe(indio_dev); | 36 | err = st_gyro_common_probe(indio_dev, |
37 | (struct st_sensors_platform_data *)&gyro_pdata); | ||
39 | if (err < 0) | 38 | if (err < 0) |
40 | goto st_gyro_common_probe_error; | 39 | return err; |
41 | 40 | ||
42 | return 0; | 41 | return 0; |
43 | |||
44 | st_gyro_common_probe_error: | ||
45 | iio_device_free(indio_dev); | ||
46 | iio_device_alloc_error: | ||
47 | return err; | ||
48 | } | 42 | } |
49 | 43 | ||
50 | static int st_gyro_spi_remove(struct spi_device *spi) | 44 | static int st_gyro_spi_remove(struct spi_device *spi) |
diff --git a/drivers/iio/iio_core_trigger.h b/drivers/iio/iio_core_trigger.h index 6f7c56fcbe78..1fdb1e4ea4a5 100644 --- a/drivers/iio/iio_core_trigger.h +++ b/drivers/iio/iio_core_trigger.h | |||
@@ -30,7 +30,7 @@ void iio_device_unregister_trigger_consumer(struct iio_dev *indio_dev); | |||
30 | static int iio_device_register_trigger_consumer(struct iio_dev *indio_dev) | 30 | static int iio_device_register_trigger_consumer(struct iio_dev *indio_dev) |
31 | { | 31 | { |
32 | return 0; | 32 | return 0; |
33 | }; | 33 | } |
34 | 34 | ||
35 | /** | 35 | /** |
36 | * iio_device_unregister_trigger_consumer() - reverse the registration process | 36 | * iio_device_unregister_trigger_consumer() - reverse the registration process |
@@ -38,9 +38,6 @@ static int iio_device_register_trigger_consumer(struct iio_dev *indio_dev) | |||
38 | **/ | 38 | **/ |
39 | static void iio_device_unregister_trigger_consumer(struct iio_dev *indio_dev) | 39 | static void iio_device_unregister_trigger_consumer(struct iio_dev *indio_dev) |
40 | { | 40 | { |
41 | }; | 41 | } |
42 | 42 | ||
43 | #endif /* CONFIG_TRIGGER_CONSUMER */ | 43 | #endif /* CONFIG_TRIGGER_CONSUMER */ |
44 | |||
45 | |||
46 | |||
diff --git a/drivers/iio/imu/Kconfig b/drivers/iio/imu/Kconfig index 4f40a10cb74f..663e88a1a3c1 100644 --- a/drivers/iio/imu/Kconfig +++ b/drivers/iio/imu/Kconfig | |||
@@ -1,6 +1,8 @@ | |||
1 | # | 1 | # |
2 | # IIO imu drivers configuration | 2 | # IIO imu drivers configuration |
3 | # | 3 | # |
4 | # When adding new entries keep the list in alphabetical order | ||
5 | |||
4 | menu "Inertial measurement units" | 6 | menu "Inertial measurement units" |
5 | 7 | ||
6 | config ADIS16400 | 8 | config ADIS16400 |
diff --git a/drivers/iio/imu/Makefile b/drivers/iio/imu/Makefile index f2f56ceaed26..114d2c17cbe2 100644 --- a/drivers/iio/imu/Makefile +++ b/drivers/iio/imu/Makefile | |||
@@ -2,6 +2,7 @@ | |||
2 | # Makefile for Inertial Measurement Units | 2 | # Makefile for Inertial Measurement Units |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | adis16400-y := adis16400_core.o | 6 | adis16400-y := adis16400_core.o |
6 | adis16400-$(CONFIG_IIO_BUFFER) += adis16400_buffer.o | 7 | adis16400-$(CONFIG_IIO_BUFFER) += adis16400_buffer.o |
7 | obj-$(CONFIG_ADIS16400) += adis16400.o | 8 | obj-$(CONFIG_ADIS16400) += adis16400.o |
diff --git a/drivers/iio/imu/adis16400_core.c b/drivers/iio/imu/adis16400_core.c index f60591f0b925..3fb7757a1028 100644 --- a/drivers/iio/imu/adis16400_core.c +++ b/drivers/iio/imu/adis16400_core.c | |||
@@ -871,7 +871,7 @@ static int adis16400_probe(struct spi_device *spi) | |||
871 | struct iio_dev *indio_dev; | 871 | struct iio_dev *indio_dev; |
872 | int ret; | 872 | int ret; |
873 | 873 | ||
874 | indio_dev = iio_device_alloc(sizeof(*st)); | 874 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
875 | if (indio_dev == NULL) | 875 | if (indio_dev == NULL) |
876 | return -ENOMEM; | 876 | return -ENOMEM; |
877 | 877 | ||
@@ -893,12 +893,12 @@ static int adis16400_probe(struct spi_device *spi) | |||
893 | 893 | ||
894 | ret = adis_init(&st->adis, indio_dev, spi, &adis16400_data); | 894 | ret = adis_init(&st->adis, indio_dev, spi, &adis16400_data); |
895 | if (ret) | 895 | if (ret) |
896 | goto error_free_dev; | 896 | return ret; |
897 | 897 | ||
898 | ret = adis_setup_buffer_and_trigger(&st->adis, indio_dev, | 898 | ret = adis_setup_buffer_and_trigger(&st->adis, indio_dev, |
899 | adis16400_trigger_handler); | 899 | adis16400_trigger_handler); |
900 | if (ret) | 900 | if (ret) |
901 | goto error_free_dev; | 901 | return ret; |
902 | 902 | ||
903 | /* Get the device into a sane initial state */ | 903 | /* Get the device into a sane initial state */ |
904 | ret = adis16400_initial_setup(indio_dev); | 904 | ret = adis16400_initial_setup(indio_dev); |
@@ -913,8 +913,6 @@ static int adis16400_probe(struct spi_device *spi) | |||
913 | 913 | ||
914 | error_cleanup_buffer: | 914 | error_cleanup_buffer: |
915 | adis_cleanup_buffer_and_trigger(&st->adis, indio_dev); | 915 | adis_cleanup_buffer_and_trigger(&st->adis, indio_dev); |
916 | error_free_dev: | ||
917 | iio_device_free(indio_dev); | ||
918 | return ret; | 916 | return ret; |
919 | } | 917 | } |
920 | 918 | ||
@@ -928,8 +926,6 @@ static int adis16400_remove(struct spi_device *spi) | |||
928 | 926 | ||
929 | adis_cleanup_buffer_and_trigger(&st->adis, indio_dev); | 927 | adis_cleanup_buffer_and_trigger(&st->adis, indio_dev); |
930 | 928 | ||
931 | iio_device_free(indio_dev); | ||
932 | |||
933 | return 0; | 929 | return 0; |
934 | } | 930 | } |
935 | 931 | ||
diff --git a/drivers/iio/imu/adis16480.c b/drivers/iio/imu/adis16480.c index b7db38376295..dd4206cac62d 100644 --- a/drivers/iio/imu/adis16480.c +++ b/drivers/iio/imu/adis16480.c | |||
@@ -839,7 +839,7 @@ static int adis16480_probe(struct spi_device *spi) | |||
839 | struct adis16480 *st; | 839 | struct adis16480 *st; |
840 | int ret; | 840 | int ret; |
841 | 841 | ||
842 | indio_dev = iio_device_alloc(sizeof(*st)); | 842 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); |
843 | if (indio_dev == NULL) | 843 | if (indio_dev == NULL) |
844 | return -ENOMEM; | 844 | return -ENOMEM; |
845 | 845 | ||
@@ -857,11 +857,11 @@ static int adis16480_probe(struct spi_device *spi) | |||
857 | 857 | ||
858 | ret = adis_init(&st->adis, indio_dev, spi, &adis16480_data); | 858 | ret = adis_init(&st->adis, indio_dev, spi, &adis16480_data); |
859 | if (ret) | 859 | if (ret) |
860 | goto error_free_dev; | 860 | return ret; |
861 | 861 | ||
862 | ret = adis_setup_buffer_and_trigger(&st->adis, indio_dev, NULL); | 862 | ret = adis_setup_buffer_and_trigger(&st->adis, indio_dev, NULL); |
863 | if (ret) | 863 | if (ret) |
864 | goto error_free_dev; | 864 | return ret; |
865 | 865 | ||
866 | ret = adis16480_initial_setup(indio_dev); | 866 | ret = adis16480_initial_setup(indio_dev); |
867 | if (ret) | 867 | if (ret) |
@@ -879,8 +879,6 @@ error_stop_device: | |||
879 | adis16480_stop_device(indio_dev); | 879 | adis16480_stop_device(indio_dev); |
880 | error_cleanup_buffer: | 880 | error_cleanup_buffer: |
881 | adis_cleanup_buffer_and_trigger(&st->adis, indio_dev); | 881 | adis_cleanup_buffer_and_trigger(&st->adis, indio_dev); |
882 | error_free_dev: | ||
883 | iio_device_free(indio_dev); | ||
884 | return ret; | 882 | return ret; |
885 | } | 883 | } |
886 | 884 | ||
@@ -894,8 +892,6 @@ static int adis16480_remove(struct spi_device *spi) | |||
894 | 892 | ||
895 | adis_cleanup_buffer_and_trigger(&st->adis, indio_dev); | 893 | adis_cleanup_buffer_and_trigger(&st->adis, indio_dev); |
896 | 894 | ||
897 | iio_device_free(indio_dev); | ||
898 | |||
899 | return 0; | 895 | return 0; |
900 | } | 896 | } |
901 | 897 | ||
diff --git a/drivers/iio/imu/inv_mpu6050/inv_mpu_core.c b/drivers/iio/imu/inv_mpu6050/inv_mpu_core.c index fe4c61e219f3..df7f1e1157ae 100644 --- a/drivers/iio/imu/inv_mpu6050/inv_mpu_core.c +++ b/drivers/iio/imu/inv_mpu6050/inv_mpu_core.c | |||
@@ -23,6 +23,7 @@ | |||
23 | #include <linux/interrupt.h> | 23 | #include <linux/interrupt.h> |
24 | #include <linux/kfifo.h> | 24 | #include <linux/kfifo.h> |
25 | #include <linux/spinlock.h> | 25 | #include <linux/spinlock.h> |
26 | #include <linux/iio/iio.h> | ||
26 | #include "inv_mpu_iio.h" | 27 | #include "inv_mpu_iio.h" |
27 | 28 | ||
28 | /* | 29 | /* |
@@ -663,16 +664,13 @@ static int inv_mpu_probe(struct i2c_client *client, | |||
663 | int result; | 664 | int result; |
664 | 665 | ||
665 | if (!i2c_check_functionality(client->adapter, | 666 | if (!i2c_check_functionality(client->adapter, |
666 | I2C_FUNC_SMBUS_READ_I2C_BLOCK | | 667 | I2C_FUNC_SMBUS_I2C_BLOCK)) |
667 | I2C_FUNC_SMBUS_WRITE_I2C_BLOCK)) { | 668 | return -ENOSYS; |
668 | result = -ENOSYS; | 669 | |
669 | goto out_no_free; | 670 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*st)); |
670 | } | 671 | if (!indio_dev) |
671 | indio_dev = iio_device_alloc(sizeof(*st)); | 672 | return -ENOMEM; |
672 | if (indio_dev == NULL) { | 673 | |
673 | result = -ENOMEM; | ||
674 | goto out_no_free; | ||
675 | } | ||
676 | st = iio_priv(indio_dev); | 674 | st = iio_priv(indio_dev); |
677 | st->client = client; | 675 | st->client = client; |
678 | st->plat_data = *(struct inv_mpu6050_platform_data | 676 | st->plat_data = *(struct inv_mpu6050_platform_data |
@@ -680,13 +678,13 @@ static int inv_mpu_probe(struct i2c_client *client, | |||
680 | /* power is turned on inside check chip type*/ | 678 | /* power is turned on inside check chip type*/ |
681 | result = inv_check_and_setup_chip(st, id); | 679 | result = inv_check_and_setup_chip(st, id); |
682 | if (result) | 680 | if (result) |
683 | goto out_free; | 681 | return result; |
684 | 682 | ||
685 | result = inv_mpu6050_init_config(indio_dev); | 683 | result = inv_mpu6050_init_config(indio_dev); |
686 | if (result) { | 684 | if (result) { |
687 | dev_err(&client->dev, | 685 | dev_err(&client->dev, |
688 | "Could not initialize device.\n"); | 686 | "Could not initialize device.\n"); |
689 | goto out_free; | 687 | return result; |
690 | } | 688 | } |
691 | 689 | ||
692 | i2c_set_clientdata(client, indio_dev); | 690 | i2c_set_clientdata(client, indio_dev); |
@@ -705,7 +703,7 @@ static int inv_mpu_probe(struct i2c_client *client, | |||
705 | if (result) { | 703 | if (result) { |
706 | dev_err(&st->client->dev, "configure buffer fail %d\n", | 704 | dev_err(&st->client->dev, "configure buffer fail %d\n", |
707 | result); | 705 | result); |
708 | goto out_free; | 706 | return result; |
709 | } | 707 | } |
710 | result = inv_mpu6050_probe_trigger(indio_dev); | 708 | result = inv_mpu6050_probe_trigger(indio_dev); |
711 | if (result) { | 709 | if (result) { |
@@ -727,10 +725,6 @@ out_remove_trigger: | |||
727 | inv_mpu6050_remove_trigger(st); | 725 | inv_mpu6050_remove_trigger(st); |
728 | out_unreg_ring: | 726 | out_unreg_ring: |
729 | iio_triggered_buffer_cleanup(indio_dev); | 727 | iio_triggered_buffer_cleanup(indio_dev); |
730 | out_free: | ||
731 | iio_device_free(indio_dev); | ||
732 | out_no_free: | ||
733 | |||
734 | return result; | 728 | return result; |
735 | } | 729 | } |
736 | 730 | ||
@@ -742,7 +736,6 @@ static int inv_mpu_remove(struct i2c_client *client) | |||
742 | iio_device_unregister(indio_dev); | 736 | iio_device_unregister(indio_dev); |
743 | inv_mpu6050_remove_trigger(st); | 737 | inv_mpu6050_remove_trigger(st); |
744 | iio_triggered_buffer_cleanup(indio_dev); | 738 | iio_triggered_buffer_cleanup(indio_dev); |
745 | iio_device_free(indio_dev); | ||
746 | 739 | ||
747 | return 0; | 740 | return 0; |
748 | } | 741 | } |
diff --git a/drivers/iio/industrialio-core.c b/drivers/iio/industrialio-core.c index e145931ef1b8..97f0297b120f 100644 --- a/drivers/iio/industrialio-core.c +++ b/drivers/iio/industrialio-core.c | |||
@@ -383,14 +383,14 @@ static ssize_t iio_read_channel_info(struct device *dev, | |||
383 | scale_db = true; | 383 | scale_db = true; |
384 | case IIO_VAL_INT_PLUS_MICRO: | 384 | case IIO_VAL_INT_PLUS_MICRO: |
385 | if (val2 < 0) | 385 | if (val2 < 0) |
386 | return sprintf(buf, "-%d.%06u%s\n", val, -val2, | 386 | return sprintf(buf, "-%ld.%06u%s\n", abs(val), -val2, |
387 | scale_db ? " dB" : ""); | 387 | scale_db ? " dB" : ""); |
388 | else | 388 | else |
389 | return sprintf(buf, "%d.%06u%s\n", val, val2, | 389 | return sprintf(buf, "%d.%06u%s\n", val, val2, |
390 | scale_db ? " dB" : ""); | 390 | scale_db ? " dB" : ""); |
391 | case IIO_VAL_INT_PLUS_NANO: | 391 | case IIO_VAL_INT_PLUS_NANO: |
392 | if (val2 < 0) | 392 | if (val2 < 0) |
393 | return sprintf(buf, "-%d.%09u\n", val, -val2); | 393 | return sprintf(buf, "-%ld.%09u\n", abs(val), -val2); |
394 | else | 394 | else |
395 | return sprintf(buf, "%d.%09u\n", val, val2); | 395 | return sprintf(buf, "%d.%09u\n", val, val2); |
396 | case IIO_VAL_FRACTIONAL: | 396 | case IIO_VAL_FRACTIONAL: |
@@ -912,6 +912,53 @@ void iio_device_free(struct iio_dev *dev) | |||
912 | } | 912 | } |
913 | EXPORT_SYMBOL(iio_device_free); | 913 | EXPORT_SYMBOL(iio_device_free); |
914 | 914 | ||
915 | static void devm_iio_device_release(struct device *dev, void *res) | ||
916 | { | ||
917 | iio_device_free(*(struct iio_dev **)res); | ||
918 | } | ||
919 | |||
920 | static int devm_iio_device_match(struct device *dev, void *res, void *data) | ||
921 | { | ||
922 | struct iio_dev **r = res; | ||
923 | if (!r || !*r) { | ||
924 | WARN_ON(!r || !*r); | ||
925 | return 0; | ||
926 | } | ||
927 | return *r == data; | ||
928 | } | ||
929 | |||
930 | struct iio_dev *devm_iio_device_alloc(struct device *dev, int sizeof_priv) | ||
931 | { | ||
932 | struct iio_dev **ptr, *iio_dev; | ||
933 | |||
934 | ptr = devres_alloc(devm_iio_device_release, sizeof(*ptr), | ||
935 | GFP_KERNEL); | ||
936 | if (!ptr) | ||
937 | return NULL; | ||
938 | |||
939 | /* use raw alloc_dr for kmalloc caller tracing */ | ||
940 | iio_dev = iio_device_alloc(sizeof_priv); | ||
941 | if (iio_dev) { | ||
942 | *ptr = iio_dev; | ||
943 | devres_add(dev, ptr); | ||
944 | } else { | ||
945 | devres_free(ptr); | ||
946 | } | ||
947 | |||
948 | return iio_dev; | ||
949 | } | ||
950 | EXPORT_SYMBOL_GPL(devm_iio_device_alloc); | ||
951 | |||
952 | void devm_iio_device_free(struct device *dev, struct iio_dev *iio_dev) | ||
953 | { | ||
954 | int rc; | ||
955 | |||
956 | rc = devres_release(dev, devm_iio_device_release, | ||
957 | devm_iio_device_match, iio_dev); | ||
958 | WARN_ON(rc); | ||
959 | } | ||
960 | EXPORT_SYMBOL_GPL(devm_iio_device_free); | ||
961 | |||
915 | /** | 962 | /** |
916 | * iio_chrdev_open() - chrdev file open for buffer access and ioctls | 963 | * iio_chrdev_open() - chrdev file open for buffer access and ioctls |
917 | **/ | 964 | **/ |
diff --git a/drivers/iio/industrialio-trigger.c b/drivers/iio/industrialio-trigger.c index 0dd9bb873130..bf5e70a32d3f 100644 --- a/drivers/iio/industrialio-trigger.c +++ b/drivers/iio/industrialio-trigger.c | |||
@@ -424,9 +424,8 @@ static void iio_trig_subirqunmask(struct irq_data *d) | |||
424 | trig->subirqs[d->irq - trig->subirq_base].enabled = true; | 424 | trig->subirqs[d->irq - trig->subirq_base].enabled = true; |
425 | } | 425 | } |
426 | 426 | ||
427 | struct iio_trigger *iio_trigger_alloc(const char *fmt, ...) | 427 | static struct iio_trigger *viio_trigger_alloc(const char *fmt, va_list vargs) |
428 | { | 428 | { |
429 | va_list vargs; | ||
430 | struct iio_trigger *trig; | 429 | struct iio_trigger *trig; |
431 | trig = kzalloc(sizeof *trig, GFP_KERNEL); | 430 | trig = kzalloc(sizeof *trig, GFP_KERNEL); |
432 | if (trig) { | 431 | if (trig) { |
@@ -444,9 +443,8 @@ struct iio_trigger *iio_trigger_alloc(const char *fmt, ...) | |||
444 | kfree(trig); | 443 | kfree(trig); |
445 | return NULL; | 444 | return NULL; |
446 | } | 445 | } |
447 | va_start(vargs, fmt); | 446 | |
448 | trig->name = kvasprintf(GFP_KERNEL, fmt, vargs); | 447 | trig->name = kvasprintf(GFP_KERNEL, fmt, vargs); |
449 | va_end(vargs); | ||
450 | if (trig->name == NULL) { | 448 | if (trig->name == NULL) { |
451 | irq_free_descs(trig->subirq_base, | 449 | irq_free_descs(trig->subirq_base, |
452 | CONFIG_IIO_CONSUMERS_PER_TRIGGER); | 450 | CONFIG_IIO_CONSUMERS_PER_TRIGGER); |
@@ -467,6 +465,19 @@ struct iio_trigger *iio_trigger_alloc(const char *fmt, ...) | |||
467 | } | 465 | } |
468 | get_device(&trig->dev); | 466 | get_device(&trig->dev); |
469 | } | 467 | } |
468 | |||
469 | return trig; | ||
470 | } | ||
471 | |||
472 | struct iio_trigger *iio_trigger_alloc(const char *fmt, ...) | ||
473 | { | ||
474 | struct iio_trigger *trig; | ||
475 | va_list vargs; | ||
476 | |||
477 | va_start(vargs, fmt); | ||
478 | trig = viio_trigger_alloc(fmt, vargs); | ||
479 | va_end(vargs); | ||
480 | |||
470 | return trig; | 481 | return trig; |
471 | } | 482 | } |
472 | EXPORT_SYMBOL(iio_trigger_alloc); | 483 | EXPORT_SYMBOL(iio_trigger_alloc); |
@@ -478,6 +489,59 @@ void iio_trigger_free(struct iio_trigger *trig) | |||
478 | } | 489 | } |
479 | EXPORT_SYMBOL(iio_trigger_free); | 490 | EXPORT_SYMBOL(iio_trigger_free); |
480 | 491 | ||
492 | static void devm_iio_trigger_release(struct device *dev, void *res) | ||
493 | { | ||
494 | iio_trigger_free(*(struct iio_trigger **)res); | ||
495 | } | ||
496 | |||
497 | static int devm_iio_trigger_match(struct device *dev, void *res, void *data) | ||
498 | { | ||
499 | struct iio_trigger **r = res; | ||
500 | |||
501 | if (!r || !*r) { | ||
502 | WARN_ON(!r || !*r); | ||
503 | return 0; | ||
504 | } | ||
505 | |||
506 | return *r == data; | ||
507 | } | ||
508 | |||
509 | struct iio_trigger *devm_iio_trigger_alloc(struct device *dev, | ||
510 | const char *fmt, ...) | ||
511 | { | ||
512 | struct iio_trigger **ptr, *trig; | ||
513 | va_list vargs; | ||
514 | |||
515 | ptr = devres_alloc(devm_iio_trigger_release, sizeof(*ptr), | ||
516 | GFP_KERNEL); | ||
517 | if (!ptr) | ||
518 | return NULL; | ||
519 | |||
520 | /* use raw alloc_dr for kmalloc caller tracing */ | ||
521 | va_start(vargs, fmt); | ||
522 | trig = viio_trigger_alloc(fmt, vargs); | ||
523 | va_end(vargs); | ||
524 | if (trig) { | ||
525 | *ptr = trig; | ||
526 | devres_add(dev, ptr); | ||
527 | } else { | ||
528 | devres_free(ptr); | ||
529 | } | ||
530 | |||
531 | return trig; | ||
532 | } | ||
533 | EXPORT_SYMBOL_GPL(devm_iio_trigger_alloc); | ||
534 | |||
535 | void devm_iio_trigger_free(struct device *dev, struct iio_trigger *iio_trig) | ||
536 | { | ||
537 | int rc; | ||
538 | |||
539 | rc = devres_release(dev, devm_iio_trigger_release, | ||
540 | devm_iio_trigger_match, iio_trig); | ||
541 | WARN_ON(rc); | ||
542 | } | ||
543 | EXPORT_SYMBOL_GPL(devm_iio_trigger_free); | ||
544 | |||
481 | void iio_device_register_trigger_consumer(struct iio_dev *indio_dev) | 545 | void iio_device_register_trigger_consumer(struct iio_dev *indio_dev) |
482 | { | 546 | { |
483 | indio_dev->groups[indio_dev->groupcounter++] = | 547 | indio_dev->groups[indio_dev->groupcounter++] = |
diff --git a/drivers/iio/light/Kconfig b/drivers/iio/light/Kconfig index 5ef1a396e0c9..bf9fa0d7aff9 100644 --- a/drivers/iio/light/Kconfig +++ b/drivers/iio/light/Kconfig | |||
@@ -1,6 +1,8 @@ | |||
1 | # | 1 | # |
2 | # Light sensors | 2 | # Light sensors |
3 | # | 3 | # |
4 | # When adding new entries keep the list in alphabetical order | ||
5 | |||
4 | menu "Light sensors" | 6 | menu "Light sensors" |
5 | 7 | ||
6 | config ADJD_S311 | 8 | config ADJD_S311 |
@@ -15,6 +17,27 @@ config ADJD_S311 | |||
15 | This driver can also be built as a module. If so, the module | 17 | This driver can also be built as a module. If so, the module |
16 | will be called adjd_s311. | 18 | will be called adjd_s311. |
17 | 19 | ||
20 | config APDS9300 | ||
21 | tristate "APDS9300 ambient light sensor" | ||
22 | depends on I2C | ||
23 | help | ||
24 | Say Y here if you want to build a driver for the Avago APDS9300 | ||
25 | ambient light sensor. | ||
26 | |||
27 | To compile this driver as a module, choose M here: the | ||
28 | module will be called apds9300. | ||
29 | |||
30 | config HID_SENSOR_ALS | ||
31 | depends on HID_SENSOR_HUB | ||
32 | select IIO_BUFFER | ||
33 | select IIO_TRIGGERED_BUFFER | ||
34 | select HID_SENSOR_IIO_COMMON | ||
35 | select HID_SENSOR_IIO_TRIGGER | ||
36 | tristate "HID ALS" | ||
37 | help | ||
38 | Say yes here to build support for the HID SENSOR | ||
39 | Ambient light sensor. | ||
40 | |||
18 | config SENSORS_LM3533 | 41 | config SENSORS_LM3533 |
19 | tristate "LM3533 ambient light sensor" | 42 | tristate "LM3533 ambient light sensor" |
20 | depends on MFD_LM3533 | 43 | depends on MFD_LM3533 |
@@ -52,15 +75,4 @@ config VCNL4000 | |||
52 | To compile this driver as a module, choose M here: the | 75 | To compile this driver as a module, choose M here: the |
53 | module will be called vcnl4000. | 76 | module will be called vcnl4000. |
54 | 77 | ||
55 | config HID_SENSOR_ALS | ||
56 | depends on HID_SENSOR_HUB | ||
57 | select IIO_BUFFER | ||
58 | select IIO_TRIGGERED_BUFFER | ||
59 | select HID_SENSOR_IIO_COMMON | ||
60 | select HID_SENSOR_IIO_TRIGGER | ||
61 | tristate "HID ALS" | ||
62 | help | ||
63 | Say yes here to build support for the HID SENSOR | ||
64 | Ambient light sensor. | ||
65 | |||
66 | endmenu | 78 | endmenu |
diff --git a/drivers/iio/light/Makefile b/drivers/iio/light/Makefile index 040d9c75f8e6..354ee9ab2379 100644 --- a/drivers/iio/light/Makefile +++ b/drivers/iio/light/Makefile | |||
@@ -2,8 +2,10 @@ | |||
2 | # Makefile for IIO Light sensors | 2 | # Makefile for IIO Light sensors |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | obj-$(CONFIG_ADJD_S311) += adjd_s311.o | 6 | obj-$(CONFIG_ADJD_S311) += adjd_s311.o |
7 | obj-$(CONFIG_APDS9300) += apds9300.o | ||
8 | obj-$(CONFIG_HID_SENSOR_ALS) += hid-sensor-als.o | ||
6 | obj-$(CONFIG_SENSORS_LM3533) += lm3533-als.o | 9 | obj-$(CONFIG_SENSORS_LM3533) += lm3533-als.o |
7 | obj-$(CONFIG_SENSORS_TSL2563) += tsl2563.o | 10 | obj-$(CONFIG_SENSORS_TSL2563) += tsl2563.o |
8 | obj-$(CONFIG_VCNL4000) += vcnl4000.o | 11 | obj-$(CONFIG_VCNL4000) += vcnl4000.o |
9 | obj-$(CONFIG_HID_SENSOR_ALS) += hid-sensor-als.o | ||
diff --git a/drivers/iio/light/adjd_s311.c b/drivers/iio/light/adjd_s311.c index c1cd5698b8ae..23cff798598a 100644 --- a/drivers/iio/light/adjd_s311.c +++ b/drivers/iio/light/adjd_s311.c | |||
@@ -37,22 +37,14 @@ | |||
37 | #define ADJD_S311_CAP_GREEN 0x07 | 37 | #define ADJD_S311_CAP_GREEN 0x07 |
38 | #define ADJD_S311_CAP_BLUE 0x08 | 38 | #define ADJD_S311_CAP_BLUE 0x08 |
39 | #define ADJD_S311_CAP_CLEAR 0x09 | 39 | #define ADJD_S311_CAP_CLEAR 0x09 |
40 | #define ADJD_S311_INT_RED_LO 0x0a | 40 | #define ADJD_S311_INT_RED 0x0a |
41 | #define ADJD_S311_INT_RED_HI 0x0b | 41 | #define ADJD_S311_INT_GREEN 0x0c |
42 | #define ADJD_S311_INT_GREEN_LO 0x0c | 42 | #define ADJD_S311_INT_BLUE 0x0e |
43 | #define ADJD_S311_INT_GREEN_HI 0x0d | 43 | #define ADJD_S311_INT_CLEAR 0x10 |
44 | #define ADJD_S311_INT_BLUE_LO 0x0e | 44 | #define ADJD_S311_DATA_RED 0x40 |
45 | #define ADJD_S311_INT_BLUE_HI 0x0f | 45 | #define ADJD_S311_DATA_GREEN 0x42 |
46 | #define ADJD_S311_INT_CLEAR_LO 0x10 | 46 | #define ADJD_S311_DATA_BLUE 0x44 |
47 | #define ADJD_S311_INT_CLEAR_HI 0x11 | 47 | #define ADJD_S311_DATA_CLEAR 0x46 |
48 | #define ADJD_S311_DATA_RED_LO 0x40 | ||
49 | #define ADJD_S311_DATA_RED_HI 0x41 | ||
50 | #define ADJD_S311_DATA_GREEN_LO 0x42 | ||
51 | #define ADJD_S311_DATA_GREEN_HI 0x43 | ||
52 | #define ADJD_S311_DATA_BLUE_LO 0x44 | ||
53 | #define ADJD_S311_DATA_BLUE_HI 0x45 | ||
54 | #define ADJD_S311_DATA_CLEAR_LO 0x46 | ||
55 | #define ADJD_S311_DATA_CLEAR_HI 0x47 | ||
56 | #define ADJD_S311_OFFSET_RED 0x48 | 48 | #define ADJD_S311_OFFSET_RED 0x48 |
57 | #define ADJD_S311_OFFSET_GREEN 0x49 | 49 | #define ADJD_S311_OFFSET_GREEN 0x49 |
58 | #define ADJD_S311_OFFSET_BLUE 0x4a | 50 | #define ADJD_S311_OFFSET_BLUE 0x4a |
@@ -73,8 +65,8 @@ enum adjd_s311_channel_idx { | |||
73 | IDX_RED, IDX_GREEN, IDX_BLUE, IDX_CLEAR | 65 | IDX_RED, IDX_GREEN, IDX_BLUE, IDX_CLEAR |
74 | }; | 66 | }; |
75 | 67 | ||
76 | #define ADJD_S311_DATA_REG(chan) (ADJD_S311_DATA_RED_LO + (chan) * 2) | 68 | #define ADJD_S311_DATA_REG(chan) (ADJD_S311_DATA_RED + (chan) * 2) |
77 | #define ADJD_S311_INT_REG(chan) (ADJD_S311_INT_RED_LO + (chan) * 2) | 69 | #define ADJD_S311_INT_REG(chan) (ADJD_S311_INT_RED + (chan) * 2) |
78 | #define ADJD_S311_CAP_REG(chan) (ADJD_S311_CAP_RED + (chan)) | 70 | #define ADJD_S311_CAP_REG(chan) (ADJD_S311_CAP_RED + (chan)) |
79 | 71 | ||
80 | static int adjd_s311_req_data(struct iio_dev *indio_dev) | 72 | static int adjd_s311_req_data(struct iio_dev *indio_dev) |
@@ -294,11 +286,10 @@ static int adjd_s311_probe(struct i2c_client *client, | |||
294 | struct iio_dev *indio_dev; | 286 | struct iio_dev *indio_dev; |
295 | int err; | 287 | int err; |
296 | 288 | ||
297 | indio_dev = iio_device_alloc(sizeof(*data)); | 289 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*data)); |
298 | if (indio_dev == NULL) { | 290 | if (indio_dev == NULL) |
299 | err = -ENOMEM; | 291 | return -ENOMEM; |
300 | goto exit; | 292 | |
301 | } | ||
302 | data = iio_priv(indio_dev); | 293 | data = iio_priv(indio_dev); |
303 | i2c_set_clientdata(client, indio_dev); | 294 | i2c_set_clientdata(client, indio_dev); |
304 | data->client = client; | 295 | data->client = client; |
@@ -313,7 +304,7 @@ static int adjd_s311_probe(struct i2c_client *client, | |||
313 | err = iio_triggered_buffer_setup(indio_dev, NULL, | 304 | err = iio_triggered_buffer_setup(indio_dev, NULL, |
314 | adjd_s311_trigger_handler, NULL); | 305 | adjd_s311_trigger_handler, NULL); |
315 | if (err < 0) | 306 | if (err < 0) |
316 | goto exit_free_device; | 307 | return err; |
317 | 308 | ||
318 | err = iio_device_register(indio_dev); | 309 | err = iio_device_register(indio_dev); |
319 | if (err) | 310 | if (err) |
@@ -325,9 +316,6 @@ static int adjd_s311_probe(struct i2c_client *client, | |||
325 | 316 | ||
326 | exit_unreg_buffer: | 317 | exit_unreg_buffer: |
327 | iio_triggered_buffer_cleanup(indio_dev); | 318 | iio_triggered_buffer_cleanup(indio_dev); |
328 | exit_free_device: | ||
329 | iio_device_free(indio_dev); | ||
330 | exit: | ||
331 | return err; | 319 | return err; |
332 | } | 320 | } |
333 | 321 | ||
@@ -339,7 +327,6 @@ static int adjd_s311_remove(struct i2c_client *client) | |||
339 | iio_device_unregister(indio_dev); | 327 | iio_device_unregister(indio_dev); |
340 | iio_triggered_buffer_cleanup(indio_dev); | 328 | iio_triggered_buffer_cleanup(indio_dev); |
341 | kfree(data->buffer); | 329 | kfree(data->buffer); |
342 | iio_device_free(indio_dev); | ||
343 | 330 | ||
344 | return 0; | 331 | return 0; |
345 | } | 332 | } |
diff --git a/drivers/iio/light/apds9300.c b/drivers/iio/light/apds9300.c new file mode 100644 index 000000000000..66a58bda6dc8 --- /dev/null +++ b/drivers/iio/light/apds9300.c | |||
@@ -0,0 +1,512 @@ | |||
1 | /* | ||
2 | * apds9300.c - IIO driver for Avago APDS9300 ambient light sensor | ||
3 | * | ||
4 | * Copyright 2013 Oleksandr Kravchenko <o.v.kravchenko@globallogic.com> | ||
5 | * | ||
6 | * This file is subject to the terms and conditions of version 2 of | ||
7 | * the GNU General Public License. See the file COPYING in the main | ||
8 | * directory of this archive for more details. | ||
9 | */ | ||
10 | |||
11 | #include <linux/module.h> | ||
12 | #include <linux/slab.h> | ||
13 | #include <linux/pm.h> | ||
14 | #include <linux/i2c.h> | ||
15 | #include <linux/err.h> | ||
16 | #include <linux/mutex.h> | ||
17 | #include <linux/interrupt.h> | ||
18 | #include <linux/iio/iio.h> | ||
19 | #include <linux/iio/sysfs.h> | ||
20 | #include <linux/iio/events.h> | ||
21 | |||
22 | #define APDS9300_DRV_NAME "apds9300" | ||
23 | #define APDS9300_IRQ_NAME "apds9300_event" | ||
24 | |||
25 | /* Command register bits */ | ||
26 | #define APDS9300_CMD BIT(7) /* Select command register. Must write as 1 */ | ||
27 | #define APDS9300_WORD BIT(5) /* I2C write/read: if 1 word, if 0 byte */ | ||
28 | #define APDS9300_CLEAR BIT(6) /* Interrupt clear. Clears pending interrupt */ | ||
29 | |||
30 | /* Register set */ | ||
31 | #define APDS9300_CONTROL 0x00 /* Control of basic functions */ | ||
32 | #define APDS9300_THRESHLOWLOW 0x02 /* Low byte of low interrupt threshold */ | ||
33 | #define APDS9300_THRESHHIGHLOW 0x04 /* Low byte of high interrupt threshold */ | ||
34 | #define APDS9300_INTERRUPT 0x06 /* Interrupt control */ | ||
35 | #define APDS9300_DATA0LOW 0x0c /* Low byte of ADC channel 0 */ | ||
36 | #define APDS9300_DATA1LOW 0x0e /* Low byte of ADC channel 1 */ | ||
37 | |||
38 | /* Power on/off value for APDS9300_CONTROL register */ | ||
39 | #define APDS9300_POWER_ON 0x03 | ||
40 | #define APDS9300_POWER_OFF 0x00 | ||
41 | |||
42 | /* Interrupts */ | ||
43 | #define APDS9300_INTR_ENABLE 0x10 | ||
44 | /* Interrupt Persist Function: Any value outside of threshold range */ | ||
45 | #define APDS9300_THRESH_INTR 0x01 | ||
46 | |||
47 | #define APDS9300_THRESH_MAX 0xffff /* Max threshold value */ | ||
48 | |||
49 | struct apds9300_data { | ||
50 | struct i2c_client *client; | ||
51 | struct mutex mutex; | ||
52 | int power_state; | ||
53 | int thresh_low; | ||
54 | int thresh_hi; | ||
55 | int intr_en; | ||
56 | }; | ||
57 | |||
58 | /* Lux calculation */ | ||
59 | |||
60 | /* Calculated values 1000 * (CH1/CH0)^1.4 for CH1/CH0 from 0 to 0.52 */ | ||
61 | static const u16 apds9300_lux_ratio[] = { | ||
62 | 0, 2, 4, 7, 11, 15, 19, 24, 29, 34, 40, 45, 51, 57, 64, 70, 77, 84, 91, | ||
63 | 98, 105, 112, 120, 128, 136, 144, 152, 160, 168, 177, 185, 194, 203, | ||
64 | 212, 221, 230, 239, 249, 258, 268, 277, 287, 297, 307, 317, 327, 337, | ||
65 | 347, 358, 368, 379, 390, 400, | ||
66 | }; | ||
67 | |||
68 | static unsigned long apds9300_calculate_lux(u16 ch0, u16 ch1) | ||
69 | { | ||
70 | unsigned long lux, tmp; | ||
71 | |||
72 | /* avoid division by zero */ | ||
73 | if (ch0 == 0) | ||
74 | return 0; | ||
75 | |||
76 | tmp = DIV_ROUND_UP(ch1 * 100, ch0); | ||
77 | if (tmp <= 52) { | ||
78 | lux = 3150 * ch0 - (unsigned long)DIV_ROUND_UP_ULL(ch0 | ||
79 | * apds9300_lux_ratio[tmp] * 5930ull, 1000); | ||
80 | } else if (tmp <= 65) { | ||
81 | lux = 2290 * ch0 - 2910 * ch1; | ||
82 | } else if (tmp <= 80) { | ||
83 | lux = 1570 * ch0 - 1800 * ch1; | ||
84 | } else if (tmp <= 130) { | ||
85 | lux = 338 * ch0 - 260 * ch1; | ||
86 | } else { | ||
87 | lux = 0; | ||
88 | } | ||
89 | |||
90 | return lux / 100000; | ||
91 | } | ||
92 | |||
93 | static int apds9300_get_adc_val(struct apds9300_data *data, int adc_number) | ||
94 | { | ||
95 | int ret; | ||
96 | u8 flags = APDS9300_CMD | APDS9300_WORD; | ||
97 | |||
98 | if (!data->power_state) | ||
99 | return -EBUSY; | ||
100 | |||
101 | /* Select ADC0 or ADC1 data register */ | ||
102 | flags |= adc_number ? APDS9300_DATA1LOW : APDS9300_DATA0LOW; | ||
103 | |||
104 | ret = i2c_smbus_read_word_data(data->client, flags); | ||
105 | if (ret < 0) | ||
106 | dev_err(&data->client->dev, | ||
107 | "failed to read ADC%d value\n", adc_number); | ||
108 | |||
109 | return ret; | ||
110 | } | ||
111 | |||
112 | static int apds9300_set_thresh_low(struct apds9300_data *data, int value) | ||
113 | { | ||
114 | int ret; | ||
115 | |||
116 | if (!data->power_state) | ||
117 | return -EBUSY; | ||
118 | |||
119 | if (value > APDS9300_THRESH_MAX) | ||
120 | return -EINVAL; | ||
121 | |||
122 | ret = i2c_smbus_write_word_data(data->client, APDS9300_THRESHLOWLOW | ||
123 | | APDS9300_CMD | APDS9300_WORD, value); | ||
124 | if (ret) { | ||
125 | dev_err(&data->client->dev, "failed to set thresh_low\n"); | ||
126 | return ret; | ||
127 | } | ||
128 | data->thresh_low = value; | ||
129 | |||
130 | return 0; | ||
131 | } | ||
132 | |||
133 | static int apds9300_set_thresh_hi(struct apds9300_data *data, int value) | ||
134 | { | ||
135 | int ret; | ||
136 | |||
137 | if (!data->power_state) | ||
138 | return -EBUSY; | ||
139 | |||
140 | if (value > APDS9300_THRESH_MAX) | ||
141 | return -EINVAL; | ||
142 | |||
143 | ret = i2c_smbus_write_word_data(data->client, APDS9300_THRESHHIGHLOW | ||
144 | | APDS9300_CMD | APDS9300_WORD, value); | ||
145 | if (ret) { | ||
146 | dev_err(&data->client->dev, "failed to set thresh_hi\n"); | ||
147 | return ret; | ||
148 | } | ||
149 | data->thresh_hi = value; | ||
150 | |||
151 | return 0; | ||
152 | } | ||
153 | |||
154 | static int apds9300_set_intr_state(struct apds9300_data *data, int state) | ||
155 | { | ||
156 | int ret; | ||
157 | u8 cmd; | ||
158 | |||
159 | if (!data->power_state) | ||
160 | return -EBUSY; | ||
161 | |||
162 | cmd = state ? APDS9300_INTR_ENABLE | APDS9300_THRESH_INTR : 0x00; | ||
163 | ret = i2c_smbus_write_byte_data(data->client, | ||
164 | APDS9300_INTERRUPT | APDS9300_CMD, cmd); | ||
165 | if (ret) { | ||
166 | dev_err(&data->client->dev, | ||
167 | "failed to set interrupt state %d\n", state); | ||
168 | return ret; | ||
169 | } | ||
170 | data->intr_en = state; | ||
171 | |||
172 | return 0; | ||
173 | } | ||
174 | |||
175 | static int apds9300_set_power_state(struct apds9300_data *data, int state) | ||
176 | { | ||
177 | int ret; | ||
178 | u8 cmd; | ||
179 | |||
180 | cmd = state ? APDS9300_POWER_ON : APDS9300_POWER_OFF; | ||
181 | ret = i2c_smbus_write_byte_data(data->client, | ||
182 | APDS9300_CONTROL | APDS9300_CMD, cmd); | ||
183 | if (ret) { | ||
184 | dev_err(&data->client->dev, | ||
185 | "failed to set power state %d\n", state); | ||
186 | return ret; | ||
187 | } | ||
188 | data->power_state = state; | ||
189 | |||
190 | return 0; | ||
191 | } | ||
192 | |||
193 | static void apds9300_clear_intr(struct apds9300_data *data) | ||
194 | { | ||
195 | int ret; | ||
196 | |||
197 | ret = i2c_smbus_write_byte(data->client, APDS9300_CLEAR | APDS9300_CMD); | ||
198 | if (ret < 0) | ||
199 | dev_err(&data->client->dev, "failed to clear interrupt\n"); | ||
200 | } | ||
201 | |||
202 | static int apds9300_chip_init(struct apds9300_data *data) | ||
203 | { | ||
204 | int ret; | ||
205 | |||
206 | /* Need to set power off to ensure that the chip is off */ | ||
207 | ret = apds9300_set_power_state(data, 0); | ||
208 | if (ret < 0) | ||
209 | goto err; | ||
210 | /* | ||
211 | * Probe the chip. To do so we try to power up the device and then to | ||
212 | * read back the 0x03 code | ||
213 | */ | ||
214 | ret = apds9300_set_power_state(data, 1); | ||
215 | if (ret < 0) | ||
216 | goto err; | ||
217 | ret = i2c_smbus_read_byte_data(data->client, | ||
218 | APDS9300_CONTROL | APDS9300_CMD); | ||
219 | if (ret != APDS9300_POWER_ON) { | ||
220 | ret = -ENODEV; | ||
221 | goto err; | ||
222 | } | ||
223 | /* | ||
224 | * Disable interrupt to ensure thai it is doesn't enable | ||
225 | * i.e. after device soft reset | ||
226 | */ | ||
227 | ret = apds9300_set_intr_state(data, 0); | ||
228 | if (ret < 0) | ||
229 | goto err; | ||
230 | |||
231 | return 0; | ||
232 | |||
233 | err: | ||
234 | dev_err(&data->client->dev, "failed to init the chip\n"); | ||
235 | return ret; | ||
236 | } | ||
237 | |||
238 | static int apds9300_read_raw(struct iio_dev *indio_dev, | ||
239 | struct iio_chan_spec const *chan, int *val, int *val2, | ||
240 | long mask) | ||
241 | { | ||
242 | int ch0, ch1, ret = -EINVAL; | ||
243 | struct apds9300_data *data = iio_priv(indio_dev); | ||
244 | |||
245 | mutex_lock(&data->mutex); | ||
246 | switch (chan->type) { | ||
247 | case IIO_LIGHT: | ||
248 | ch0 = apds9300_get_adc_val(data, 0); | ||
249 | if (ch0 < 0) { | ||
250 | ret = ch0; | ||
251 | break; | ||
252 | } | ||
253 | ch1 = apds9300_get_adc_val(data, 1); | ||
254 | if (ch1 < 0) { | ||
255 | ret = ch1; | ||
256 | break; | ||
257 | } | ||
258 | *val = apds9300_calculate_lux(ch0, ch1); | ||
259 | ret = IIO_VAL_INT; | ||
260 | break; | ||
261 | case IIO_INTENSITY: | ||
262 | ret = apds9300_get_adc_val(data, chan->channel); | ||
263 | if (ret < 0) | ||
264 | break; | ||
265 | *val = ret; | ||
266 | ret = IIO_VAL_INT; | ||
267 | break; | ||
268 | default: | ||
269 | break; | ||
270 | } | ||
271 | mutex_unlock(&data->mutex); | ||
272 | |||
273 | return ret; | ||
274 | } | ||
275 | |||
276 | static int apds9300_read_thresh(struct iio_dev *indio_dev, u64 event_code, | ||
277 | int *val) | ||
278 | { | ||
279 | struct apds9300_data *data = iio_priv(indio_dev); | ||
280 | |||
281 | switch (IIO_EVENT_CODE_EXTRACT_DIR(event_code)) { | ||
282 | case IIO_EV_DIR_RISING: | ||
283 | *val = data->thresh_hi; | ||
284 | break; | ||
285 | case IIO_EV_DIR_FALLING: | ||
286 | *val = data->thresh_low; | ||
287 | break; | ||
288 | default: | ||
289 | return -EINVAL; | ||
290 | } | ||
291 | |||
292 | return 0; | ||
293 | } | ||
294 | |||
295 | static int apds9300_write_thresh(struct iio_dev *indio_dev, u64 event_code, | ||
296 | int val) | ||
297 | { | ||
298 | struct apds9300_data *data = iio_priv(indio_dev); | ||
299 | int ret; | ||
300 | |||
301 | mutex_lock(&data->mutex); | ||
302 | if (IIO_EVENT_CODE_EXTRACT_DIR(event_code) == IIO_EV_DIR_RISING) | ||
303 | ret = apds9300_set_thresh_hi(data, val); | ||
304 | else | ||
305 | ret = apds9300_set_thresh_low(data, val); | ||
306 | mutex_unlock(&data->mutex); | ||
307 | |||
308 | return ret; | ||
309 | } | ||
310 | |||
311 | static int apds9300_read_interrupt_config(struct iio_dev *indio_dev, | ||
312 | u64 event_code) | ||
313 | { | ||
314 | struct apds9300_data *data = iio_priv(indio_dev); | ||
315 | |||
316 | return data->intr_en; | ||
317 | } | ||
318 | |||
319 | static int apds9300_write_interrupt_config(struct iio_dev *indio_dev, | ||
320 | u64 event_code, int state) | ||
321 | { | ||
322 | struct apds9300_data *data = iio_priv(indio_dev); | ||
323 | int ret; | ||
324 | |||
325 | mutex_lock(&data->mutex); | ||
326 | ret = apds9300_set_intr_state(data, state); | ||
327 | mutex_unlock(&data->mutex); | ||
328 | |||
329 | return ret; | ||
330 | } | ||
331 | |||
332 | static const struct iio_info apds9300_info_no_irq = { | ||
333 | .driver_module = THIS_MODULE, | ||
334 | .read_raw = apds9300_read_raw, | ||
335 | }; | ||
336 | |||
337 | static const struct iio_info apds9300_info = { | ||
338 | .driver_module = THIS_MODULE, | ||
339 | .read_raw = apds9300_read_raw, | ||
340 | .read_event_value = apds9300_read_thresh, | ||
341 | .write_event_value = apds9300_write_thresh, | ||
342 | .read_event_config = apds9300_read_interrupt_config, | ||
343 | .write_event_config = apds9300_write_interrupt_config, | ||
344 | }; | ||
345 | |||
346 | static const struct iio_chan_spec apds9300_channels[] = { | ||
347 | { | ||
348 | .type = IIO_LIGHT, | ||
349 | .channel = 0, | ||
350 | .indexed = true, | ||
351 | .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED), | ||
352 | }, { | ||
353 | .type = IIO_INTENSITY, | ||
354 | .channel = 0, | ||
355 | .channel2 = IIO_MOD_LIGHT_BOTH, | ||
356 | .indexed = true, | ||
357 | .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), | ||
358 | .event_mask = (IIO_EV_BIT(IIO_EV_TYPE_THRESH, | ||
359 | IIO_EV_DIR_RISING) | | ||
360 | IIO_EV_BIT(IIO_EV_TYPE_THRESH, | ||
361 | IIO_EV_DIR_FALLING)), | ||
362 | }, { | ||
363 | .type = IIO_INTENSITY, | ||
364 | .channel = 1, | ||
365 | .channel2 = IIO_MOD_LIGHT_IR, | ||
366 | .indexed = true, | ||
367 | .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), | ||
368 | }, | ||
369 | }; | ||
370 | |||
371 | static irqreturn_t apds9300_interrupt_handler(int irq, void *private) | ||
372 | { | ||
373 | struct iio_dev *dev_info = private; | ||
374 | struct apds9300_data *data = iio_priv(dev_info); | ||
375 | |||
376 | iio_push_event(dev_info, | ||
377 | IIO_UNMOD_EVENT_CODE(IIO_INTENSITY, 0, | ||
378 | IIO_EV_TYPE_THRESH, | ||
379 | IIO_EV_DIR_EITHER), | ||
380 | iio_get_time_ns()); | ||
381 | |||
382 | apds9300_clear_intr(data); | ||
383 | |||
384 | return IRQ_HANDLED; | ||
385 | } | ||
386 | |||
387 | static int apds9300_probe(struct i2c_client *client, | ||
388 | const struct i2c_device_id *id) | ||
389 | { | ||
390 | struct apds9300_data *data; | ||
391 | struct iio_dev *indio_dev; | ||
392 | int ret; | ||
393 | |||
394 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*data)); | ||
395 | if (!indio_dev) | ||
396 | return -ENOMEM; | ||
397 | |||
398 | data = iio_priv(indio_dev); | ||
399 | i2c_set_clientdata(client, indio_dev); | ||
400 | data->client = client; | ||
401 | |||
402 | ret = apds9300_chip_init(data); | ||
403 | if (ret < 0) | ||
404 | goto err; | ||
405 | |||
406 | mutex_init(&data->mutex); | ||
407 | |||
408 | indio_dev->dev.parent = &client->dev; | ||
409 | indio_dev->channels = apds9300_channels; | ||
410 | indio_dev->num_channels = ARRAY_SIZE(apds9300_channels); | ||
411 | indio_dev->name = APDS9300_DRV_NAME; | ||
412 | indio_dev->modes = INDIO_DIRECT_MODE; | ||
413 | |||
414 | if (client->irq) | ||
415 | indio_dev->info = &apds9300_info; | ||
416 | else | ||
417 | indio_dev->info = &apds9300_info_no_irq; | ||
418 | |||
419 | if (client->irq) { | ||
420 | ret = devm_request_threaded_irq(&client->dev, client->irq, | ||
421 | NULL, apds9300_interrupt_handler, | ||
422 | IRQF_TRIGGER_FALLING | IRQF_ONESHOT, | ||
423 | APDS9300_IRQ_NAME, indio_dev); | ||
424 | if (ret) { | ||
425 | dev_err(&client->dev, "irq request error %d\n", -ret); | ||
426 | goto err; | ||
427 | } | ||
428 | } | ||
429 | |||
430 | ret = iio_device_register(indio_dev); | ||
431 | if (ret < 0) | ||
432 | goto err; | ||
433 | |||
434 | return 0; | ||
435 | |||
436 | err: | ||
437 | /* Ensure that power off in case of error */ | ||
438 | apds9300_set_power_state(data, 0); | ||
439 | return ret; | ||
440 | } | ||
441 | |||
442 | static int apds9300_remove(struct i2c_client *client) | ||
443 | { | ||
444 | struct iio_dev *indio_dev = i2c_get_clientdata(client); | ||
445 | struct apds9300_data *data = iio_priv(indio_dev); | ||
446 | |||
447 | iio_device_unregister(indio_dev); | ||
448 | |||
449 | /* Ensure that power off and interrupts are disabled */ | ||
450 | apds9300_set_intr_state(data, 0); | ||
451 | apds9300_set_power_state(data, 0); | ||
452 | |||
453 | return 0; | ||
454 | } | ||
455 | |||
456 | #ifdef CONFIG_PM_SLEEP | ||
457 | static int apds9300_suspend(struct device *dev) | ||
458 | { | ||
459 | struct iio_dev *indio_dev = i2c_get_clientdata(to_i2c_client(dev)); | ||
460 | struct apds9300_data *data = iio_priv(indio_dev); | ||
461 | int ret; | ||
462 | |||
463 | mutex_lock(&data->mutex); | ||
464 | ret = apds9300_set_power_state(data, 0); | ||
465 | mutex_unlock(&data->mutex); | ||
466 | |||
467 | return ret; | ||
468 | } | ||
469 | |||
470 | static int apds9300_resume(struct device *dev) | ||
471 | { | ||
472 | struct iio_dev *indio_dev = i2c_get_clientdata(to_i2c_client(dev)); | ||
473 | struct apds9300_data *data = iio_priv(indio_dev); | ||
474 | int ret; | ||
475 | |||
476 | mutex_lock(&data->mutex); | ||
477 | ret = apds9300_set_power_state(data, 1); | ||
478 | mutex_unlock(&data->mutex); | ||
479 | |||
480 | return ret; | ||
481 | } | ||
482 | |||
483 | static SIMPLE_DEV_PM_OPS(apds9300_pm_ops, apds9300_suspend, apds9300_resume); | ||
484 | #define APDS9300_PM_OPS (&apds9300_pm_ops) | ||
485 | #else | ||
486 | #define APDS9300_PM_OPS NULL | ||
487 | #endif | ||
488 | |||
489 | static struct i2c_device_id apds9300_id[] = { | ||
490 | { APDS9300_DRV_NAME, 0 }, | ||
491 | { } | ||
492 | }; | ||
493 | |||
494 | MODULE_DEVICE_TABLE(i2c, apds9300_id); | ||
495 | |||
496 | static struct i2c_driver apds9300_driver = { | ||
497 | .driver = { | ||
498 | .name = APDS9300_DRV_NAME, | ||
499 | .owner = THIS_MODULE, | ||
500 | .pm = APDS9300_PM_OPS, | ||
501 | }, | ||
502 | .probe = apds9300_probe, | ||
503 | .remove = apds9300_remove, | ||
504 | .id_table = apds9300_id, | ||
505 | }; | ||
506 | |||
507 | module_i2c_driver(apds9300_driver); | ||
508 | |||
509 | MODULE_AUTHOR("Kravchenko Oleksandr <o.v.kravchenko@globallogic.com>"); | ||
510 | MODULE_AUTHOR("GlobalLogic inc."); | ||
511 | MODULE_DESCRIPTION("APDS9300 ambient light photo sensor driver"); | ||
512 | MODULE_LICENSE("GPL"); | ||
diff --git a/drivers/iio/light/hid-sensor-als.c b/drivers/iio/light/hid-sensor-als.c index cdc2cad0f01b..e59d00c3139c 100644 --- a/drivers/iio/light/hid-sensor-als.c +++ b/drivers/iio/light/hid-sensor-als.c | |||
@@ -30,10 +30,6 @@ | |||
30 | #include <linux/iio/triggered_buffer.h> | 30 | #include <linux/iio/triggered_buffer.h> |
31 | #include "../common/hid-sensors/hid-sensor-trigger.h" | 31 | #include "../common/hid-sensors/hid-sensor-trigger.h" |
32 | 32 | ||
33 | /*Format: HID-SENSOR-usage_id_in_hex*/ | ||
34 | /*Usage ID from spec for Ambiant-Light: 0x200041*/ | ||
35 | #define DRIVER_NAME "HID-SENSOR-200041" | ||
36 | |||
37 | #define CHANNEL_SCAN_INDEX_ILLUM 0 | 33 | #define CHANNEL_SCAN_INDEX_ILLUM 0 |
38 | 34 | ||
39 | struct als_state { | 35 | struct als_state { |
@@ -158,18 +154,10 @@ static int als_write_raw(struct iio_dev *indio_dev, | |||
158 | return ret; | 154 | return ret; |
159 | } | 155 | } |
160 | 156 | ||
161 | static int als_write_raw_get_fmt(struct iio_dev *indio_dev, | ||
162 | struct iio_chan_spec const *chan, | ||
163 | long mask) | ||
164 | { | ||
165 | return IIO_VAL_INT_PLUS_MICRO; | ||
166 | } | ||
167 | |||
168 | static const struct iio_info als_info = { | 157 | static const struct iio_info als_info = { |
169 | .driver_module = THIS_MODULE, | 158 | .driver_module = THIS_MODULE, |
170 | .read_raw = &als_read_raw, | 159 | .read_raw = &als_read_raw, |
171 | .write_raw = &als_write_raw, | 160 | .write_raw = &als_write_raw, |
172 | .write_raw_get_fmt = &als_write_raw_get_fmt, | ||
173 | }; | 161 | }; |
174 | 162 | ||
175 | /* Function to push data to buffer */ | 163 | /* Function to push data to buffer */ |
@@ -253,11 +241,9 @@ static int hid_als_probe(struct platform_device *pdev) | |||
253 | struct hid_sensor_hub_device *hsdev = pdev->dev.platform_data; | 241 | struct hid_sensor_hub_device *hsdev = pdev->dev.platform_data; |
254 | struct iio_chan_spec *channels; | 242 | struct iio_chan_spec *channels; |
255 | 243 | ||
256 | indio_dev = iio_device_alloc(sizeof(struct als_state)); | 244 | indio_dev = devm_iio_device_alloc(&pdev->dev, sizeof(struct als_state)); |
257 | if (indio_dev == NULL) { | 245 | if (!indio_dev) |
258 | ret = -ENOMEM; | 246 | return -ENOMEM; |
259 | goto error_ret; | ||
260 | } | ||
261 | platform_set_drvdata(pdev, indio_dev); | 247 | platform_set_drvdata(pdev, indio_dev); |
262 | 248 | ||
263 | als_state = iio_priv(indio_dev); | 249 | als_state = iio_priv(indio_dev); |
@@ -268,14 +254,13 @@ static int hid_als_probe(struct platform_device *pdev) | |||
268 | &als_state->common_attributes); | 254 | &als_state->common_attributes); |
269 | if (ret) { | 255 | if (ret) { |
270 | dev_err(&pdev->dev, "failed to setup common attributes\n"); | 256 | dev_err(&pdev->dev, "failed to setup common attributes\n"); |
271 | goto error_free_dev; | 257 | return ret; |
272 | } | 258 | } |
273 | 259 | ||
274 | channels = kmemdup(als_channels, sizeof(als_channels), GFP_KERNEL); | 260 | channels = kmemdup(als_channels, sizeof(als_channels), GFP_KERNEL); |
275 | if (!channels) { | 261 | if (!channels) { |
276 | ret = -ENOMEM; | ||
277 | dev_err(&pdev->dev, "failed to duplicate channels\n"); | 262 | dev_err(&pdev->dev, "failed to duplicate channels\n"); |
278 | goto error_free_dev; | 263 | return -ENOMEM; |
279 | } | 264 | } |
280 | 265 | ||
281 | ret = als_parse_report(pdev, hsdev, channels, | 266 | ret = als_parse_report(pdev, hsdev, channels, |
@@ -333,9 +318,6 @@ error_unreg_buffer_funcs: | |||
333 | iio_triggered_buffer_cleanup(indio_dev); | 318 | iio_triggered_buffer_cleanup(indio_dev); |
334 | error_free_dev_mem: | 319 | error_free_dev_mem: |
335 | kfree(indio_dev->channels); | 320 | kfree(indio_dev->channels); |
336 | error_free_dev: | ||
337 | iio_device_free(indio_dev); | ||
338 | error_ret: | ||
339 | return ret; | 321 | return ret; |
340 | } | 322 | } |
341 | 323 | ||
@@ -350,14 +332,23 @@ static int hid_als_remove(struct platform_device *pdev) | |||
350 | hid_sensor_remove_trigger(indio_dev); | 332 | hid_sensor_remove_trigger(indio_dev); |
351 | iio_triggered_buffer_cleanup(indio_dev); | 333 | iio_triggered_buffer_cleanup(indio_dev); |
352 | kfree(indio_dev->channels); | 334 | kfree(indio_dev->channels); |
353 | iio_device_free(indio_dev); | ||
354 | 335 | ||
355 | return 0; | 336 | return 0; |
356 | } | 337 | } |
357 | 338 | ||
339 | static struct platform_device_id hid_als_ids[] = { | ||
340 | { | ||
341 | /* Format: HID-SENSOR-usage_id_in_hex_lowercase */ | ||
342 | .name = "HID-SENSOR-200041", | ||
343 | }, | ||
344 | { /* sentinel */ } | ||
345 | }; | ||
346 | MODULE_DEVICE_TABLE(platform, hid_als_ids); | ||
347 | |||
358 | static struct platform_driver hid_als_platform_driver = { | 348 | static struct platform_driver hid_als_platform_driver = { |
349 | .id_table = hid_als_ids, | ||
359 | .driver = { | 350 | .driver = { |
360 | .name = DRIVER_NAME, | 351 | .name = KBUILD_MODNAME, |
361 | .owner = THIS_MODULE, | 352 | .owner = THIS_MODULE, |
362 | }, | 353 | }, |
363 | .probe = hid_als_probe, | 354 | .probe = hid_als_probe, |
diff --git a/drivers/iio/light/lm3533-als.c b/drivers/iio/light/lm3533-als.c index 5fa31a4ef82a..c1aadc6b865a 100644 --- a/drivers/iio/light/lm3533-als.c +++ b/drivers/iio/light/lm3533-als.c | |||
@@ -847,7 +847,7 @@ static int lm3533_als_probe(struct platform_device *pdev) | |||
847 | return -EINVAL; | 847 | return -EINVAL; |
848 | } | 848 | } |
849 | 849 | ||
850 | indio_dev = iio_device_alloc(sizeof(*als)); | 850 | indio_dev = devm_iio_device_alloc(&pdev->dev, sizeof(*als)); |
851 | if (!indio_dev) | 851 | if (!indio_dev) |
852 | return -ENOMEM; | 852 | return -ENOMEM; |
853 | 853 | ||
@@ -870,7 +870,7 @@ static int lm3533_als_probe(struct platform_device *pdev) | |||
870 | if (als->irq) { | 870 | if (als->irq) { |
871 | ret = lm3533_als_setup_irq(als, indio_dev); | 871 | ret = lm3533_als_setup_irq(als, indio_dev); |
872 | if (ret) | 872 | if (ret) |
873 | goto err_free_dev; | 873 | return ret; |
874 | } | 874 | } |
875 | 875 | ||
876 | ret = lm3533_als_setup(als, pdata); | 876 | ret = lm3533_als_setup(als, pdata); |
@@ -894,8 +894,6 @@ err_disable: | |||
894 | err_free_irq: | 894 | err_free_irq: |
895 | if (als->irq) | 895 | if (als->irq) |
896 | free_irq(als->irq, indio_dev); | 896 | free_irq(als->irq, indio_dev); |
897 | err_free_dev: | ||
898 | iio_device_free(indio_dev); | ||
899 | 897 | ||
900 | return ret; | 898 | return ret; |
901 | } | 899 | } |
@@ -910,7 +908,6 @@ static int lm3533_als_remove(struct platform_device *pdev) | |||
910 | lm3533_als_disable(als); | 908 | lm3533_als_disable(als); |
911 | if (als->irq) | 909 | if (als->irq) |
912 | free_irq(als->irq, indio_dev); | 910 | free_irq(als->irq, indio_dev); |
913 | iio_device_free(indio_dev); | ||
914 | 911 | ||
915 | return 0; | 912 | return 0; |
916 | } | 913 | } |
diff --git a/drivers/iio/light/tsl2563.c b/drivers/iio/light/tsl2563.c index 1f529f36f138..ebb962c5c323 100644 --- a/drivers/iio/light/tsl2563.c +++ b/drivers/iio/light/tsl2563.c | |||
@@ -702,7 +702,7 @@ static int tsl2563_probe(struct i2c_client *client, | |||
702 | int err = 0; | 702 | int err = 0; |
703 | u8 id = 0; | 703 | u8 id = 0; |
704 | 704 | ||
705 | indio_dev = iio_device_alloc(sizeof(*chip)); | 705 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*chip)); |
706 | if (!indio_dev) | 706 | if (!indio_dev) |
707 | return -ENOMEM; | 707 | return -ENOMEM; |
708 | 708 | ||
@@ -714,13 +714,13 @@ static int tsl2563_probe(struct i2c_client *client, | |||
714 | err = tsl2563_detect(chip); | 714 | err = tsl2563_detect(chip); |
715 | if (err) { | 715 | if (err) { |
716 | dev_err(&client->dev, "detect error %d\n", -err); | 716 | dev_err(&client->dev, "detect error %d\n", -err); |
717 | goto fail1; | 717 | return err; |
718 | } | 718 | } |
719 | 719 | ||
720 | err = tsl2563_read_id(chip, &id); | 720 | err = tsl2563_read_id(chip, &id); |
721 | if (err) { | 721 | if (err) { |
722 | dev_err(&client->dev, "read id error %d\n", -err); | 722 | dev_err(&client->dev, "read id error %d\n", -err); |
723 | goto fail1; | 723 | return err; |
724 | } | 724 | } |
725 | 725 | ||
726 | mutex_init(&chip->lock); | 726 | mutex_init(&chip->lock); |
@@ -751,7 +751,7 @@ static int tsl2563_probe(struct i2c_client *client, | |||
751 | indio_dev->info = &tsl2563_info_no_irq; | 751 | indio_dev->info = &tsl2563_info_no_irq; |
752 | 752 | ||
753 | if (client->irq) { | 753 | if (client->irq) { |
754 | err = request_threaded_irq(client->irq, | 754 | err = devm_request_threaded_irq(&client->dev, client->irq, |
755 | NULL, | 755 | NULL, |
756 | &tsl2563_event_handler, | 756 | &tsl2563_event_handler, |
757 | IRQF_TRIGGER_RISING | IRQF_ONESHOT, | 757 | IRQF_TRIGGER_RISING | IRQF_ONESHOT, |
@@ -759,14 +759,14 @@ static int tsl2563_probe(struct i2c_client *client, | |||
759 | indio_dev); | 759 | indio_dev); |
760 | if (err) { | 760 | if (err) { |
761 | dev_err(&client->dev, "irq request error %d\n", -err); | 761 | dev_err(&client->dev, "irq request error %d\n", -err); |
762 | goto fail1; | 762 | return err; |
763 | } | 763 | } |
764 | } | 764 | } |
765 | 765 | ||
766 | err = tsl2563_configure(chip); | 766 | err = tsl2563_configure(chip); |
767 | if (err) { | 767 | if (err) { |
768 | dev_err(&client->dev, "configure error %d\n", -err); | 768 | dev_err(&client->dev, "configure error %d\n", -err); |
769 | goto fail2; | 769 | return err; |
770 | } | 770 | } |
771 | 771 | ||
772 | INIT_DELAYED_WORK(&chip->poweroff_work, tsl2563_poweroff_work); | 772 | INIT_DELAYED_WORK(&chip->poweroff_work, tsl2563_poweroff_work); |
@@ -777,19 +777,14 @@ static int tsl2563_probe(struct i2c_client *client, | |||
777 | err = iio_device_register(indio_dev); | 777 | err = iio_device_register(indio_dev); |
778 | if (err) { | 778 | if (err) { |
779 | dev_err(&client->dev, "iio registration error %d\n", -err); | 779 | dev_err(&client->dev, "iio registration error %d\n", -err); |
780 | goto fail3; | 780 | goto fail; |
781 | } | 781 | } |
782 | 782 | ||
783 | return 0; | 783 | return 0; |
784 | 784 | ||
785 | fail3: | 785 | fail: |
786 | cancel_delayed_work(&chip->poweroff_work); | 786 | cancel_delayed_work(&chip->poweroff_work); |
787 | flush_scheduled_work(); | 787 | flush_scheduled_work(); |
788 | fail2: | ||
789 | if (client->irq) | ||
790 | free_irq(client->irq, indio_dev); | ||
791 | fail1: | ||
792 | iio_device_free(indio_dev); | ||
793 | return err; | 788 | return err; |
794 | } | 789 | } |
795 | 790 | ||
@@ -807,10 +802,6 @@ static int tsl2563_remove(struct i2c_client *client) | |||
807 | chip->intr); | 802 | chip->intr); |
808 | flush_scheduled_work(); | 803 | flush_scheduled_work(); |
809 | tsl2563_set_power(chip, 0); | 804 | tsl2563_set_power(chip, 0); |
810 | if (client->irq) | ||
811 | free_irq(client->irq, indio_dev); | ||
812 | |||
813 | iio_device_free(indio_dev); | ||
814 | 805 | ||
815 | return 0; | 806 | return 0; |
816 | } | 807 | } |
diff --git a/drivers/iio/light/vcnl4000.c b/drivers/iio/light/vcnl4000.c index 1014943d949a..2bb304215b1d 100644 --- a/drivers/iio/light/vcnl4000.c +++ b/drivers/iio/light/vcnl4000.c | |||
@@ -157,7 +157,7 @@ static int vcnl4000_probe(struct i2c_client *client, | |||
157 | struct iio_dev *indio_dev; | 157 | struct iio_dev *indio_dev; |
158 | int ret; | 158 | int ret; |
159 | 159 | ||
160 | indio_dev = iio_device_alloc(sizeof(*data)); | 160 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*data)); |
161 | if (!indio_dev) | 161 | if (!indio_dev) |
162 | return -ENOMEM; | 162 | return -ENOMEM; |
163 | 163 | ||
@@ -167,7 +167,7 @@ static int vcnl4000_probe(struct i2c_client *client, | |||
167 | 167 | ||
168 | ret = i2c_smbus_read_byte_data(data->client, VCNL4000_PROD_REV); | 168 | ret = i2c_smbus_read_byte_data(data->client, VCNL4000_PROD_REV); |
169 | if (ret < 0) | 169 | if (ret < 0) |
170 | goto error_free_dev; | 170 | return ret; |
171 | 171 | ||
172 | dev_info(&client->dev, "VCNL4000 Ambient light/proximity sensor, Prod %02x, Rev: %02x\n", | 172 | dev_info(&client->dev, "VCNL4000 Ambient light/proximity sensor, Prod %02x, Rev: %02x\n", |
173 | ret >> 4, ret & 0xf); | 173 | ret >> 4, ret & 0xf); |
@@ -181,22 +181,14 @@ static int vcnl4000_probe(struct i2c_client *client, | |||
181 | 181 | ||
182 | ret = iio_device_register(indio_dev); | 182 | ret = iio_device_register(indio_dev); |
183 | if (ret < 0) | 183 | if (ret < 0) |
184 | goto error_free_dev; | 184 | return ret; |
185 | 185 | ||
186 | return 0; | 186 | return 0; |
187 | |||
188 | error_free_dev: | ||
189 | iio_device_free(indio_dev); | ||
190 | return ret; | ||
191 | } | 187 | } |
192 | 188 | ||
193 | static int vcnl4000_remove(struct i2c_client *client) | 189 | static int vcnl4000_remove(struct i2c_client *client) |
194 | { | 190 | { |
195 | struct iio_dev *indio_dev = i2c_get_clientdata(client); | 191 | iio_device_unregister(i2c_get_clientdata(client)); |
196 | |||
197 | iio_device_unregister(indio_dev); | ||
198 | iio_device_free(indio_dev); | ||
199 | |||
200 | return 0; | 192 | return 0; |
201 | } | 193 | } |
202 | 194 | ||
diff --git a/drivers/iio/magnetometer/Kconfig b/drivers/iio/magnetometer/Kconfig index c332b0ae4a3b..4fa923f37b97 100644 --- a/drivers/iio/magnetometer/Kconfig +++ b/drivers/iio/magnetometer/Kconfig | |||
@@ -1,6 +1,8 @@ | |||
1 | # | 1 | # |
2 | # Magnetometer sensors | 2 | # Magnetometer sensors |
3 | # | 3 | # |
4 | # When adding new entries keep the list in alphabetical order | ||
5 | |||
4 | menu "Magnetometer sensors" | 6 | menu "Magnetometer sensors" |
5 | 7 | ||
6 | config AK8975 | 8 | config AK8975 |
@@ -36,8 +38,8 @@ config IIO_ST_MAGN_3AXIS | |||
36 | Say yes here to build support for STMicroelectronics magnetometers: | 38 | Say yes here to build support for STMicroelectronics magnetometers: |
37 | LSM303DLHC, LSM303DLM, LIS3MDL. | 39 | LSM303DLHC, LSM303DLM, LIS3MDL. |
38 | 40 | ||
39 | This driver can also be built as a module. If so, will be created | 41 | This driver can also be built as a module. If so, these modules |
40 | these modules: | 42 | will be created: |
41 | - st_magn (core functions for the driver [it is mandatory]); | 43 | - st_magn (core functions for the driver [it is mandatory]); |
42 | - st_magn_i2c (necessary for the I2C devices [optional*]); | 44 | - st_magn_i2c (necessary for the I2C devices [optional*]); |
43 | - st_magn_spi (necessary for the SPI devices [optional*]); | 45 | - st_magn_spi (necessary for the SPI devices [optional*]); |
diff --git a/drivers/iio/magnetometer/Makefile b/drivers/iio/magnetometer/Makefile index 7f328e37fbab..f91b1b68d392 100644 --- a/drivers/iio/magnetometer/Makefile +++ b/drivers/iio/magnetometer/Makefile | |||
@@ -2,6 +2,7 @@ | |||
2 | # Makefile for industrial I/O Magnetometer sensor drivers | 2 | # Makefile for industrial I/O Magnetometer sensor drivers |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | obj-$(CONFIG_AK8975) += ak8975.o | 6 | obj-$(CONFIG_AK8975) += ak8975.o |
6 | obj-$(CONFIG_HID_SENSOR_MAGNETOMETER_3D) += hid-sensor-magn-3d.o | 7 | obj-$(CONFIG_HID_SENSOR_MAGNETOMETER_3D) += hid-sensor-magn-3d.o |
7 | 8 | ||
diff --git a/drivers/iio/magnetometer/hid-sensor-magn-3d.c b/drivers/iio/magnetometer/hid-sensor-magn-3d.c index 99f4e494513b..a98460b15e4b 100644 --- a/drivers/iio/magnetometer/hid-sensor-magn-3d.c +++ b/drivers/iio/magnetometer/hid-sensor-magn-3d.c | |||
@@ -30,10 +30,6 @@ | |||
30 | #include <linux/iio/triggered_buffer.h> | 30 | #include <linux/iio/triggered_buffer.h> |
31 | #include "../common/hid-sensors/hid-sensor-trigger.h" | 31 | #include "../common/hid-sensors/hid-sensor-trigger.h" |
32 | 32 | ||
33 | /*Format: HID-SENSOR-usage_id_in_hex*/ | ||
34 | /*Usage ID from spec for Magnetometer-3D: 0x200083*/ | ||
35 | #define DRIVER_NAME "HID-SENSOR-200083" | ||
36 | |||
37 | enum magn_3d_channel { | 33 | enum magn_3d_channel { |
38 | CHANNEL_SCAN_INDEX_X, | 34 | CHANNEL_SCAN_INDEX_X, |
39 | CHANNEL_SCAN_INDEX_Y, | 35 | CHANNEL_SCAN_INDEX_Y, |
@@ -180,18 +176,10 @@ static int magn_3d_write_raw(struct iio_dev *indio_dev, | |||
180 | return ret; | 176 | return ret; |
181 | } | 177 | } |
182 | 178 | ||
183 | static int magn_3d_write_raw_get_fmt(struct iio_dev *indio_dev, | ||
184 | struct iio_chan_spec const *chan, | ||
185 | long mask) | ||
186 | { | ||
187 | return IIO_VAL_INT_PLUS_MICRO; | ||
188 | } | ||
189 | |||
190 | static const struct iio_info magn_3d_info = { | 179 | static const struct iio_info magn_3d_info = { |
191 | .driver_module = THIS_MODULE, | 180 | .driver_module = THIS_MODULE, |
192 | .read_raw = &magn_3d_read_raw, | 181 | .read_raw = &magn_3d_read_raw, |
193 | .write_raw = &magn_3d_write_raw, | 182 | .write_raw = &magn_3d_write_raw, |
194 | .write_raw_get_fmt = &magn_3d_write_raw_get_fmt, | ||
195 | }; | 183 | }; |
196 | 184 | ||
197 | /* Function to push data to buffer */ | 185 | /* Function to push data to buffer */ |
@@ -287,11 +275,11 @@ static int hid_magn_3d_probe(struct platform_device *pdev) | |||
287 | struct hid_sensor_hub_device *hsdev = pdev->dev.platform_data; | 275 | struct hid_sensor_hub_device *hsdev = pdev->dev.platform_data; |
288 | struct iio_chan_spec *channels; | 276 | struct iio_chan_spec *channels; |
289 | 277 | ||
290 | indio_dev = iio_device_alloc(sizeof(struct magn_3d_state)); | 278 | indio_dev = devm_iio_device_alloc(&pdev->dev, |
291 | if (indio_dev == NULL) { | 279 | sizeof(struct magn_3d_state)); |
292 | ret = -ENOMEM; | 280 | if (indio_dev == NULL) |
293 | goto error_ret; | 281 | return -ENOMEM; |
294 | } | 282 | |
295 | platform_set_drvdata(pdev, indio_dev); | 283 | platform_set_drvdata(pdev, indio_dev); |
296 | 284 | ||
297 | magn_state = iio_priv(indio_dev); | 285 | magn_state = iio_priv(indio_dev); |
@@ -303,15 +291,14 @@ static int hid_magn_3d_probe(struct platform_device *pdev) | |||
303 | &magn_state->common_attributes); | 291 | &magn_state->common_attributes); |
304 | if (ret) { | 292 | if (ret) { |
305 | dev_err(&pdev->dev, "failed to setup common attributes\n"); | 293 | dev_err(&pdev->dev, "failed to setup common attributes\n"); |
306 | goto error_free_dev; | 294 | return ret; |
307 | } | 295 | } |
308 | 296 | ||
309 | channels = kmemdup(magn_3d_channels, sizeof(magn_3d_channels), | 297 | channels = kmemdup(magn_3d_channels, sizeof(magn_3d_channels), |
310 | GFP_KERNEL); | 298 | GFP_KERNEL); |
311 | if (!channels) { | 299 | if (!channels) { |
312 | ret = -ENOMEM; | ||
313 | dev_err(&pdev->dev, "failed to duplicate channels\n"); | 300 | dev_err(&pdev->dev, "failed to duplicate channels\n"); |
314 | goto error_free_dev; | 301 | return -ENOMEM; |
315 | } | 302 | } |
316 | 303 | ||
317 | ret = magn_3d_parse_report(pdev, hsdev, channels, | 304 | ret = magn_3d_parse_report(pdev, hsdev, channels, |
@@ -368,9 +355,6 @@ error_unreg_buffer_funcs: | |||
368 | iio_triggered_buffer_cleanup(indio_dev); | 355 | iio_triggered_buffer_cleanup(indio_dev); |
369 | error_free_dev_mem: | 356 | error_free_dev_mem: |
370 | kfree(indio_dev->channels); | 357 | kfree(indio_dev->channels); |
371 | error_free_dev: | ||
372 | iio_device_free(indio_dev); | ||
373 | error_ret: | ||
374 | return ret; | 358 | return ret; |
375 | } | 359 | } |
376 | 360 | ||
@@ -385,14 +369,23 @@ static int hid_magn_3d_remove(struct platform_device *pdev) | |||
385 | hid_sensor_remove_trigger(indio_dev); | 369 | hid_sensor_remove_trigger(indio_dev); |
386 | iio_triggered_buffer_cleanup(indio_dev); | 370 | iio_triggered_buffer_cleanup(indio_dev); |
387 | kfree(indio_dev->channels); | 371 | kfree(indio_dev->channels); |
388 | iio_device_free(indio_dev); | ||
389 | 372 | ||
390 | return 0; | 373 | return 0; |
391 | } | 374 | } |
392 | 375 | ||
376 | static struct platform_device_id hid_magn_3d_ids[] = { | ||
377 | { | ||
378 | /* Format: HID-SENSOR-usage_id_in_hex_lowercase */ | ||
379 | .name = "HID-SENSOR-200083", | ||
380 | }, | ||
381 | { /* sentinel */ } | ||
382 | }; | ||
383 | MODULE_DEVICE_TABLE(platform, hid_magn_3d_ids); | ||
384 | |||
393 | static struct platform_driver hid_magn_3d_platform_driver = { | 385 | static struct platform_driver hid_magn_3d_platform_driver = { |
386 | .id_table = hid_magn_3d_ids, | ||
394 | .driver = { | 387 | .driver = { |
395 | .name = DRIVER_NAME, | 388 | .name = KBUILD_MODNAME, |
396 | .owner = THIS_MODULE, | 389 | .owner = THIS_MODULE, |
397 | }, | 390 | }, |
398 | .probe = hid_magn_3d_probe, | 391 | .probe = hid_magn_3d_probe, |
diff --git a/drivers/iio/magnetometer/st_magn.h b/drivers/iio/magnetometer/st_magn.h index 7e81d00ef0c3..694e33e0fb72 100644 --- a/drivers/iio/magnetometer/st_magn.h +++ b/drivers/iio/magnetometer/st_magn.h | |||
@@ -18,7 +18,8 @@ | |||
18 | #define LSM303DLM_MAGN_DEV_NAME "lsm303dlm_magn" | 18 | #define LSM303DLM_MAGN_DEV_NAME "lsm303dlm_magn" |
19 | #define LIS3MDL_MAGN_DEV_NAME "lis3mdl" | 19 | #define LIS3MDL_MAGN_DEV_NAME "lis3mdl" |
20 | 20 | ||
21 | int st_magn_common_probe(struct iio_dev *indio_dev); | 21 | int st_magn_common_probe(struct iio_dev *indio_dev, |
22 | struct st_sensors_platform_data *pdata); | ||
22 | void st_magn_common_remove(struct iio_dev *indio_dev); | 23 | void st_magn_common_remove(struct iio_dev *indio_dev); |
23 | 24 | ||
24 | #ifdef CONFIG_IIO_BUFFER | 25 | #ifdef CONFIG_IIO_BUFFER |
diff --git a/drivers/iio/magnetometer/st_magn_core.c b/drivers/iio/magnetometer/st_magn_core.c index ebfe8f11a0c2..e8d2849cc81d 100644 --- a/drivers/iio/magnetometer/st_magn_core.c +++ b/drivers/iio/magnetometer/st_magn_core.c | |||
@@ -345,7 +345,8 @@ static const struct iio_info magn_info = { | |||
345 | .write_raw = &st_magn_write_raw, | 345 | .write_raw = &st_magn_write_raw, |
346 | }; | 346 | }; |
347 | 347 | ||
348 | int st_magn_common_probe(struct iio_dev *indio_dev) | 348 | int st_magn_common_probe(struct iio_dev *indio_dev, |
349 | struct st_sensors_platform_data *pdata) | ||
349 | { | 350 | { |
350 | int err; | 351 | int err; |
351 | struct st_sensor_data *mdata = iio_priv(indio_dev); | 352 | struct st_sensor_data *mdata = iio_priv(indio_dev); |
@@ -367,7 +368,7 @@ int st_magn_common_probe(struct iio_dev *indio_dev) | |||
367 | &mdata->sensor->fs.fs_avl[0]; | 368 | &mdata->sensor->fs.fs_avl[0]; |
368 | mdata->odr = mdata->sensor->odr.odr_avl[0].hz; | 369 | mdata->odr = mdata->sensor->odr.odr_avl[0].hz; |
369 | 370 | ||
370 | err = st_sensors_init_sensor(indio_dev); | 371 | err = st_sensors_init_sensor(indio_dev, pdata); |
371 | if (err < 0) | 372 | if (err < 0) |
372 | goto st_magn_common_probe_error; | 373 | goto st_magn_common_probe_error; |
373 | 374 | ||
@@ -406,7 +407,6 @@ void st_magn_common_remove(struct iio_dev *indio_dev) | |||
406 | st_sensors_deallocate_trigger(indio_dev); | 407 | st_sensors_deallocate_trigger(indio_dev); |
407 | st_magn_deallocate_ring(indio_dev); | 408 | st_magn_deallocate_ring(indio_dev); |
408 | } | 409 | } |
409 | iio_device_free(indio_dev); | ||
410 | } | 410 | } |
411 | EXPORT_SYMBOL(st_magn_common_remove); | 411 | EXPORT_SYMBOL(st_magn_common_remove); |
412 | 412 | ||
diff --git a/drivers/iio/magnetometer/st_magn_i2c.c b/drivers/iio/magnetometer/st_magn_i2c.c index e6adc4a86425..892e0feeb5c1 100644 --- a/drivers/iio/magnetometer/st_magn_i2c.c +++ b/drivers/iio/magnetometer/st_magn_i2c.c | |||
@@ -25,27 +25,20 @@ static int st_magn_i2c_probe(struct i2c_client *client, | |||
25 | struct st_sensor_data *mdata; | 25 | struct st_sensor_data *mdata; |
26 | int err; | 26 | int err; |
27 | 27 | ||
28 | indio_dev = iio_device_alloc(sizeof(*mdata)); | 28 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*mdata)); |
29 | if (indio_dev == NULL) { | 29 | if (!indio_dev) |
30 | err = -ENOMEM; | 30 | return -ENOMEM; |
31 | goto iio_device_alloc_error; | ||
32 | } | ||
33 | 31 | ||
34 | mdata = iio_priv(indio_dev); | 32 | mdata = iio_priv(indio_dev); |
35 | mdata->dev = &client->dev; | 33 | mdata->dev = &client->dev; |
36 | 34 | ||
37 | st_sensors_i2c_configure(indio_dev, client, mdata); | 35 | st_sensors_i2c_configure(indio_dev, client, mdata); |
38 | 36 | ||
39 | err = st_magn_common_probe(indio_dev); | 37 | err = st_magn_common_probe(indio_dev, NULL); |
40 | if (err < 0) | 38 | if (err < 0) |
41 | goto st_magn_common_probe_error; | 39 | return err; |
42 | 40 | ||
43 | return 0; | 41 | return 0; |
44 | |||
45 | st_magn_common_probe_error: | ||
46 | iio_device_free(indio_dev); | ||
47 | iio_device_alloc_error: | ||
48 | return err; | ||
49 | } | 42 | } |
50 | 43 | ||
51 | static int st_magn_i2c_remove(struct i2c_client *client) | 44 | static int st_magn_i2c_remove(struct i2c_client *client) |
diff --git a/drivers/iio/magnetometer/st_magn_spi.c b/drivers/iio/magnetometer/st_magn_spi.c index 51adb797cb7d..a6143ea51dfc 100644 --- a/drivers/iio/magnetometer/st_magn_spi.c +++ b/drivers/iio/magnetometer/st_magn_spi.c | |||
@@ -24,27 +24,20 @@ static int st_magn_spi_probe(struct spi_device *spi) | |||
24 | struct st_sensor_data *mdata; | 24 | struct st_sensor_data *mdata; |
25 | int err; | 25 | int err; |
26 | 26 | ||
27 | indio_dev = iio_device_alloc(sizeof(*mdata)); | 27 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*mdata)); |
28 | if (indio_dev == NULL) { | 28 | if (!indio_dev) |
29 | err = -ENOMEM; | 29 | return -ENOMEM; |
30 | goto iio_device_alloc_error; | ||
31 | } | ||
32 | 30 | ||
33 | mdata = iio_priv(indio_dev); | 31 | mdata = iio_priv(indio_dev); |
34 | mdata->dev = &spi->dev; | 32 | mdata->dev = &spi->dev; |
35 | 33 | ||
36 | st_sensors_spi_configure(indio_dev, spi, mdata); | 34 | st_sensors_spi_configure(indio_dev, spi, mdata); |
37 | 35 | ||
38 | err = st_magn_common_probe(indio_dev); | 36 | err = st_magn_common_probe(indio_dev, NULL); |
39 | if (err < 0) | 37 | if (err < 0) |
40 | goto st_magn_common_probe_error; | 38 | return err; |
41 | 39 | ||
42 | return 0; | 40 | return 0; |
43 | |||
44 | st_magn_common_probe_error: | ||
45 | iio_device_free(indio_dev); | ||
46 | iio_device_alloc_error: | ||
47 | return err; | ||
48 | } | 41 | } |
49 | 42 | ||
50 | static int st_magn_spi_remove(struct spi_device *spi) | 43 | static int st_magn_spi_remove(struct spi_device *spi) |
diff --git a/drivers/iio/pressure/Kconfig b/drivers/iio/pressure/Kconfig index 9427f01e1499..26fdc0bdb99d 100644 --- a/drivers/iio/pressure/Kconfig +++ b/drivers/iio/pressure/Kconfig | |||
@@ -1,21 +1,23 @@ | |||
1 | # | 1 | # |
2 | # Pressure drivers | 2 | # Pressure drivers |
3 | # | 3 | # |
4 | menu "Pressure Sensors" | 4 | # When adding new entries keep the list in alphabetical order |
5 | |||
6 | menu "Pressure sensors" | ||
5 | 7 | ||
6 | config IIO_ST_PRESS | 8 | config IIO_ST_PRESS |
7 | tristate "STMicroelectronics pressures Driver" | 9 | tristate "STMicroelectronics pressure sensor Driver" |
8 | depends on (I2C || SPI_MASTER) && SYSFS | 10 | depends on (I2C || SPI_MASTER) && SYSFS |
9 | select IIO_ST_SENSORS_CORE | 11 | select IIO_ST_SENSORS_CORE |
10 | select IIO_ST_PRESS_I2C if (I2C) | 12 | select IIO_ST_PRESS_I2C if (I2C) |
11 | select IIO_ST_PRESS_SPI if (SPI_MASTER) | 13 | select IIO_ST_PRESS_SPI if (SPI_MASTER) |
12 | select IIO_TRIGGERED_BUFFER if (IIO_BUFFER) | 14 | select IIO_TRIGGERED_BUFFER if (IIO_BUFFER) |
13 | help | 15 | help |
14 | Say yes here to build support for STMicroelectronics pressures: | 16 | Say yes here to build support for STMicroelectronics pressure |
15 | LPS331AP. | 17 | sensors: LPS331AP. |
16 | 18 | ||
17 | This driver can also be built as a module. If so, will be created | 19 | This driver can also be built as a module. If so, these modules |
18 | these modules: | 20 | will be created: |
19 | - st_pressure (core functions for the driver [it is mandatory]); | 21 | - st_pressure (core functions for the driver [it is mandatory]); |
20 | - st_pressure_i2c (necessary for the I2C devices [optional*]); | 22 | - st_pressure_i2c (necessary for the I2C devices [optional*]); |
21 | - st_pressure_spi (necessary for the SPI devices [optional*]); | 23 | - st_pressure_spi (necessary for the SPI devices [optional*]); |
diff --git a/drivers/iio/pressure/Makefile b/drivers/iio/pressure/Makefile index d4bb33e5c846..be71464c2752 100644 --- a/drivers/iio/pressure/Makefile +++ b/drivers/iio/pressure/Makefile | |||
@@ -2,6 +2,7 @@ | |||
2 | # Makefile for industrial I/O pressure drivers | 2 | # Makefile for industrial I/O pressure drivers |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | obj-$(CONFIG_IIO_ST_PRESS) += st_pressure.o | 6 | obj-$(CONFIG_IIO_ST_PRESS) += st_pressure.o |
6 | st_pressure-y := st_pressure_core.o | 7 | st_pressure-y := st_pressure_core.o |
7 | st_pressure-$(CONFIG_IIO_BUFFER) += st_pressure_buffer.o | 8 | st_pressure-$(CONFIG_IIO_BUFFER) += st_pressure_buffer.o |
diff --git a/drivers/iio/pressure/st_pressure.h b/drivers/iio/pressure/st_pressure.h index 414e45ac9b9b..b0b630688da6 100644 --- a/drivers/iio/pressure/st_pressure.h +++ b/drivers/iio/pressure/st_pressure.h | |||
@@ -16,7 +16,16 @@ | |||
16 | 16 | ||
17 | #define LPS331AP_PRESS_DEV_NAME "lps331ap" | 17 | #define LPS331AP_PRESS_DEV_NAME "lps331ap" |
18 | 18 | ||
19 | int st_press_common_probe(struct iio_dev *indio_dev); | 19 | /** |
20 | * struct st_sensors_platform_data - default press platform data | ||
21 | * @drdy_int_pin: default press DRDY is available on INT1 pin. | ||
22 | */ | ||
23 | static const struct st_sensors_platform_data default_press_pdata = { | ||
24 | .drdy_int_pin = 1, | ||
25 | }; | ||
26 | |||
27 | int st_press_common_probe(struct iio_dev *indio_dev, | ||
28 | struct st_sensors_platform_data *pdata); | ||
20 | void st_press_common_remove(struct iio_dev *indio_dev); | 29 | void st_press_common_remove(struct iio_dev *indio_dev); |
21 | 30 | ||
22 | #ifdef CONFIG_IIO_BUFFER | 31 | #ifdef CONFIG_IIO_BUFFER |
diff --git a/drivers/iio/pressure/st_pressure_core.c b/drivers/iio/pressure/st_pressure_core.c index 3ffbc56917b4..ceebd3c27892 100644 --- a/drivers/iio/pressure/st_pressure_core.c +++ b/drivers/iio/pressure/st_pressure_core.c | |||
@@ -31,6 +31,9 @@ | |||
31 | #define ST_PRESS_LSB_PER_MBAR 4096UL | 31 | #define ST_PRESS_LSB_PER_MBAR 4096UL |
32 | #define ST_PRESS_KPASCAL_NANO_SCALE (100000000UL / \ | 32 | #define ST_PRESS_KPASCAL_NANO_SCALE (100000000UL / \ |
33 | ST_PRESS_LSB_PER_MBAR) | 33 | ST_PRESS_LSB_PER_MBAR) |
34 | #define ST_PRESS_LSB_PER_CELSIUS 480UL | ||
35 | #define ST_PRESS_CELSIUS_NANO_SCALE (1000000000UL / \ | ||
36 | ST_PRESS_LSB_PER_CELSIUS) | ||
34 | #define ST_PRESS_NUMBER_DATA_CHANNELS 1 | 37 | #define ST_PRESS_NUMBER_DATA_CHANNELS 1 |
35 | 38 | ||
36 | /* DEFAULT VALUE FOR SENSORS */ | 39 | /* DEFAULT VALUE FOR SENSORS */ |
@@ -53,12 +56,13 @@ | |||
53 | #define ST_PRESS_1_FS_ADDR 0x23 | 56 | #define ST_PRESS_1_FS_ADDR 0x23 |
54 | #define ST_PRESS_1_FS_MASK 0x30 | 57 | #define ST_PRESS_1_FS_MASK 0x30 |
55 | #define ST_PRESS_1_FS_AVL_1260_VAL 0x00 | 58 | #define ST_PRESS_1_FS_AVL_1260_VAL 0x00 |
56 | #define ST_PRESS_1_FS_AVL_TEMP_GAIN 2083000 | ||
57 | #define ST_PRESS_1_FS_AVL_1260_GAIN ST_PRESS_KPASCAL_NANO_SCALE | 59 | #define ST_PRESS_1_FS_AVL_1260_GAIN ST_PRESS_KPASCAL_NANO_SCALE |
60 | #define ST_PRESS_1_FS_AVL_TEMP_GAIN ST_PRESS_CELSIUS_NANO_SCALE | ||
58 | #define ST_PRESS_1_BDU_ADDR 0x20 | 61 | #define ST_PRESS_1_BDU_ADDR 0x20 |
59 | #define ST_PRESS_1_BDU_MASK 0x04 | 62 | #define ST_PRESS_1_BDU_MASK 0x04 |
60 | #define ST_PRESS_1_DRDY_IRQ_ADDR 0x22 | 63 | #define ST_PRESS_1_DRDY_IRQ_ADDR 0x22 |
61 | #define ST_PRESS_1_DRDY_IRQ_MASK 0x04 | 64 | #define ST_PRESS_1_DRDY_IRQ_INT1_MASK 0x04 |
65 | #define ST_PRESS_1_DRDY_IRQ_INT2_MASK 0x20 | ||
62 | #define ST_PRESS_1_MULTIREAD_BIT true | 66 | #define ST_PRESS_1_MULTIREAD_BIT true |
63 | #define ST_PRESS_1_TEMP_OFFSET 42500 | 67 | #define ST_PRESS_1_TEMP_OFFSET 42500 |
64 | 68 | ||
@@ -116,7 +120,8 @@ static const struct st_sensors st_press_sensors[] = { | |||
116 | }, | 120 | }, |
117 | .drdy_irq = { | 121 | .drdy_irq = { |
118 | .addr = ST_PRESS_1_DRDY_IRQ_ADDR, | 122 | .addr = ST_PRESS_1_DRDY_IRQ_ADDR, |
119 | .mask = ST_PRESS_1_DRDY_IRQ_MASK, | 123 | .mask_int1 = ST_PRESS_1_DRDY_IRQ_INT1_MASK, |
124 | .mask_int2 = ST_PRESS_1_DRDY_IRQ_INT2_MASK, | ||
120 | }, | 125 | }, |
121 | .multi_read_bit = ST_PRESS_1_MULTIREAD_BIT, | 126 | .multi_read_bit = ST_PRESS_1_MULTIREAD_BIT, |
122 | .bootime = 2, | 127 | .bootime = 2, |
@@ -202,7 +207,8 @@ static const struct iio_trigger_ops st_press_trigger_ops = { | |||
202 | #define ST_PRESS_TRIGGER_OPS NULL | 207 | #define ST_PRESS_TRIGGER_OPS NULL |
203 | #endif | 208 | #endif |
204 | 209 | ||
205 | int st_press_common_probe(struct iio_dev *indio_dev) | 210 | int st_press_common_probe(struct iio_dev *indio_dev, |
211 | struct st_sensors_platform_data *plat_data) | ||
206 | { | 212 | { |
207 | int err; | 213 | int err; |
208 | struct st_sensor_data *pdata = iio_priv(indio_dev); | 214 | struct st_sensor_data *pdata = iio_priv(indio_dev); |
@@ -224,7 +230,11 @@ int st_press_common_probe(struct iio_dev *indio_dev) | |||
224 | &pdata->sensor->fs.fs_avl[0]; | 230 | &pdata->sensor->fs.fs_avl[0]; |
225 | pdata->odr = pdata->sensor->odr.odr_avl[0].hz; | 231 | pdata->odr = pdata->sensor->odr.odr_avl[0].hz; |
226 | 232 | ||
227 | err = st_sensors_init_sensor(indio_dev); | 233 | if (!plat_data) |
234 | plat_data = | ||
235 | (struct st_sensors_platform_data *)&default_press_pdata; | ||
236 | |||
237 | err = st_sensors_init_sensor(indio_dev, plat_data); | ||
228 | if (err < 0) | 238 | if (err < 0) |
229 | goto st_press_common_probe_error; | 239 | goto st_press_common_probe_error; |
230 | 240 | ||
@@ -265,7 +275,6 @@ void st_press_common_remove(struct iio_dev *indio_dev) | |||
265 | st_sensors_deallocate_trigger(indio_dev); | 275 | st_sensors_deallocate_trigger(indio_dev); |
266 | st_press_deallocate_ring(indio_dev); | 276 | st_press_deallocate_ring(indio_dev); |
267 | } | 277 | } |
268 | iio_device_free(indio_dev); | ||
269 | } | 278 | } |
270 | EXPORT_SYMBOL(st_press_common_remove); | 279 | EXPORT_SYMBOL(st_press_common_remove); |
271 | 280 | ||
diff --git a/drivers/iio/pressure/st_pressure_i2c.c b/drivers/iio/pressure/st_pressure_i2c.c index 7cebcc73bfb0..08aac5e6251d 100644 --- a/drivers/iio/pressure/st_pressure_i2c.c +++ b/drivers/iio/pressure/st_pressure_i2c.c | |||
@@ -25,27 +25,20 @@ static int st_press_i2c_probe(struct i2c_client *client, | |||
25 | struct st_sensor_data *pdata; | 25 | struct st_sensor_data *pdata; |
26 | int err; | 26 | int err; |
27 | 27 | ||
28 | indio_dev = iio_device_alloc(sizeof(*pdata)); | 28 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*pdata)); |
29 | if (indio_dev == NULL) { | 29 | if (!indio_dev) |
30 | err = -ENOMEM; | 30 | return -ENOMEM; |
31 | goto iio_device_alloc_error; | ||
32 | } | ||
33 | 31 | ||
34 | pdata = iio_priv(indio_dev); | 32 | pdata = iio_priv(indio_dev); |
35 | pdata->dev = &client->dev; | 33 | pdata->dev = &client->dev; |
36 | 34 | ||
37 | st_sensors_i2c_configure(indio_dev, client, pdata); | 35 | st_sensors_i2c_configure(indio_dev, client, pdata); |
38 | 36 | ||
39 | err = st_press_common_probe(indio_dev); | 37 | err = st_press_common_probe(indio_dev, client->dev.platform_data); |
40 | if (err < 0) | 38 | if (err < 0) |
41 | goto st_press_common_probe_error; | 39 | return err; |
42 | 40 | ||
43 | return 0; | 41 | return 0; |
44 | |||
45 | st_press_common_probe_error: | ||
46 | iio_device_free(indio_dev); | ||
47 | iio_device_alloc_error: | ||
48 | return err; | ||
49 | } | 42 | } |
50 | 43 | ||
51 | static int st_press_i2c_remove(struct i2c_client *client) | 44 | static int st_press_i2c_remove(struct i2c_client *client) |
diff --git a/drivers/iio/pressure/st_pressure_spi.c b/drivers/iio/pressure/st_pressure_spi.c index 17a14907940a..399a29b6017b 100644 --- a/drivers/iio/pressure/st_pressure_spi.c +++ b/drivers/iio/pressure/st_pressure_spi.c | |||
@@ -24,27 +24,20 @@ static int st_press_spi_probe(struct spi_device *spi) | |||
24 | struct st_sensor_data *pdata; | 24 | struct st_sensor_data *pdata; |
25 | int err; | 25 | int err; |
26 | 26 | ||
27 | indio_dev = iio_device_alloc(sizeof(*pdata)); | 27 | indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*pdata)); |
28 | if (indio_dev == NULL) { | 28 | if (indio_dev == NULL) |
29 | err = -ENOMEM; | 29 | return -ENOMEM; |
30 | goto iio_device_alloc_error; | ||
31 | } | ||
32 | 30 | ||
33 | pdata = iio_priv(indio_dev); | 31 | pdata = iio_priv(indio_dev); |
34 | pdata->dev = &spi->dev; | 32 | pdata->dev = &spi->dev; |
35 | 33 | ||
36 | st_sensors_spi_configure(indio_dev, spi, pdata); | 34 | st_sensors_spi_configure(indio_dev, spi, pdata); |
37 | 35 | ||
38 | err = st_press_common_probe(indio_dev); | 36 | err = st_press_common_probe(indio_dev, spi->dev.platform_data); |
39 | if (err < 0) | 37 | if (err < 0) |
40 | goto st_press_common_probe_error; | 38 | return err; |
41 | 39 | ||
42 | return 0; | 40 | return 0; |
43 | |||
44 | st_press_common_probe_error: | ||
45 | iio_device_free(indio_dev); | ||
46 | iio_device_alloc_error: | ||
47 | return err; | ||
48 | } | 41 | } |
49 | 42 | ||
50 | static int st_press_spi_remove(struct spi_device *spi) | 43 | static int st_press_spi_remove(struct spi_device *spi) |
diff --git a/drivers/iio/temperature/Kconfig b/drivers/iio/temperature/Kconfig new file mode 100644 index 000000000000..372f8fb3085f --- /dev/null +++ b/drivers/iio/temperature/Kconfig | |||
@@ -0,0 +1,16 @@ | |||
1 | # | ||
2 | # Temperature sensor drivers | ||
3 | # | ||
4 | menu "Temperature sensors" | ||
5 | |||
6 | config TMP006 | ||
7 | tristate "TMP006 infrared thermopile sensor" | ||
8 | depends on I2C | ||
9 | help | ||
10 | If you say yes here you get support for the Texas Instruments | ||
11 | TMP006 infrared thermopile sensor. | ||
12 | |||
13 | This driver can also be built as a module. If so, the module will | ||
14 | be called tmp006. | ||
15 | |||
16 | endmenu | ||
diff --git a/drivers/iio/temperature/Makefile b/drivers/iio/temperature/Makefile new file mode 100644 index 000000000000..24d7b602db3e --- /dev/null +++ b/drivers/iio/temperature/Makefile | |||
@@ -0,0 +1,5 @@ | |||
1 | # | ||
2 | # Makefile for industrial I/O temperature drivers | ||
3 | # | ||
4 | |||
5 | obj-$(CONFIG_TMP006) += tmp006.o | ||
diff --git a/drivers/iio/temperature/tmp006.c b/drivers/iio/temperature/tmp006.c new file mode 100644 index 000000000000..64ccde3f1f7a --- /dev/null +++ b/drivers/iio/temperature/tmp006.c | |||
@@ -0,0 +1,291 @@ | |||
1 | /* | ||
2 | * tmp006.c - Support for TI TMP006 IR thermopile sensor | ||
3 | * | ||
4 | * Copyright (c) 2013 Peter Meerwald <pmeerw@pmeerw.net> | ||
5 | * | ||
6 | * This file is subject to the terms and conditions of version 2 of | ||
7 | * the GNU General Public License. See the file COPYING in the main | ||
8 | * directory of this archive for more details. | ||
9 | * | ||
10 | * Driver for the Texas Instruments I2C 16-bit IR thermopile sensor | ||
11 | * | ||
12 | * (7-bit I2C slave address 0x40, changeable via ADR pins) | ||
13 | * | ||
14 | * TODO: data ready irq | ||
15 | */ | ||
16 | |||
17 | #include <linux/err.h> | ||
18 | #include <linux/i2c.h> | ||
19 | #include <linux/delay.h> | ||
20 | #include <linux/module.h> | ||
21 | #include <linux/pm.h> | ||
22 | #include <linux/bitops.h> | ||
23 | |||
24 | #include <linux/iio/iio.h> | ||
25 | #include <linux/iio/sysfs.h> | ||
26 | |||
27 | #define TMP006_VOBJECT 0x00 | ||
28 | #define TMP006_TAMBIENT 0x01 | ||
29 | #define TMP006_CONFIG 0x02 | ||
30 | #define TMP006_MANUFACTURER_ID 0xfe | ||
31 | #define TMP006_DEVICE_ID 0xff | ||
32 | |||
33 | #define TMP006_TAMBIENT_SHIFT 2 | ||
34 | |||
35 | #define TMP006_CONFIG_RESET BIT(15) | ||
36 | #define TMP006_CONFIG_DRDY_EN BIT(8) | ||
37 | #define TMP006_CONFIG_DRDY BIT(7) | ||
38 | |||
39 | #define TMP006_CONFIG_MOD_MASK 0x7000 | ||
40 | |||
41 | #define TMP006_CONFIG_CR_MASK 0x0e00 | ||
42 | #define TMP006_CONFIG_CR_SHIFT 9 | ||
43 | |||
44 | #define MANUFACTURER_MAGIC 0x5449 | ||
45 | #define DEVICE_MAGIC 0x0067 | ||
46 | |||
47 | struct tmp006_data { | ||
48 | struct i2c_client *client; | ||
49 | u16 config; | ||
50 | }; | ||
51 | |||
52 | static int tmp006_read_measurement(struct tmp006_data *data, u8 reg) | ||
53 | { | ||
54 | s32 ret; | ||
55 | int tries = 50; | ||
56 | |||
57 | while (tries-- > 0) { | ||
58 | ret = i2c_smbus_read_word_swapped(data->client, | ||
59 | TMP006_CONFIG); | ||
60 | if (ret < 0) | ||
61 | return ret; | ||
62 | if (ret & TMP006_CONFIG_DRDY) | ||
63 | break; | ||
64 | msleep(100); | ||
65 | } | ||
66 | |||
67 | if (tries < 0) | ||
68 | return -EIO; | ||
69 | |||
70 | return i2c_smbus_read_word_swapped(data->client, reg); | ||
71 | } | ||
72 | |||
73 | static int tmp006_read_raw(struct iio_dev *indio_dev, | ||
74 | struct iio_chan_spec const *channel, int *val, | ||
75 | int *val2, long mask) | ||
76 | { | ||
77 | struct tmp006_data *data = iio_priv(indio_dev); | ||
78 | s32 ret; | ||
79 | |||
80 | switch (mask) { | ||
81 | case IIO_CHAN_INFO_RAW: | ||
82 | if (channel->type == IIO_VOLTAGE) { | ||
83 | /* LSB is 156.25 nV */ | ||
84 | ret = tmp006_read_measurement(data, TMP006_VOBJECT); | ||
85 | if (ret < 0) | ||
86 | return ret; | ||
87 | *val = sign_extend32(ret, 15); | ||
88 | } else if (channel->type == IIO_TEMP) { | ||
89 | /* LSB is 0.03125 degrees Celsius */ | ||
90 | ret = tmp006_read_measurement(data, TMP006_TAMBIENT); | ||
91 | if (ret < 0) | ||
92 | return ret; | ||
93 | *val = sign_extend32(ret, 15) >> TMP006_TAMBIENT_SHIFT; | ||
94 | } else { | ||
95 | break; | ||
96 | } | ||
97 | return IIO_VAL_INT; | ||
98 | case IIO_CHAN_INFO_SCALE: | ||
99 | if (channel->type == IIO_VOLTAGE) { | ||
100 | *val = 0; | ||
101 | *val2 = 156250; | ||
102 | } else if (channel->type == IIO_TEMP) { | ||
103 | *val = 31; | ||
104 | *val2 = 250000; | ||
105 | } else { | ||
106 | break; | ||
107 | } | ||
108 | return IIO_VAL_INT_PLUS_MICRO; | ||
109 | default: | ||
110 | break; | ||
111 | } | ||
112 | |||
113 | return -EINVAL; | ||
114 | } | ||
115 | |||
116 | static const char * const tmp006_freqs[] = { "4", "2", "1", "0.5", "0.25" }; | ||
117 | |||
118 | static ssize_t tmp006_show_freq(struct device *dev, | ||
119 | struct device_attribute *attr, char *buf) | ||
120 | { | ||
121 | struct tmp006_data *data = iio_priv(dev_to_iio_dev(dev)); | ||
122 | int cr = (data->config & TMP006_CONFIG_CR_MASK) | ||
123 | >> TMP006_CONFIG_CR_SHIFT; | ||
124 | return sprintf(buf, "%s\n", tmp006_freqs[cr]); | ||
125 | } | ||
126 | |||
127 | static ssize_t tmp006_store_freq(struct device *dev, | ||
128 | struct device_attribute *attr, | ||
129 | const char *buf, size_t len) | ||
130 | { | ||
131 | struct iio_dev *indio_dev = dev_to_iio_dev(dev); | ||
132 | struct tmp006_data *data = iio_priv(indio_dev); | ||
133 | int i; | ||
134 | bool found = false; | ||
135 | |||
136 | for (i = 0; i < ARRAY_SIZE(tmp006_freqs); i++) | ||
137 | if (sysfs_streq(buf, tmp006_freqs[i])) { | ||
138 | found = true; | ||
139 | break; | ||
140 | } | ||
141 | if (!found) | ||
142 | return -EINVAL; | ||
143 | |||
144 | data->config &= ~TMP006_CONFIG_CR_MASK; | ||
145 | data->config |= i << TMP006_CONFIG_CR_SHIFT; | ||
146 | |||
147 | return i2c_smbus_write_word_swapped(data->client, TMP006_CONFIG, | ||
148 | data->config); | ||
149 | } | ||
150 | |||
151 | static IIO_DEV_ATTR_SAMP_FREQ(S_IRUGO | S_IWUSR, | ||
152 | tmp006_show_freq, tmp006_store_freq); | ||
153 | |||
154 | static IIO_CONST_ATTR(sampling_frequency_available, "4 2 1 0.5 0.25"); | ||
155 | |||
156 | static struct attribute *tmp006_attributes[] = { | ||
157 | &iio_dev_attr_sampling_frequency.dev_attr.attr, | ||
158 | &iio_const_attr_sampling_frequency_available.dev_attr.attr, | ||
159 | NULL | ||
160 | }; | ||
161 | |||
162 | static const struct attribute_group tmp006_attribute_group = { | ||
163 | .attrs = tmp006_attributes, | ||
164 | }; | ||
165 | |||
166 | static const struct iio_chan_spec tmp006_channels[] = { | ||
167 | { | ||
168 | .type = IIO_VOLTAGE, | ||
169 | .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | | ||
170 | BIT(IIO_CHAN_INFO_SCALE), | ||
171 | }, | ||
172 | { | ||
173 | .type = IIO_TEMP, | ||
174 | .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | | ||
175 | BIT(IIO_CHAN_INFO_SCALE), | ||
176 | } | ||
177 | }; | ||
178 | |||
179 | static const struct iio_info tmp006_info = { | ||
180 | .read_raw = tmp006_read_raw, | ||
181 | .attrs = &tmp006_attribute_group, | ||
182 | .driver_module = THIS_MODULE, | ||
183 | }; | ||
184 | |||
185 | static bool tmp006_check_identification(struct i2c_client *client) | ||
186 | { | ||
187 | int mid, did; | ||
188 | |||
189 | mid = i2c_smbus_read_word_swapped(client, TMP006_MANUFACTURER_ID); | ||
190 | if (mid < 0) | ||
191 | return false; | ||
192 | |||
193 | did = i2c_smbus_read_word_swapped(client, TMP006_DEVICE_ID); | ||
194 | if (did < 0) | ||
195 | return false; | ||
196 | |||
197 | return mid == MANUFACTURER_MAGIC && did == DEVICE_MAGIC; | ||
198 | } | ||
199 | |||
200 | static int tmp006_probe(struct i2c_client *client, | ||
201 | const struct i2c_device_id *id) | ||
202 | { | ||
203 | struct iio_dev *indio_dev; | ||
204 | struct tmp006_data *data; | ||
205 | int ret; | ||
206 | |||
207 | if (!i2c_check_functionality(client->adapter, I2C_FUNC_SMBUS_WORD_DATA)) | ||
208 | return -ENODEV; | ||
209 | |||
210 | if (!tmp006_check_identification(client)) { | ||
211 | dev_err(&client->dev, "no TMP006 sensor\n"); | ||
212 | return -ENODEV; | ||
213 | } | ||
214 | |||
215 | indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*data)); | ||
216 | if (!indio_dev) | ||
217 | return -ENOMEM; | ||
218 | |||
219 | data = iio_priv(indio_dev); | ||
220 | i2c_set_clientdata(client, indio_dev); | ||
221 | data->client = client; | ||
222 | |||
223 | indio_dev->dev.parent = &client->dev; | ||
224 | indio_dev->name = dev_name(&client->dev); | ||
225 | indio_dev->modes = INDIO_DIRECT_MODE; | ||
226 | indio_dev->info = &tmp006_info; | ||
227 | |||
228 | indio_dev->channels = tmp006_channels; | ||
229 | indio_dev->num_channels = ARRAY_SIZE(tmp006_channels); | ||
230 | |||
231 | ret = i2c_smbus_read_word_swapped(data->client, TMP006_CONFIG); | ||
232 | if (ret < 0) | ||
233 | return ret; | ||
234 | data->config = ret; | ||
235 | |||
236 | return iio_device_register(indio_dev); | ||
237 | } | ||
238 | |||
239 | static int tmp006_powerdown(struct tmp006_data *data) | ||
240 | { | ||
241 | return i2c_smbus_write_word_swapped(data->client, TMP006_CONFIG, | ||
242 | data->config & ~TMP006_CONFIG_MOD_MASK); | ||
243 | } | ||
244 | |||
245 | static int tmp006_remove(struct i2c_client *client) | ||
246 | { | ||
247 | struct iio_dev *indio_dev = i2c_get_clientdata(client); | ||
248 | |||
249 | iio_device_unregister(indio_dev); | ||
250 | tmp006_powerdown(iio_priv(indio_dev)); | ||
251 | |||
252 | return 0; | ||
253 | } | ||
254 | |||
255 | #ifdef CONFIG_PM_SLEEP | ||
256 | static int tmp006_suspend(struct device *dev) | ||
257 | { | ||
258 | return tmp006_powerdown(iio_priv(dev_to_iio_dev(dev))); | ||
259 | } | ||
260 | |||
261 | static int tmp006_resume(struct device *dev) | ||
262 | { | ||
263 | struct tmp006_data *data = iio_priv(dev_to_iio_dev(dev)); | ||
264 | return i2c_smbus_write_word_swapped(data->client, TMP006_CONFIG, | ||
265 | data->config | TMP006_CONFIG_MOD_MASK); | ||
266 | } | ||
267 | #endif | ||
268 | |||
269 | static SIMPLE_DEV_PM_OPS(tmp006_pm_ops, tmp006_suspend, tmp006_resume); | ||
270 | |||
271 | static const struct i2c_device_id tmp006_id[] = { | ||
272 | { "tmp006", 0 }, | ||
273 | { } | ||
274 | }; | ||
275 | MODULE_DEVICE_TABLE(i2c, tmp006_id); | ||
276 | |||
277 | static struct i2c_driver tmp006_driver = { | ||
278 | .driver = { | ||
279 | .name = "tmp006", | ||
280 | .pm = &tmp006_pm_ops, | ||
281 | .owner = THIS_MODULE, | ||
282 | }, | ||
283 | .probe = tmp006_probe, | ||
284 | .remove = tmp006_remove, | ||
285 | .id_table = tmp006_id, | ||
286 | }; | ||
287 | module_i2c_driver(tmp006_driver); | ||
288 | |||
289 | MODULE_AUTHOR("Peter Meerwald <pmeerw@pmeerw.net>"); | ||
290 | MODULE_DESCRIPTION("TI TMP006 IR thermopile sensor driver"); | ||
291 | MODULE_LICENSE("GPL"); | ||
diff --git a/drivers/iio/trigger/Kconfig b/drivers/iio/trigger/Kconfig index 360fd508b088..79996123a71b 100644 --- a/drivers/iio/trigger/Kconfig +++ b/drivers/iio/trigger/Kconfig | |||
@@ -1,6 +1,8 @@ | |||
1 | # | 1 | # |
2 | # Industrial I/O standalone triggers | 2 | # Industrial I/O standalone triggers |
3 | # | 3 | # |
4 | # When adding new entries keep the list in alphabetical order | ||
5 | |||
4 | menu "Triggers - standalone" | 6 | menu "Triggers - standalone" |
5 | 7 | ||
6 | config IIO_INTERRUPT_TRIGGER | 8 | config IIO_INTERRUPT_TRIGGER |
@@ -17,7 +19,7 @@ config IIO_SYSFS_TRIGGER | |||
17 | depends on SYSFS | 19 | depends on SYSFS |
18 | select IRQ_WORK | 20 | select IRQ_WORK |
19 | help | 21 | help |
20 | Provides support for using SYSFS entry as IIO triggers. | 22 | Provides support for using SYSFS entries as IIO triggers. |
21 | If unsure, say N (but it's safe to say "Y"). | 23 | If unsure, say N (but it's safe to say "Y"). |
22 | 24 | ||
23 | To compile this driver as a module, choose M here: the | 25 | To compile this driver as a module, choose M here: the |
diff --git a/drivers/iio/trigger/Makefile b/drivers/iio/trigger/Makefile index ce319a51b6af..0694daecaf22 100644 --- a/drivers/iio/trigger/Makefile +++ b/drivers/iio/trigger/Makefile | |||
@@ -2,5 +2,6 @@ | |||
2 | # Makefile for triggers not associated with iio-devices | 2 | # Makefile for triggers not associated with iio-devices |
3 | # | 3 | # |
4 | 4 | ||
5 | # When adding new entries keep the list in alphabetical order | ||
5 | obj-$(CONFIG_IIO_INTERRUPT_TRIGGER) += iio-trig-interrupt.o | 6 | obj-$(CONFIG_IIO_INTERRUPT_TRIGGER) += iio-trig-interrupt.o |
6 | obj-$(CONFIG_IIO_SYSFS_TRIGGER) += iio-trig-sysfs.o | 7 | obj-$(CONFIG_IIO_SYSFS_TRIGGER) += iio-trig-sysfs.o |