1/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * Copyright (c) 2011 Samsung Electronics Co., Ltd
4 * http://www.samsung.com
5 */
6
7#ifndef __LINUX_MFD_SEC_CORE_H
8#define __LINUX_MFD_SEC_CORE_H
9
10/* Macros to represent minimum voltages for LDO/BUCK */
11#define MIN_3000_MV 3000000
12#define MIN_2500_MV 2500000
13#define MIN_2000_MV 2000000
14#define MIN_1800_MV 1800000
15#define MIN_1500_MV 1500000
16#define MIN_1400_MV 1400000
17#define MIN_1000_MV 1000000
18
19#define MIN_900_MV 900000
20#define MIN_850_MV 850000
21#define MIN_800_MV 800000
22#define MIN_750_MV 750000
23#define MIN_650_MV 650000
24#define MIN_600_MV 600000
25#define MIN_500_MV 500000
26
27/* Ramp delay in uV/us */
28#define RAMP_DELAY_12_MVUS 12000
29
30/* Macros to represent steps for LDO/BUCK */
31#define STEP_50_MV 50000
32#define STEP_25_MV 25000
33#define STEP_12_5_MV 12500
34#define STEP_6_25_MV 6250
35
36struct gpio_desc;
37
38enum sec_device_type {
39 S5M8767X,
40 S2MPA01,
41 S2MPS11X,
42 S2MPS13X,
43 S2MPS14X,
44 S2MPS15X,
45 S2MPU02,
46};
47
48/**
49 * struct sec_pmic_dev - s2m/s5m master device for sub-drivers
50 * @dev: Master device of the chip
51 * @pdata: Platform data populated with data from DTS
52 * or board files
53 * @regmap_pmic: Regmap associated with PMIC's I2C address
54 * @i2c: I2C client of the main driver
55 * @device_type: Type of device, matches enum sec_device_type
56 * @irq_base: Base IRQ number for device, required for IRQs
57 * @irq: Generic IRQ number for device
58 * @irq_data: Runtime data structure for IRQ controller
59 * @wakeup: Whether or not this is a wakeup device
60 */
61struct sec_pmic_dev {
62 struct device *dev;
63 struct sec_platform_data *pdata;
64 struct regmap *regmap_pmic;
65 struct i2c_client *i2c;
66
67 unsigned long device_type;
68 int irq;
69 struct regmap_irq_chip_data *irq_data;
70};
71
72int sec_irq_init(struct sec_pmic_dev *sec_pmic);
73void sec_irq_exit(struct sec_pmic_dev *sec_pmic);
74int sec_irq_resume(struct sec_pmic_dev *sec_pmic);
75
76struct sec_platform_data {
77 struct sec_regulator_data *regulators;
78 struct sec_opmode_data *opmode;
79 int num_regulators;
80
81 int buck_gpios[3];
82 int buck_ds[3];
83 unsigned int buck2_voltage[8];
84 bool buck2_gpiodvs;
85 unsigned int buck3_voltage[8];
86 bool buck3_gpiodvs;
87 unsigned int buck4_voltage[8];
88 bool buck4_gpiodvs;
89
90 int buck_default_idx;
91 int buck_ramp_delay;
92
93 bool buck2_ramp_enable;
94 bool buck3_ramp_enable;
95 bool buck4_ramp_enable;
96
97 int buck2_init;
98 int buck3_init;
99 int buck4_init;
100 /* Whether or not manually set PWRHOLD to low during shutdown. */
101 bool manual_poweroff;
102 /* Disable the WRSTBI (buck voltage warm reset) when probing? */
103 bool disable_wrstbi;
104};
105
106/**
107 * sec_regulator_data - regulator data
108 * @id: regulator id
109 * @initdata: regulator init data (contraints, supplies, ...)
110 */
111struct sec_regulator_data {
112 int id;
113 struct regulator_init_data *initdata;
114 struct device_node *reg_node;
115 struct gpio_desc *ext_control_gpiod;
116};
117
118/*
119 * sec_opmode_data - regulator operation mode data
120 * @id: regulator id
121 * @mode: regulator operation mode
122 */
123struct sec_opmode_data {
124 int id;
125 unsigned int mode;
126};
127
128/*
129 * samsung regulator operation mode
130 * SEC_OPMODE_OFF Regulator always OFF
131 * SEC_OPMODE_ON Regulator always ON
132 * SEC_OPMODE_LOWPOWER Regulator is on in low-power mode
133 * SEC_OPMODE_SUSPEND Regulator is changed by PWREN pin
134 * If PWREN is high, regulator is on
135 * If PWREN is low, regulator is off
136 */
137
138enum sec_opmode {
139 SEC_OPMODE_OFF,
140 SEC_OPMODE_ON,
141 SEC_OPMODE_LOWPOWER,
142 SEC_OPMODE_SUSPEND,
143};
144
145#endif /* __LINUX_MFD_SEC_CORE_H */
146

source code of linux/include/linux/mfd/samsung/core.h