diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2010-10-25 19:25:31 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-10-25 19:25:31 -0400 |
| commit | b20f9e5bddddb5ef0d743d6e0d409ffc8cf9fc56 (patch) | |
| tree | 7654b53ebb9af77b5daeab696d1d48069ae631a1 /include | |
| parent | 5260562754c0aa4b95eebb1f851eaccce7286365 (diff) | |
| parent | b11e7b3f3b56119194234085d42a633ceabd6aba (diff) | |
Merge branch 'hwmon-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/staging
* 'hwmon-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/staging: (24 commits)
hwmon: lis3: Release resources in case of failure
hwmon: lis3: Short explanations of platform data fields
hwmon: lis3: Enhance lis3 selftest with IRQ line test
hwmon: lis3: use block read to access data registers
hwmon: lis3: Adjust fuzziness for 8 bit device
hwmon: lis3: New parameters to platform data
hwmon: lis3: restore axis enabled bits
hwmon: lis3: Power on corrections
hwmon: lis3: Update coordinates at polled device open
hwmon: lis3: Cleanup interrupt handling
hwmon: lis3: regulator control
hwmon: lis3: pm_runtime support
Kirkwood: add fan support for Network Space Max v2
hwmon: add generic GPIO fan driver
hwmon: (coretemp) fix reading of microcode revision (v2)
hwmon: ({core, pkg, via-cpu}temp) remove unnecessary CONFIG_HOTPLUG_CPU ifdefs
hwmon: (pkgtemp) align driver initialization style with coretemp
hwmon: LTC4261 Hardware monitoring driver
hwmon: (lis3) add axes module parameter for custom axis-mapping
hwmon: (hp_accel) Add HP Mini 510x family support
...
Diffstat (limited to 'include')
| -rw-r--r-- | include/linux/gpio-fan.h | 36 | ||||
| -rw-r--r-- | include/linux/lis3lv02d.h | 55 |
2 files changed, 90 insertions, 1 deletions
diff --git a/include/linux/gpio-fan.h b/include/linux/gpio-fan.h new file mode 100644 index 000000000000..096659169215 --- /dev/null +++ b/include/linux/gpio-fan.h | |||
| @@ -0,0 +1,36 @@ | |||
| 1 | /* | ||
| 2 | * include/linux/gpio-fan.h | ||
| 3 | * | ||
| 4 | * Platform data structure for GPIO fan driver | ||
| 5 | * | ||
| 6 | * This file is licensed under the terms of the GNU General Public | ||
| 7 | * License version 2. This program is licensed "as is" without any | ||
| 8 | * warranty of any kind, whether express or implied. | ||
| 9 | */ | ||
| 10 | |||
| 11 | #ifndef __LINUX_GPIO_FAN_H | ||
| 12 | #define __LINUX_GPIO_FAN_H | ||
| 13 | |||
| 14 | struct gpio_fan_alarm { | ||
| 15 | unsigned gpio; | ||
| 16 | unsigned active_low; | ||
| 17 | }; | ||
| 18 | |||
| 19 | struct gpio_fan_speed { | ||
| 20 | int rpm; | ||
| 21 | int ctrl_val; | ||
| 22 | }; | ||
| 23 | |||
| 24 | struct gpio_fan_platform_data { | ||
| 25 | int num_ctrl; | ||
| 26 | unsigned *ctrl; /* fan control GPIOs. */ | ||
| 27 | struct gpio_fan_alarm *alarm; /* fan alarm GPIO. */ | ||
| 28 | /* | ||
| 29 | * Speed conversion array: rpm from/to GPIO bit field. | ||
| 30 | * This array _must_ be sorted in ascending rpm order. | ||
| 31 | */ | ||
| 32 | int num_speed; | ||
| 33 | struct gpio_fan_speed *speed; | ||
| 34 | }; | ||
| 35 | |||
| 36 | #endif /* __LINUX_GPIO_FAN_H */ | ||
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 */ |
