diff options
Diffstat (limited to 'include/linux/lis3lv02d.h')
| -rw-r--r-- | include/linux/lis3lv02d.h | 55 |
1 files changed, 54 insertions, 1 deletions
diff --git a/include/linux/lis3lv02d.h b/include/linux/lis3lv02d.h index 0e8a346424bb..d4292c8431e0 100644 --- a/include/linux/lis3lv02d.h +++ b/include/linux/lis3lv02d.h | |||
| @@ -1,6 +1,52 @@ | |||
| 1 | #ifndef __LIS3LV02D_H_ | 1 | #ifndef __LIS3LV02D_H_ |
| 2 | #define __LIS3LV02D_H_ | 2 | #define __LIS3LV02D_H_ |
| 3 | 3 | ||
| 4 | /** | ||
| 5 | * struct lis3lv02d_platform_data - lis3 chip family platform data | ||
| 6 | * @click_flags: Click detection unit configuration | ||
| 7 | * @click_thresh_x: Click detection unit x axis threshold | ||
| 8 | * @click_thresh_y: Click detection unit y axis threshold | ||
| 9 | * @click_thresh_z: Click detection unit z axis threshold | ||
| 10 | * @click_time_limit: Click detection unit time parameter | ||
| 11 | * @click_latency: Click detection unit latency parameter | ||
| 12 | * @click_window: Click detection unit window parameter | ||
| 13 | * @irq_cfg: On chip irq source and type configuration (click / | ||
| 14 | * data available / wake up, open drain, polarity) | ||
| 15 | * @irq_flags1: Additional irq triggering flags for irq channel 0 | ||
| 16 | * @irq_flags2: Additional irq triggering flags for irq channel 1 | ||
| 17 | * @duration1: Wake up unit 1 duration parameter | ||
| 18 | * @duration2: Wake up unit 2 duration parameter | ||
| 19 | * @wakeup_flags: Wake up unit 1 flags | ||
| 20 | * @wakeup_thresh: Wake up unit 1 threshold value | ||
| 21 | * @wakeup_flags2: Wake up unit 2 flags | ||
| 22 | * @wakeup_thresh2: Wake up unit 2 threshold value | ||
| 23 | * @hipass_ctrl: High pass filter control (enable / disable, cut off | ||
| 24 | * frequency) | ||
| 25 | * @axis_x: Sensor orientation remapping for x-axis | ||
| 26 | * @axis_y: Sensor orientation remapping for y-axis | ||
| 27 | * @axis_z: Sensor orientation remapping for z-axis | ||
| 28 | * @driver_features: Enable bits for different features. Disabled by default | ||
| 29 | * @default_rate: Default sampling rate. 0 means reset default | ||
| 30 | * @setup_resources: Interrupt line setup call back function | ||
| 31 | * @release_resources: Interrupt line release call back function | ||
| 32 | * @st_min_limits[3]: Selftest acceptance minimum values | ||
| 33 | * @st_max_limits[3]: Selftest acceptance maximum values | ||
| 34 | * @irq2: Irq line 2 number | ||
| 35 | * | ||
| 36 | * Platform data is used to setup the sensor chip. Meaning of the different | ||
| 37 | * chip features can be found from the data sheet. It is publicly available | ||
| 38 | * at www.st.com web pages. Currently the platform data is used | ||
| 39 | * only for the 8 bit device. The 8 bit device has two wake up / free fall | ||
| 40 | * detection units and click detection unit. There are plenty of ways to | ||
| 41 | * configure the chip which makes is quite hard to explain deeper meaning of | ||
| 42 | * the fields here. Behaviour of the detection blocks varies heavily depending | ||
| 43 | * on the configuration. For example, interrupt detection block can use high | ||
| 44 | * pass filtered data which makes it react to the changes in the acceleration. | ||
| 45 | * Irq_flags can be used to enable interrupt detection on the both edges. | ||
| 46 | * With proper chip configuration this produces interrupt when some trigger | ||
| 47 | * starts and when it goes away. | ||
| 48 | */ | ||
| 49 | |||
| 4 | struct lis3lv02d_platform_data { | 50 | struct lis3lv02d_platform_data { |
| 5 | /* please note: the 'click' feature is only supported for | 51 | /* please note: the 'click' feature is only supported for |
| 6 | * LIS[32]02DL variants of the chip and will be ignored for | 52 | * LIS[32]02DL variants of the chip and will be ignored for |
| @@ -36,7 +82,10 @@ struct lis3lv02d_platform_data { | |||
| 36 | #define LIS3_IRQ_OPEN_DRAIN (1 << 6) | 82 | #define LIS3_IRQ_OPEN_DRAIN (1 << 6) |
| 37 | #define LIS3_IRQ_ACTIVE_LOW (1 << 7) | 83 | #define LIS3_IRQ_ACTIVE_LOW (1 << 7) |
| 38 | unsigned char irq_cfg; | 84 | unsigned char irq_cfg; |
| 39 | 85 | unsigned char irq_flags1; /* Additional irq edge / level flags */ | |
| 86 | unsigned char irq_flags2; /* Additional irq edge / level flags */ | ||
| 87 | unsigned char duration1; | ||
| 88 | unsigned char duration2; | ||
| 40 | #define LIS3_WAKEUP_X_LO (1 << 0) | 89 | #define LIS3_WAKEUP_X_LO (1 << 0) |
| 41 | #define LIS3_WAKEUP_X_HI (1 << 1) | 90 | #define LIS3_WAKEUP_X_HI (1 << 1) |
| 42 | #define LIS3_WAKEUP_Y_LO (1 << 2) | 91 | #define LIS3_WAKEUP_Y_LO (1 << 2) |
| @@ -64,6 +113,10 @@ struct lis3lv02d_platform_data { | |||
| 64 | s8 axis_x; | 113 | s8 axis_x; |
| 65 | s8 axis_y; | 114 | s8 axis_y; |
| 66 | s8 axis_z; | 115 | s8 axis_z; |
| 116 | #define LIS3_USE_REGULATOR_CTRL 0x01 | ||
| 117 | #define LIS3_USE_BLOCK_READ 0x02 | ||
| 118 | u16 driver_features; | ||
| 119 | int default_rate; | ||
| 67 | int (*setup_resources)(void); | 120 | int (*setup_resources)(void); |
| 68 | int (*release_resources)(void); | 121 | int (*release_resources)(void); |
| 69 | /* Limits for selftest are specified in chip data sheet */ | 122 | /* Limits for selftest are specified in chip data sheet */ |
