diff options
Diffstat (limited to 'include/linux/i2c')
| -rw-r--r-- | include/linux/i2c/adp5588.h | 21 | ||||
| -rw-r--r-- | include/linux/i2c/apds990x.h | 79 | ||||
| -rw-r--r-- | include/linux/i2c/bh1770glc.h | 53 | ||||
| -rw-r--r-- | include/linux/i2c/twl.h | 77 |
4 files changed, 228 insertions, 2 deletions
diff --git a/include/linux/i2c/adp5588.h b/include/linux/i2c/adp5588.h index 269181b8f623..3c5d6b6e765c 100644 --- a/include/linux/i2c/adp5588.h +++ b/include/linux/i2c/adp5588.h | |||
| @@ -74,6 +74,20 @@ | |||
| 74 | 74 | ||
| 75 | #define ADP5588_DEVICE_ID_MASK 0xF | 75 | #define ADP5588_DEVICE_ID_MASK 0xF |
| 76 | 76 | ||
| 77 | /* Configuration Register1 */ | ||
| 78 | #define ADP5588_AUTO_INC (1 << 7) | ||
| 79 | #define ADP5588_GPIEM_CFG (1 << 6) | ||
| 80 | #define ADP5588_INT_CFG (1 << 4) | ||
| 81 | #define ADP5588_GPI_IEN (1 << 1) | ||
| 82 | |||
| 83 | /* Interrupt Status Register */ | ||
| 84 | #define ADP5588_GPI_INT (1 << 1) | ||
| 85 | #define ADP5588_KE_INT (1 << 0) | ||
| 86 | |||
| 87 | #define ADP5588_MAXGPIO 18 | ||
| 88 | #define ADP5588_BANK(offs) ((offs) >> 3) | ||
| 89 | #define ADP5588_BIT(offs) (1u << ((offs) & 0x7)) | ||
| 90 | |||
| 77 | /* Put one of these structures in i2c_board_info platform_data */ | 91 | /* Put one of these structures in i2c_board_info platform_data */ |
| 78 | 92 | ||
| 79 | #define ADP5588_KEYMAPSIZE 80 | 93 | #define ADP5588_KEYMAPSIZE 80 |
| @@ -126,9 +140,12 @@ struct adp5588_kpad_platform_data { | |||
| 126 | const struct adp5588_gpio_platform_data *gpio_data; | 140 | const struct adp5588_gpio_platform_data *gpio_data; |
| 127 | }; | 141 | }; |
| 128 | 142 | ||
| 143 | struct i2c_client; /* forward declaration */ | ||
| 144 | |||
| 129 | struct adp5588_gpio_platform_data { | 145 | struct adp5588_gpio_platform_data { |
| 130 | unsigned gpio_start; /* GPIO Chip base # */ | 146 | int gpio_start; /* GPIO Chip base # */ |
| 131 | unsigned pullup_dis_mask; /* Pull-Up Disable Mask */ | 147 | unsigned irq_base; /* interrupt base # */ |
| 148 | unsigned pullup_dis_mask; /* Pull-Up Disable Mask */ | ||
| 132 | int (*setup)(struct i2c_client *client, | 149 | int (*setup)(struct i2c_client *client, |
| 133 | int gpio, unsigned ngpio, | 150 | int gpio, unsigned ngpio, |
| 134 | void *context); | 151 | void *context); |
diff --git a/include/linux/i2c/apds990x.h b/include/linux/i2c/apds990x.h new file mode 100644 index 000000000000..d186fcc5d257 --- /dev/null +++ b/include/linux/i2c/apds990x.h | |||
| @@ -0,0 +1,79 @@ | |||
| 1 | /* | ||
| 2 | * This file is part of the APDS990x sensor driver. | ||
| 3 | * Chip is combined proximity and ambient light sensor. | ||
| 4 | * | ||
| 5 | * Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies). | ||
| 6 | * | ||
| 7 | * Contact: Samu Onkalo <samu.p.onkalo@nokia.com> | ||
| 8 | * | ||
| 9 | * This program is free software; you can redistribute it and/or | ||
| 10 | * modify it under the terms of the GNU General Public License | ||
| 11 | * version 2 as published by the Free Software Foundation. | ||
| 12 | * | ||
| 13 | * This program is distributed in the hope that it will be useful, but | ||
| 14 | * WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| 16 | * General Public License for more details. | ||
| 17 | * | ||
| 18 | * You should have received a copy of the GNU General Public License | ||
| 19 | * along with this program; if not, write to the Free Software | ||
| 20 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | ||
| 21 | * 02110-1301 USA | ||
| 22 | * | ||
| 23 | */ | ||
| 24 | |||
| 25 | #ifndef __APDS990X_H__ | ||
| 26 | #define __APDS990X_H__ | ||
| 27 | |||
| 28 | |||
| 29 | #define APDS_IRLED_CURR_12mA 0x3 | ||
| 30 | #define APDS_IRLED_CURR_25mA 0x2 | ||
| 31 | #define APDS_IRLED_CURR_50mA 0x1 | ||
| 32 | #define APDS_IRLED_CURR_100mA 0x0 | ||
| 33 | |||
| 34 | /** | ||
| 35 | * struct apds990x_chip_factors - defines effect of the cover window | ||
| 36 | * @ga: Total glass attenuation | ||
| 37 | * @cf1: clear channel factor 1 for raw to lux conversion | ||
| 38 | * @irf1: IR channel factor 1 for raw to lux conversion | ||
| 39 | * @cf2: clear channel factor 2 for raw to lux conversion | ||
| 40 | * @irf2: IR channel factor 2 for raw to lux conversion | ||
| 41 | * @df: device factor for conversion formulas | ||
| 42 | * | ||
| 43 | * Structure for tuning ALS calculation to match with environment. | ||
| 44 | * Values depend on the material above the sensor and the sensor | ||
| 45 | * itself. If the GA is zero, driver will use uncovered sensor default values | ||
| 46 | * format: decimal value * APDS_PARAM_SCALE except df which is plain integer. | ||
| 47 | */ | ||
| 48 | #define APDS_PARAM_SCALE 4096 | ||
| 49 | struct apds990x_chip_factors { | ||
| 50 | int ga; | ||
| 51 | int cf1; | ||
| 52 | int irf1; | ||
| 53 | int cf2; | ||
| 54 | int irf2; | ||
| 55 | int df; | ||
| 56 | }; | ||
| 57 | |||
| 58 | /** | ||
| 59 | * struct apds990x_platform_data - platform data for apsd990x.c driver | ||
| 60 | * @cf: chip factor data | ||
| 61 | * @pddrive: IR-led driving current | ||
| 62 | * @ppcount: number of IR pulses used for proximity estimation | ||
| 63 | * @setup_resources: interrupt line setup call back function | ||
| 64 | * @release_resources: interrupt line release call back function | ||
| 65 | * | ||
| 66 | * Proximity detection result depends heavily on correct ppcount, pdrive | ||
| 67 | * and cover window. | ||
| 68 | * | ||
| 69 | */ | ||
| 70 | |||
| 71 | struct apds990x_platform_data { | ||
| 72 | struct apds990x_chip_factors cf; | ||
| 73 | u8 pdrive; | ||
| 74 | u8 ppcount; | ||
| 75 | int (*setup_resources)(void); | ||
| 76 | int (*release_resources)(void); | ||
| 77 | }; | ||
| 78 | |||
| 79 | #endif | ||
diff --git a/include/linux/i2c/bh1770glc.h b/include/linux/i2c/bh1770glc.h new file mode 100644 index 000000000000..8b5e2df36c72 --- /dev/null +++ b/include/linux/i2c/bh1770glc.h | |||
| @@ -0,0 +1,53 @@ | |||
| 1 | /* | ||
| 2 | * This file is part of the ROHM BH1770GLC / OSRAM SFH7770 sensor driver. | ||
| 3 | * Chip is combined proximity and ambient light sensor. | ||
| 4 | * | ||
| 5 | * Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies). | ||
| 6 | * | ||
| 7 | * Contact: Samu Onkalo <samu.p.onkalo@nokia.com> | ||
| 8 | * | ||
| 9 | * This program is free software; you can redistribute it and/or | ||
| 10 | * modify it under the terms of the GNU General Public License | ||
| 11 | * version 2 as published by the Free Software Foundation. | ||
| 12 | * | ||
| 13 | * This program is distributed in the hope that it will be useful, but | ||
| 14 | * WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| 16 | * General Public License for more details. | ||
| 17 | * | ||
| 18 | * You should have received a copy of the GNU General Public License | ||
| 19 | * along with this program; if not, write to the Free Software | ||
| 20 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | ||
| 21 | * 02110-1301 USA | ||
| 22 | * | ||
| 23 | */ | ||
| 24 | |||
| 25 | #ifndef __BH1770_H__ | ||
| 26 | #define __BH1770_H__ | ||
| 27 | |||
| 28 | /** | ||
| 29 | * struct bh1770_platform_data - platform data for bh1770glc driver | ||
| 30 | * @led_def_curr: IR led driving current. | ||
| 31 | * @glass_attenuation: Attenuation factor for covering window. | ||
| 32 | * @setup_resources: Call back for interrupt line setup function | ||
| 33 | * @release_resources: Call back for interrupte line release function | ||
| 34 | * | ||
| 35 | * Example of glass attenuation: 16384 * 385 / 100 means attenuation factor | ||
| 36 | * of 3.85. i.e. light_above_sensor = light_above_cover_window / 3.85 | ||
| 37 | */ | ||
| 38 | |||
| 39 | struct bh1770_platform_data { | ||
| 40 | #define BH1770_LED_5mA 0 | ||
| 41 | #define BH1770_LED_10mA 1 | ||
| 42 | #define BH1770_LED_20mA 2 | ||
| 43 | #define BH1770_LED_50mA 3 | ||
| 44 | #define BH1770_LED_100mA 4 | ||
| 45 | #define BH1770_LED_150mA 5 | ||
| 46 | #define BH1770_LED_200mA 6 | ||
| 47 | __u8 led_def_curr; | ||
| 48 | #define BH1770_NEUTRAL_GA 16384 /* 16384 / 16384 = 1 */ | ||
| 49 | __u32 glass_attenuation; | ||
| 50 | int (*setup_resources)(void); | ||
| 51 | int (*release_resources)(void); | ||
| 52 | }; | ||
| 53 | #endif | ||
diff --git a/include/linux/i2c/twl.h b/include/linux/i2c/twl.h index 4793d8a7f480..c760991b354a 100644 --- a/include/linux/i2c/twl.h +++ b/include/linux/i2c/twl.h | |||
| @@ -141,6 +141,16 @@ | |||
| 141 | #define TWL6030_CHARGER_CTRL_INT_MASK 0x10 | 141 | #define TWL6030_CHARGER_CTRL_INT_MASK 0x10 |
| 142 | #define TWL6030_CHARGER_FAULT_INT_MASK 0x60 | 142 | #define TWL6030_CHARGER_FAULT_INT_MASK 0x60 |
| 143 | 143 | ||
| 144 | #define TWL6030_MMCCTRL 0xEE | ||
| 145 | #define VMMC_AUTO_OFF (0x1 << 3) | ||
| 146 | #define SW_FC (0x1 << 2) | ||
| 147 | #define STS_MMC 0x1 | ||
| 148 | |||
| 149 | #define TWL6030_CFG_INPUT_PUPD3 0xF2 | ||
| 150 | #define MMC_PU (0x1 << 3) | ||
| 151 | #define MMC_PD (0x1 << 2) | ||
| 152 | |||
| 153 | |||
| 144 | 154 | ||
| 145 | #define TWL4030_CLASS_ID 0x4030 | 155 | #define TWL4030_CLASS_ID 0x4030 |
| 146 | #define TWL6030_CLASS_ID 0x6030 | 156 | #define TWL6030_CLASS_ID 0x6030 |
| @@ -173,6 +183,27 @@ int twl_i2c_read(u8 mod_no, u8 *value, u8 reg, unsigned num_bytes); | |||
| 173 | int twl6030_interrupt_unmask(u8 bit_mask, u8 offset); | 183 | int twl6030_interrupt_unmask(u8 bit_mask, u8 offset); |
| 174 | int twl6030_interrupt_mask(u8 bit_mask, u8 offset); | 184 | int twl6030_interrupt_mask(u8 bit_mask, u8 offset); |
| 175 | 185 | ||
| 186 | /* Card detect Configuration for MMC1 Controller on OMAP4 */ | ||
| 187 | #ifdef CONFIG_TWL4030_CORE | ||
| 188 | int twl6030_mmc_card_detect_config(void); | ||
| 189 | #else | ||
| 190 | static inline int twl6030_mmc_card_detect_config(void) | ||
| 191 | { | ||
| 192 | pr_debug("twl6030_mmc_card_detect_config not supported\n"); | ||
| 193 | return 0; | ||
| 194 | } | ||
| 195 | #endif | ||
| 196 | |||
| 197 | /* MMC1 Controller on OMAP4 uses Phoenix irq for Card detect */ | ||
| 198 | #ifdef CONFIG_TWL4030_CORE | ||
| 199 | int twl6030_mmc_card_detect(struct device *dev, int slot); | ||
| 200 | #else | ||
| 201 | static inline int twl6030_mmc_card_detect(struct device *dev, int slot) | ||
| 202 | { | ||
| 203 | pr_debug("Call back twl6030_mmc_card_detect not supported\n"); | ||
| 204 | return -EIO; | ||
| 205 | } | ||
| 206 | #endif | ||
| 176 | /*----------------------------------------------------------------------*/ | 207 | /*----------------------------------------------------------------------*/ |
| 177 | 208 | ||
| 178 | /* | 209 | /* |
| @@ -357,6 +388,52 @@ int twl6030_interrupt_mask(u8 bit_mask, u8 offset); | |||
| 357 | 388 | ||
| 358 | /*----------------------------------------------------------------------*/ | 389 | /*----------------------------------------------------------------------*/ |
| 359 | 390 | ||
| 391 | /* | ||
| 392 | * PM Master module register offsets (use TWL4030_MODULE_PM_MASTER) | ||
| 393 | */ | ||
| 394 | |||
| 395 | #define TWL4030_PM_MASTER_CFG_P1_TRANSITION 0x00 | ||
| 396 | #define TWL4030_PM_MASTER_CFG_P2_TRANSITION 0x01 | ||
| 397 | #define TWL4030_PM_MASTER_CFG_P3_TRANSITION 0x02 | ||
| 398 | #define TWL4030_PM_MASTER_CFG_P123_TRANSITION 0x03 | ||
| 399 | #define TWL4030_PM_MASTER_STS_BOOT 0x04 | ||
| 400 | #define TWL4030_PM_MASTER_CFG_BOOT 0x05 | ||
| 401 | #define TWL4030_PM_MASTER_SHUNDAN 0x06 | ||
| 402 | #define TWL4030_PM_MASTER_BOOT_BCI 0x07 | ||
| 403 | #define TWL4030_PM_MASTER_CFG_PWRANA1 0x08 | ||
| 404 | #define TWL4030_PM_MASTER_CFG_PWRANA2 0x09 | ||
| 405 | #define TWL4030_PM_MASTER_BACKUP_MISC_STS 0x0b | ||
| 406 | #define TWL4030_PM_MASTER_BACKUP_MISC_CFG 0x0c | ||
| 407 | #define TWL4030_PM_MASTER_BACKUP_MISC_TST 0x0d | ||
| 408 | #define TWL4030_PM_MASTER_PROTECT_KEY 0x0e | ||
| 409 | #define TWL4030_PM_MASTER_STS_HW_CONDITIONS 0x0f | ||
| 410 | #define TWL4030_PM_MASTER_P1_SW_EVENTS 0x10 | ||
| 411 | #define TWL4030_PM_MASTER_P2_SW_EVENTS 0x11 | ||
| 412 | #define TWL4030_PM_MASTER_P3_SW_EVENTS 0x12 | ||
| 413 | #define TWL4030_PM_MASTER_STS_P123_STATE 0x13 | ||
| 414 | #define TWL4030_PM_MASTER_PB_CFG 0x14 | ||
| 415 | #define TWL4030_PM_MASTER_PB_WORD_MSB 0x15 | ||
| 416 | #define TWL4030_PM_MASTER_PB_WORD_LSB 0x16 | ||
| 417 | #define TWL4030_PM_MASTER_SEQ_ADD_W2P 0x1c | ||
| 418 | #define TWL4030_PM_MASTER_SEQ_ADD_P2A 0x1d | ||
| 419 | #define TWL4030_PM_MASTER_SEQ_ADD_A2W 0x1e | ||
| 420 | #define TWL4030_PM_MASTER_SEQ_ADD_A2S 0x1f | ||
| 421 | #define TWL4030_PM_MASTER_SEQ_ADD_S2A12 0x20 | ||
| 422 | #define TWL4030_PM_MASTER_SEQ_ADD_S2A3 0x21 | ||
| 423 | #define TWL4030_PM_MASTER_SEQ_ADD_WARM 0x22 | ||
| 424 | #define TWL4030_PM_MASTER_MEMORY_ADDRESS 0x23 | ||
| 425 | #define TWL4030_PM_MASTER_MEMORY_DATA 0x24 | ||
| 426 | |||
| 427 | #define TWL4030_PM_MASTER_KEY_CFG1 0xc0 | ||
| 428 | #define TWL4030_PM_MASTER_KEY_CFG2 0x0c | ||
| 429 | |||
| 430 | #define TWL4030_PM_MASTER_KEY_TST1 0xe0 | ||
| 431 | #define TWL4030_PM_MASTER_KEY_TST2 0x0e | ||
| 432 | |||
| 433 | #define TWL4030_PM_MASTER_GLOBAL_TST 0xb6 | ||
| 434 | |||
| 435 | /*----------------------------------------------------------------------*/ | ||
| 436 | |||
| 360 | /* Power bus message definitions */ | 437 | /* Power bus message definitions */ |
| 361 | 438 | ||
| 362 | /* The TWL4030/5030 splits its power-management resources (the various | 439 | /* The TWL4030/5030 splits its power-management resources (the various |
