4 * copyright (c) 2011 Samsung Electronics Co., Ltd
5 * http://www.samsung.com
7 * This program is free software; you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by the
9 * Free Software Foundation; either version 2 of the License, or (at your
10 * option) any later version.
14 #ifndef __LINUX_MFD_SEC_CORE_H
15 #define __LINUX_MFD_SEC_CORE_H
17 enum sec_device_type {
25 * struct sec_pmic_dev - s5m87xx master device for sub-drivers
26 * @dev: master device of the chip (can be used to access platform data)
27 * @pdata: pointer to private data used to pass platform data to child
28 * @i2c: i2c client private data for regulator
29 * @rtc: i2c client private data for rtc
30 * @iolock: mutex for serializing io access
31 * @irqlock: mutex for buslock
32 * @irq_base: base IRQ number for sec-pmic, required for IRQs
33 * @irq: generic IRQ number for s5m87xx
34 * @ono: power onoff IRQ number for s5m87xx
35 * @irq_masks_cur: currently active value
36 * @irq_masks_cache: cached hardware value
37 * @type: indicate which s5m87xx "variant" is used
41 struct sec_platform_data *pdata;
42 struct regmap *regmap;
43 struct i2c_client *i2c;
44 struct i2c_client *rtc;
49 struct regmap_irq_chip_data *irq_data;
57 int sec_irq_init(struct sec_pmic_dev *sec_pmic);
58 void sec_irq_exit(struct sec_pmic_dev *sec_pmic);
59 int sec_irq_resume(struct sec_pmic_dev *sec_pmic);
61 extern int sec_reg_read(struct sec_pmic_dev *sec_pmic, u8 reg, void *dest);
62 extern int sec_bulk_read(struct sec_pmic_dev *sec_pmic, u8 reg, int count, u8 *buf);
63 extern int sec_reg_write(struct sec_pmic_dev *sec_pmic, u8 reg, u8 value);
64 extern int sec_bulk_write(struct sec_pmic_dev *sec_pmic, u8 reg, int count, u8 *buf);
65 extern int sec_reg_update(struct sec_pmic_dev *sec_pmic, u8 reg, u8 val, u8 mask);
67 struct sec_platform_data {
68 struct sec_regulator_data *regulators;
69 struct sec_opmode_data *opmode;
74 int (*cfg_pmic_irq)(void);
78 bool buck_voltage_lock;
82 unsigned int buck2_voltage[8];
84 unsigned int buck3_voltage[8];
86 unsigned int buck4_voltage[8];
96 int buck2_default_idx;
97 int buck3_default_idx;
98 int buck4_default_idx;
102 int buck2_ramp_delay;
103 int buck34_ramp_delay;
104 int buck5_ramp_delay;
105 int buck16_ramp_delay;
106 int buck7810_ramp_delay;
107 int buck9_ramp_delay;
109 bool buck2_ramp_enable;
110 bool buck3_ramp_enable;
111 bool buck4_ramp_enable;
112 bool buck6_ramp_enable;
120 * sec_regulator_data - regulator data
122 * @initdata: regulator init data (contraints, supplies, ...)
124 struct sec_regulator_data {
126 struct regulator_init_data *initdata;
127 struct device_node *reg_node;
131 * sec_opmode_data - regulator operation mode data
133 * @mode: regulator operation mode
135 struct sec_opmode_data {
141 * samsung regulator operation mode
142 * SEC_OPMODE_OFF Regulator always OFF
143 * SEC_OPMODE_ON Regulator always ON
144 * SEC_OPMODE_LOWPOWER Regulator is on in low-power mode
145 * SEC_OPMODE_SUSPEND Regulator is changed by PWREN pin
146 * If PWREN is high, regulator is on
147 * If PWREN is low, regulator is off
157 #endif /* __LINUX_MFD_SEC_CORE_H */