diff options
author | Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com> | 2014-04-18 19:22:00 -0400 |
---|---|---|
committer | Jonathan Cameron <jic23@kernel.org> | 2014-05-05 05:59:49 -0400 |
commit | 56ff6be608659ac06d4e3cc5827476efa29d610f (patch) | |
tree | 8d08e07b518db810f8f6bee492ba7dba08683b84 /drivers/iio | |
parent | a269b9a0a27675c34c62c4e20c4ffb62054cd51a (diff) |
iio: hid-sensors: Add API to power on/off
Added an API to allow client drivers to turn ON and OFF sensors for
quick read. Added data_read as counting varaible instead of boolean,
so that sensor is powered off only when last user released it.
Signed-off-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
Diffstat (limited to 'drivers/iio')
-rw-r--r-- | drivers/iio/accel/hid-sensor-accel-3d.c | 7 | ||||
-rw-r--r-- | drivers/iio/common/hid-sensors/hid-sensor-trigger.c | 17 | ||||
-rw-r--r-- | drivers/iio/common/hid-sensors/hid-sensor-trigger.h | 1 | ||||
-rw-r--r-- | drivers/iio/gyro/hid-sensor-gyro-3d.c | 7 | ||||
-rw-r--r-- | drivers/iio/light/hid-sensor-als.c | 7 | ||||
-rw-r--r-- | drivers/iio/light/hid-sensor-prox.c | 7 | ||||
-rw-r--r-- | drivers/iio/magnetometer/hid-sensor-magn-3d.c | 7 | ||||
-rw-r--r-- | drivers/iio/orientation/hid-sensor-incl-3d.c | 7 | ||||
-rw-r--r-- | drivers/iio/orientation/hid-sensor-rotation.c | 8 | ||||
-rw-r--r-- | drivers/iio/pressure/hid-sensor-press.c | 7 |
10 files changed, 38 insertions, 37 deletions
diff --git a/drivers/iio/accel/hid-sensor-accel-3d.c b/drivers/iio/accel/hid-sensor-accel-3d.c index ca50a91752d8..cf61c87a47e9 100644 --- a/drivers/iio/accel/hid-sensor-accel-3d.c +++ b/drivers/iio/accel/hid-sensor-accel-3d.c | |||
@@ -201,9 +201,8 @@ static int accel_3d_proc_event(struct hid_sensor_hub_device *hsdev, | |||
201 | struct iio_dev *indio_dev = platform_get_drvdata(priv); | 201 | struct iio_dev *indio_dev = platform_get_drvdata(priv); |
202 | struct accel_3d_state *accel_state = iio_priv(indio_dev); | 202 | struct accel_3d_state *accel_state = iio_priv(indio_dev); |
203 | 203 | ||
204 | dev_dbg(&indio_dev->dev, "accel_3d_proc_event [%d]\n", | 204 | dev_dbg(&indio_dev->dev, "accel_3d_proc_event\n"); |
205 | accel_state->common_attributes.data_ready); | 205 | if (atomic_read(&accel_state->common_attributes.data_ready)) |
206 | if (accel_state->common_attributes.data_ready) | ||
207 | hid_sensor_push_data(indio_dev, | 206 | hid_sensor_push_data(indio_dev, |
208 | accel_state->accel_val, | 207 | accel_state->accel_val, |
209 | sizeof(accel_state->accel_val)); | 208 | sizeof(accel_state->accel_val)); |
@@ -342,7 +341,7 @@ static int hid_accel_3d_probe(struct platform_device *pdev) | |||
342 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); | 341 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); |
343 | goto error_free_dev_mem; | 342 | goto error_free_dev_mem; |
344 | } | 343 | } |
345 | accel_state->common_attributes.data_ready = false; | 344 | atomic_set(&accel_state->common_attributes.data_ready, 0); |
346 | ret = hid_sensor_setup_trigger(indio_dev, name, | 345 | ret = hid_sensor_setup_trigger(indio_dev, name, |
347 | &accel_state->common_attributes); | 346 | &accel_state->common_attributes); |
348 | if (ret < 0) { | 347 | if (ret < 0) { |
diff --git a/drivers/iio/common/hid-sensors/hid-sensor-trigger.c b/drivers/iio/common/hid-sensors/hid-sensor-trigger.c index dbefbdaf7cd1..73282cee0c81 100644 --- a/drivers/iio/common/hid-sensors/hid-sensor-trigger.c +++ b/drivers/iio/common/hid-sensors/hid-sensor-trigger.c | |||
@@ -28,16 +28,17 @@ | |||
28 | #include <linux/iio/sysfs.h> | 28 | #include <linux/iio/sysfs.h> |
29 | #include "hid-sensor-trigger.h" | 29 | #include "hid-sensor-trigger.h" |
30 | 30 | ||
31 | static int hid_sensor_data_rdy_trigger_set_state(struct iio_trigger *trig, | 31 | int hid_sensor_power_state(struct hid_sensor_common *st, bool state) |
32 | bool state) | ||
33 | { | 32 | { |
34 | struct hid_sensor_common *st = iio_trigger_get_drvdata(trig); | ||
35 | int state_val; | 33 | int state_val; |
36 | int report_val; | 34 | int report_val; |
37 | 35 | ||
38 | if (state) { | 36 | if (state) { |
39 | if (sensor_hub_device_open(st->hsdev)) | 37 | if (sensor_hub_device_open(st->hsdev)) |
40 | return -EIO; | 38 | return -EIO; |
39 | |||
40 | atomic_inc(&st->data_ready); | ||
41 | |||
41 | state_val = hid_sensor_get_usage_index(st->hsdev, | 42 | state_val = hid_sensor_get_usage_index(st->hsdev, |
42 | st->power_state.report_id, | 43 | st->power_state.report_id, |
43 | st->power_state.index, | 44 | st->power_state.index, |
@@ -47,6 +48,8 @@ static int hid_sensor_data_rdy_trigger_set_state(struct iio_trigger *trig, | |||
47 | st->report_state.index, | 48 | st->report_state.index, |
48 | HID_USAGE_SENSOR_PROP_REPORTING_STATE_ALL_EVENTS_ENUM); | 49 | HID_USAGE_SENSOR_PROP_REPORTING_STATE_ALL_EVENTS_ENUM); |
49 | } else { | 50 | } else { |
51 | if (!atomic_dec_and_test(&st->data_ready)) | ||
52 | return 0; | ||
50 | sensor_hub_device_close(st->hsdev); | 53 | sensor_hub_device_close(st->hsdev); |
51 | state_val = hid_sensor_get_usage_index(st->hsdev, | 54 | state_val = hid_sensor_get_usage_index(st->hsdev, |
52 | st->power_state.report_id, | 55 | st->power_state.report_id, |
@@ -57,7 +60,6 @@ static int hid_sensor_data_rdy_trigger_set_state(struct iio_trigger *trig, | |||
57 | st->report_state.index, | 60 | st->report_state.index, |
58 | HID_USAGE_SENSOR_PROP_REPORTING_STATE_NO_EVENTS_ENUM); | 61 | HID_USAGE_SENSOR_PROP_REPORTING_STATE_NO_EVENTS_ENUM); |
59 | } | 62 | } |
60 | st->data_ready = state; | ||
61 | 63 | ||
62 | if (state_val >= 0) { | 64 | if (state_val >= 0) { |
63 | state_val += st->power_state.logical_minimum; | 65 | state_val += st->power_state.logical_minimum; |
@@ -75,6 +77,13 @@ static int hid_sensor_data_rdy_trigger_set_state(struct iio_trigger *trig, | |||
75 | 77 | ||
76 | return 0; | 78 | return 0; |
77 | } | 79 | } |
80 | EXPORT_SYMBOL(hid_sensor_power_state); | ||
81 | |||
82 | static int hid_sensor_data_rdy_trigger_set_state(struct iio_trigger *trig, | ||
83 | bool state) | ||
84 | { | ||
85 | return hid_sensor_power_state(iio_trigger_get_drvdata(trig), state); | ||
86 | } | ||
78 | 87 | ||
79 | void hid_sensor_remove_trigger(struct hid_sensor_common *attrb) | 88 | void hid_sensor_remove_trigger(struct hid_sensor_common *attrb) |
80 | { | 89 | { |
diff --git a/drivers/iio/common/hid-sensors/hid-sensor-trigger.h b/drivers/iio/common/hid-sensors/hid-sensor-trigger.h index ca02f7811aa8..0f8e78c249d3 100644 --- a/drivers/iio/common/hid-sensors/hid-sensor-trigger.h +++ b/drivers/iio/common/hid-sensors/hid-sensor-trigger.h | |||
@@ -22,5 +22,6 @@ | |||
22 | int hid_sensor_setup_trigger(struct iio_dev *indio_dev, const char *name, | 22 | int hid_sensor_setup_trigger(struct iio_dev *indio_dev, const char *name, |
23 | struct hid_sensor_common *attrb); | 23 | struct hid_sensor_common *attrb); |
24 | void hid_sensor_remove_trigger(struct hid_sensor_common *attrb); | 24 | void hid_sensor_remove_trigger(struct hid_sensor_common *attrb); |
25 | int hid_sensor_power_state(struct hid_sensor_common *st, bool state); | ||
25 | 26 | ||
26 | #endif | 27 | #endif |
diff --git a/drivers/iio/gyro/hid-sensor-gyro-3d.c b/drivers/iio/gyro/hid-sensor-gyro-3d.c index 53ac06040fbe..392c30b8cd74 100644 --- a/drivers/iio/gyro/hid-sensor-gyro-3d.c +++ b/drivers/iio/gyro/hid-sensor-gyro-3d.c | |||
@@ -201,9 +201,8 @@ static int gyro_3d_proc_event(struct hid_sensor_hub_device *hsdev, | |||
201 | struct iio_dev *indio_dev = platform_get_drvdata(priv); | 201 | struct iio_dev *indio_dev = platform_get_drvdata(priv); |
202 | struct gyro_3d_state *gyro_state = iio_priv(indio_dev); | 202 | struct gyro_3d_state *gyro_state = iio_priv(indio_dev); |
203 | 203 | ||
204 | dev_dbg(&indio_dev->dev, "gyro_3d_proc_event [%d]\n", | 204 | dev_dbg(&indio_dev->dev, "gyro_3d_proc_event\n"); |
205 | gyro_state->common_attributes.data_ready); | 205 | if (atomic_read(&gyro_state->common_attributes.data_ready)) |
206 | if (gyro_state->common_attributes.data_ready) | ||
207 | hid_sensor_push_data(indio_dev, | 206 | hid_sensor_push_data(indio_dev, |
208 | gyro_state->gyro_val, | 207 | gyro_state->gyro_val, |
209 | sizeof(gyro_state->gyro_val)); | 208 | sizeof(gyro_state->gyro_val)); |
@@ -339,7 +338,7 @@ static int hid_gyro_3d_probe(struct platform_device *pdev) | |||
339 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); | 338 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); |
340 | goto error_free_dev_mem; | 339 | goto error_free_dev_mem; |
341 | } | 340 | } |
342 | gyro_state->common_attributes.data_ready = false; | 341 | atomic_set(&gyro_state->common_attributes.data_ready, 0); |
343 | ret = hid_sensor_setup_trigger(indio_dev, name, | 342 | ret = hid_sensor_setup_trigger(indio_dev, name, |
344 | &gyro_state->common_attributes); | 343 | &gyro_state->common_attributes); |
345 | if (ret < 0) { | 344 | if (ret < 0) { |
diff --git a/drivers/iio/light/hid-sensor-als.c b/drivers/iio/light/hid-sensor-als.c index 39b50be9d456..e124b395f320 100644 --- a/drivers/iio/light/hid-sensor-als.c +++ b/drivers/iio/light/hid-sensor-als.c | |||
@@ -180,9 +180,8 @@ static int als_proc_event(struct hid_sensor_hub_device *hsdev, | |||
180 | struct iio_dev *indio_dev = platform_get_drvdata(priv); | 180 | struct iio_dev *indio_dev = platform_get_drvdata(priv); |
181 | struct als_state *als_state = iio_priv(indio_dev); | 181 | struct als_state *als_state = iio_priv(indio_dev); |
182 | 182 | ||
183 | dev_dbg(&indio_dev->dev, "als_proc_event [%d]\n", | 183 | dev_dbg(&indio_dev->dev, "als_proc_event\n"); |
184 | als_state->common_attributes.data_ready); | 184 | if (atomic_read(&als_state->common_attributes.data_ready)) |
185 | if (als_state->common_attributes.data_ready) | ||
186 | hid_sensor_push_data(indio_dev, | 185 | hid_sensor_push_data(indio_dev, |
187 | &als_state->illum, | 186 | &als_state->illum, |
188 | sizeof(als_state->illum)); | 187 | sizeof(als_state->illum)); |
@@ -305,7 +304,7 @@ static int hid_als_probe(struct platform_device *pdev) | |||
305 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); | 304 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); |
306 | goto error_free_dev_mem; | 305 | goto error_free_dev_mem; |
307 | } | 306 | } |
308 | als_state->common_attributes.data_ready = false; | 307 | atomic_set(&als_state->common_attributes.data_ready, 0); |
309 | ret = hid_sensor_setup_trigger(indio_dev, name, | 308 | ret = hid_sensor_setup_trigger(indio_dev, name, |
310 | &als_state->common_attributes); | 309 | &als_state->common_attributes); |
311 | if (ret < 0) { | 310 | if (ret < 0) { |
diff --git a/drivers/iio/light/hid-sensor-prox.c b/drivers/iio/light/hid-sensor-prox.c index 1894ab196f97..07e98ec8e9f1 100644 --- a/drivers/iio/light/hid-sensor-prox.c +++ b/drivers/iio/light/hid-sensor-prox.c | |||
@@ -176,9 +176,8 @@ static int prox_proc_event(struct hid_sensor_hub_device *hsdev, | |||
176 | struct iio_dev *indio_dev = platform_get_drvdata(priv); | 176 | struct iio_dev *indio_dev = platform_get_drvdata(priv); |
177 | struct prox_state *prox_state = iio_priv(indio_dev); | 177 | struct prox_state *prox_state = iio_priv(indio_dev); |
178 | 178 | ||
179 | dev_dbg(&indio_dev->dev, "prox_proc_event [%d]\n", | 179 | dev_dbg(&indio_dev->dev, "prox_proc_event\n"); |
180 | prox_state->common_attributes.data_ready); | 180 | if (atomic_read(&prox_state->common_attributes.data_ready)) |
181 | if (prox_state->common_attributes.data_ready) | ||
182 | hid_sensor_push_data(indio_dev, | 181 | hid_sensor_push_data(indio_dev, |
183 | &prox_state->human_presence, | 182 | &prox_state->human_presence, |
184 | sizeof(prox_state->human_presence)); | 183 | sizeof(prox_state->human_presence)); |
@@ -297,7 +296,7 @@ static int hid_prox_probe(struct platform_device *pdev) | |||
297 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); | 296 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); |
298 | goto error_free_dev_mem; | 297 | goto error_free_dev_mem; |
299 | } | 298 | } |
300 | prox_state->common_attributes.data_ready = false; | 299 | atomic_set(&prox_state->common_attributes.data_ready, 0); |
301 | ret = hid_sensor_setup_trigger(indio_dev, name, | 300 | ret = hid_sensor_setup_trigger(indio_dev, name, |
302 | &prox_state->common_attributes); | 301 | &prox_state->common_attributes); |
303 | if (ret) { | 302 | if (ret) { |
diff --git a/drivers/iio/magnetometer/hid-sensor-magn-3d.c b/drivers/iio/magnetometer/hid-sensor-magn-3d.c index 131ced0dcb1c..54eea6a17061 100644 --- a/drivers/iio/magnetometer/hid-sensor-magn-3d.c +++ b/drivers/iio/magnetometer/hid-sensor-magn-3d.c | |||
@@ -202,9 +202,8 @@ static int magn_3d_proc_event(struct hid_sensor_hub_device *hsdev, | |||
202 | struct iio_dev *indio_dev = platform_get_drvdata(priv); | 202 | struct iio_dev *indio_dev = platform_get_drvdata(priv); |
203 | struct magn_3d_state *magn_state = iio_priv(indio_dev); | 203 | struct magn_3d_state *magn_state = iio_priv(indio_dev); |
204 | 204 | ||
205 | dev_dbg(&indio_dev->dev, "magn_3d_proc_event [%d]\n", | 205 | dev_dbg(&indio_dev->dev, "magn_3d_proc_event\n"); |
206 | magn_state->common_attributes.data_ready); | 206 | if (atomic_read(&magn_state->common_attributes.data_ready)) |
207 | if (magn_state->common_attributes.data_ready) | ||
208 | hid_sensor_push_data(indio_dev, | 207 | hid_sensor_push_data(indio_dev, |
209 | magn_state->magn_val, | 208 | magn_state->magn_val, |
210 | sizeof(magn_state->magn_val)); | 209 | sizeof(magn_state->magn_val)); |
@@ -343,7 +342,7 @@ static int hid_magn_3d_probe(struct platform_device *pdev) | |||
343 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); | 342 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); |
344 | goto error_free_dev_mem; | 343 | goto error_free_dev_mem; |
345 | } | 344 | } |
346 | magn_state->common_attributes.data_ready = false; | 345 | atomic_set(&magn_state->common_attributes.data_ready, 0); |
347 | ret = hid_sensor_setup_trigger(indio_dev, name, | 346 | ret = hid_sensor_setup_trigger(indio_dev, name, |
348 | &magn_state->common_attributes); | 347 | &magn_state->common_attributes); |
349 | if (ret < 0) { | 348 | if (ret < 0) { |
diff --git a/drivers/iio/orientation/hid-sensor-incl-3d.c b/drivers/iio/orientation/hid-sensor-incl-3d.c index f0c465cc192a..bf11678dd04e 100644 --- a/drivers/iio/orientation/hid-sensor-incl-3d.c +++ b/drivers/iio/orientation/hid-sensor-incl-3d.c | |||
@@ -200,9 +200,8 @@ static int incl_3d_proc_event(struct hid_sensor_hub_device *hsdev, | |||
200 | struct iio_dev *indio_dev = platform_get_drvdata(priv); | 200 | struct iio_dev *indio_dev = platform_get_drvdata(priv); |
201 | struct incl_3d_state *incl_state = iio_priv(indio_dev); | 201 | struct incl_3d_state *incl_state = iio_priv(indio_dev); |
202 | 202 | ||
203 | dev_dbg(&indio_dev->dev, "incl_3d_proc_event [%d]\n", | 203 | dev_dbg(&indio_dev->dev, "incl_3d_proc_event\n"); |
204 | incl_state->common_attributes.data_ready); | 204 | if (atomic_read(&incl_state->common_attributes.data_ready)) |
205 | if (incl_state->common_attributes.data_ready) | ||
206 | hid_sensor_push_data(indio_dev, | 205 | hid_sensor_push_data(indio_dev, |
207 | (u8 *)incl_state->incl_val, | 206 | (u8 *)incl_state->incl_val, |
208 | sizeof(incl_state->incl_val)); | 207 | sizeof(incl_state->incl_val)); |
@@ -358,7 +357,7 @@ static int hid_incl_3d_probe(struct platform_device *pdev) | |||
358 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); | 357 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); |
359 | goto error_free_dev_mem; | 358 | goto error_free_dev_mem; |
360 | } | 359 | } |
361 | incl_state->common_attributes.data_ready = false; | 360 | atomic_set(&incl_state->common_attributes.data_ready, 0); |
362 | ret = hid_sensor_setup_trigger(indio_dev, name, | 361 | ret = hid_sensor_setup_trigger(indio_dev, name, |
363 | &incl_state->common_attributes); | 362 | &incl_state->common_attributes); |
364 | if (ret) { | 363 | if (ret) { |
diff --git a/drivers/iio/orientation/hid-sensor-rotation.c b/drivers/iio/orientation/hid-sensor-rotation.c index 51387bbc1ce1..dccf848e8b0f 100644 --- a/drivers/iio/orientation/hid-sensor-rotation.c +++ b/drivers/iio/orientation/hid-sensor-rotation.c | |||
@@ -145,10 +145,8 @@ static int dev_rot_proc_event(struct hid_sensor_hub_device *hsdev, | |||
145 | struct iio_dev *indio_dev = platform_get_drvdata(priv); | 145 | struct iio_dev *indio_dev = platform_get_drvdata(priv); |
146 | struct dev_rot_state *rot_state = iio_priv(indio_dev); | 146 | struct dev_rot_state *rot_state = iio_priv(indio_dev); |
147 | 147 | ||
148 | dev_dbg(&indio_dev->dev, "dev_rot_proc_event [%d]\n", | 148 | dev_dbg(&indio_dev->dev, "dev_rot_proc_event\n"); |
149 | rot_state->common_attributes.data_ready); | 149 | if (atomic_read(&rot_state->common_attributes.data_ready)) |
150 | |||
151 | if (rot_state->common_attributes.data_ready) | ||
152 | hid_sensor_push_data(indio_dev, | 150 | hid_sensor_push_data(indio_dev, |
153 | (u8 *)rot_state->sampled_vals, | 151 | (u8 *)rot_state->sampled_vals, |
154 | sizeof(rot_state->sampled_vals)); | 152 | sizeof(rot_state->sampled_vals)); |
@@ -272,7 +270,7 @@ static int hid_dev_rot_probe(struct platform_device *pdev) | |||
272 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); | 270 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); |
273 | return ret; | 271 | return ret; |
274 | } | 272 | } |
275 | rot_state->common_attributes.data_ready = false; | 273 | atomic_set(&rot_state->common_attributes.data_ready, 0); |
276 | ret = hid_sensor_setup_trigger(indio_dev, name, | 274 | ret = hid_sensor_setup_trigger(indio_dev, name, |
277 | &rot_state->common_attributes); | 275 | &rot_state->common_attributes); |
278 | if (ret) { | 276 | if (ret) { |
diff --git a/drivers/iio/pressure/hid-sensor-press.c b/drivers/iio/pressure/hid-sensor-press.c index ff69da4443b8..39df50c45dab 100644 --- a/drivers/iio/pressure/hid-sensor-press.c +++ b/drivers/iio/pressure/hid-sensor-press.c | |||
@@ -180,9 +180,8 @@ static int press_proc_event(struct hid_sensor_hub_device *hsdev, | |||
180 | struct iio_dev *indio_dev = platform_get_drvdata(priv); | 180 | struct iio_dev *indio_dev = platform_get_drvdata(priv); |
181 | struct press_state *press_state = iio_priv(indio_dev); | 181 | struct press_state *press_state = iio_priv(indio_dev); |
182 | 182 | ||
183 | dev_dbg(&indio_dev->dev, "press_proc_event [%d]\n", | 183 | dev_dbg(&indio_dev->dev, "press_proc_event\n"); |
184 | press_state->common_attributes.data_ready); | 184 | if (atomic_read(&press_state->common_attributes.data_ready)) |
185 | if (press_state->common_attributes.data_ready) | ||
186 | hid_sensor_push_data(indio_dev, | 185 | hid_sensor_push_data(indio_dev, |
187 | &press_state->press_data, | 186 | &press_state->press_data, |
188 | sizeof(press_state->press_data)); | 187 | sizeof(press_state->press_data)); |
@@ -307,7 +306,7 @@ static int hid_press_probe(struct platform_device *pdev) | |||
307 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); | 306 | dev_err(&pdev->dev, "failed to initialize trigger buffer\n"); |
308 | goto error_free_dev_mem; | 307 | goto error_free_dev_mem; |
309 | } | 308 | } |
310 | press_state->common_attributes.data_ready = false; | 309 | atomic_set(&press_state->common_attributes.data_ready, 0); |
311 | ret = hid_sensor_setup_trigger(indio_dev, name, | 310 | ret = hid_sensor_setup_trigger(indio_dev, name, |
312 | &press_state->common_attributes); | 311 | &press_state->common_attributes); |
313 | if (ret) { | 312 | if (ret) { |