Linux Audio

Check our new training course

Loading...
v6.2
   1/*
   2 * AXP20x regulators driver.
   3 *
   4 * Copyright (C) 2013 Carlo Caione <carlo@caione.org>
   5 *
   6 * This file is subject to the terms and conditions of the GNU General
   7 * Public License. See the file "COPYING" in the main directory of this
   8 * archive for more details.
   9 *
  10 * This program is distributed in the hope that it will be useful,
  11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13 * GNU General Public License for more details.
  14 */
  15
  16#include <linux/bitops.h>
  17#include <linux/delay.h>
  18#include <linux/err.h>
  19#include <linux/init.h>
  20#include <linux/mfd/axp20x.h>
  21#include <linux/module.h>
  22#include <linux/of.h>
  23#include <linux/of_device.h>
  24#include <linux/platform_device.h>
  25#include <linux/regmap.h>
  26#include <linux/regulator/driver.h>
  27#include <linux/regulator/machine.h>
  28#include <linux/regulator/of_regulator.h>
  29
  30#define AXP20X_GPIO0_FUNC_MASK		GENMASK(3, 0)
  31#define AXP20X_GPIO1_FUNC_MASK		GENMASK(3, 0)
  32
  33#define AXP20X_IO_ENABLED		0x03
  34#define AXP20X_IO_DISABLED		0x07
  35
  36#define AXP20X_WORKMODE_DCDC2_MASK	BIT_MASK(2)
  37#define AXP20X_WORKMODE_DCDC3_MASK	BIT_MASK(1)
  38
  39#define AXP20X_FREQ_DCDC_MASK		GENMASK(3, 0)
  40
  41#define AXP20X_VBUS_IPSOUT_MGMT_MASK	BIT_MASK(2)
  42
  43#define AXP20X_DCDC2_V_OUT_MASK		GENMASK(5, 0)
  44#define AXP20X_DCDC3_V_OUT_MASK		GENMASK(7, 0)
  45#define AXP20X_LDO2_V_OUT_MASK		GENMASK(7, 4)
  46#define AXP20X_LDO3_V_OUT_MASK		GENMASK(6, 0)
  47#define AXP20X_LDO4_V_OUT_MASK		GENMASK(3, 0)
  48#define AXP20X_LDO5_V_OUT_MASK		GENMASK(7, 4)
  49
  50#define AXP20X_PWR_OUT_EXTEN_MASK	BIT_MASK(0)
  51#define AXP20X_PWR_OUT_DCDC3_MASK	BIT_MASK(1)
  52#define AXP20X_PWR_OUT_LDO2_MASK	BIT_MASK(2)
  53#define AXP20X_PWR_OUT_LDO4_MASK	BIT_MASK(3)
  54#define AXP20X_PWR_OUT_DCDC2_MASK	BIT_MASK(4)
  55#define AXP20X_PWR_OUT_LDO3_MASK	BIT_MASK(6)
  56
  57#define AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_RATE_MASK	BIT_MASK(0)
  58#define AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_RATE(x) \
  59	((x) << 0)
  60#define AXP20X_DCDC2_LDO3_V_RAMP_LDO3_RATE_MASK		BIT_MASK(1)
  61#define AXP20X_DCDC2_LDO3_V_RAMP_LDO3_RATE(x) \
  62	((x) << 1)
  63#define AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_EN_MASK		BIT_MASK(2)
  64#define AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_EN		BIT(2)
  65#define AXP20X_DCDC2_LDO3_V_RAMP_LDO3_EN_MASK		BIT_MASK(3)
  66#define AXP20X_DCDC2_LDO3_V_RAMP_LDO3_EN		BIT(3)
  67
  68#define AXP20X_LDO4_V_OUT_1250mV_START	0x0
  69#define AXP20X_LDO4_V_OUT_1250mV_STEPS	0
  70#define AXP20X_LDO4_V_OUT_1250mV_END	\
  71	(AXP20X_LDO4_V_OUT_1250mV_START + AXP20X_LDO4_V_OUT_1250mV_STEPS)
  72#define AXP20X_LDO4_V_OUT_1300mV_START	0x1
  73#define AXP20X_LDO4_V_OUT_1300mV_STEPS	7
  74#define AXP20X_LDO4_V_OUT_1300mV_END	\
  75	(AXP20X_LDO4_V_OUT_1300mV_START + AXP20X_LDO4_V_OUT_1300mV_STEPS)
  76#define AXP20X_LDO4_V_OUT_2500mV_START	0x9
  77#define AXP20X_LDO4_V_OUT_2500mV_STEPS	0
  78#define AXP20X_LDO4_V_OUT_2500mV_END	\
  79	(AXP20X_LDO4_V_OUT_2500mV_START + AXP20X_LDO4_V_OUT_2500mV_STEPS)
  80#define AXP20X_LDO4_V_OUT_2700mV_START	0xa
  81#define AXP20X_LDO4_V_OUT_2700mV_STEPS	1
  82#define AXP20X_LDO4_V_OUT_2700mV_END	\
  83	(AXP20X_LDO4_V_OUT_2700mV_START + AXP20X_LDO4_V_OUT_2700mV_STEPS)
  84#define AXP20X_LDO4_V_OUT_3000mV_START	0xc
  85#define AXP20X_LDO4_V_OUT_3000mV_STEPS	3
  86#define AXP20X_LDO4_V_OUT_3000mV_END	\
  87	(AXP20X_LDO4_V_OUT_3000mV_START + AXP20X_LDO4_V_OUT_3000mV_STEPS)
  88#define AXP20X_LDO4_V_OUT_NUM_VOLTAGES	16
  89
  90#define AXP22X_IO_ENABLED		0x03
  91#define AXP22X_IO_DISABLED		0x04
  92
  93#define AXP22X_WORKMODE_DCDCX_MASK(x)	BIT_MASK(x)
  94
  95#define AXP22X_MISC_N_VBUSEN_FUNC	BIT(4)
  96
  97#define AXP22X_DCDC1_V_OUT_MASK		GENMASK(4, 0)
  98#define AXP22X_DCDC2_V_OUT_MASK		GENMASK(5, 0)
  99#define AXP22X_DCDC3_V_OUT_MASK		GENMASK(5, 0)
 100#define AXP22X_DCDC4_V_OUT_MASK		GENMASK(5, 0)
 101#define AXP22X_DCDC5_V_OUT_MASK		GENMASK(4, 0)
 102#define AXP22X_DC5LDO_V_OUT_MASK	GENMASK(2, 0)
 103#define AXP22X_ALDO1_V_OUT_MASK		GENMASK(4, 0)
 104#define AXP22X_ALDO2_V_OUT_MASK		GENMASK(4, 0)
 105#define AXP22X_ALDO3_V_OUT_MASK		GENMASK(4, 0)
 106#define AXP22X_DLDO1_V_OUT_MASK		GENMASK(4, 0)
 107#define AXP22X_DLDO2_V_OUT_MASK		GENMASK(4, 0)
 108#define AXP22X_DLDO3_V_OUT_MASK		GENMASK(4, 0)
 109#define AXP22X_DLDO4_V_OUT_MASK		GENMASK(4, 0)
 110#define AXP22X_ELDO1_V_OUT_MASK		GENMASK(4, 0)
 111#define AXP22X_ELDO2_V_OUT_MASK		GENMASK(4, 0)
 112#define AXP22X_ELDO3_V_OUT_MASK		GENMASK(4, 0)
 113#define AXP22X_LDO_IO0_V_OUT_MASK	GENMASK(4, 0)
 114#define AXP22X_LDO_IO1_V_OUT_MASK	GENMASK(4, 0)
 115
 116#define AXP22X_PWR_OUT_DC5LDO_MASK	BIT_MASK(0)
 117#define AXP22X_PWR_OUT_DCDC1_MASK	BIT_MASK(1)
 118#define AXP22X_PWR_OUT_DCDC2_MASK	BIT_MASK(2)
 119#define AXP22X_PWR_OUT_DCDC3_MASK	BIT_MASK(3)
 120#define AXP22X_PWR_OUT_DCDC4_MASK	BIT_MASK(4)
 121#define AXP22X_PWR_OUT_DCDC5_MASK	BIT_MASK(5)
 122#define AXP22X_PWR_OUT_ALDO1_MASK	BIT_MASK(6)
 123#define AXP22X_PWR_OUT_ALDO2_MASK	BIT_MASK(7)
 124
 125#define AXP22X_PWR_OUT_SW_MASK		BIT_MASK(6)
 126#define AXP22X_PWR_OUT_DC1SW_MASK	BIT_MASK(7)
 127
 128#define AXP22X_PWR_OUT_ELDO1_MASK	BIT_MASK(0)
 129#define AXP22X_PWR_OUT_ELDO2_MASK	BIT_MASK(1)
 130#define AXP22X_PWR_OUT_ELDO3_MASK	BIT_MASK(2)
 131#define AXP22X_PWR_OUT_DLDO1_MASK	BIT_MASK(3)
 132#define AXP22X_PWR_OUT_DLDO2_MASK	BIT_MASK(4)
 133#define AXP22X_PWR_OUT_DLDO3_MASK	BIT_MASK(5)
 134#define AXP22X_PWR_OUT_DLDO4_MASK	BIT_MASK(6)
 135#define AXP22X_PWR_OUT_ALDO3_MASK	BIT_MASK(7)
 136
 
 
 
 
 
 137#define AXP803_PWR_OUT_DCDC1_MASK	BIT_MASK(0)
 138#define AXP803_PWR_OUT_DCDC2_MASK	BIT_MASK(1)
 139#define AXP803_PWR_OUT_DCDC3_MASK	BIT_MASK(2)
 140#define AXP803_PWR_OUT_DCDC4_MASK	BIT_MASK(3)
 141#define AXP803_PWR_OUT_DCDC5_MASK	BIT_MASK(4)
 142#define AXP803_PWR_OUT_DCDC6_MASK	BIT_MASK(5)
 143
 144#define AXP803_PWR_OUT_FLDO1_MASK	BIT_MASK(2)
 145#define AXP803_PWR_OUT_FLDO2_MASK	BIT_MASK(3)
 146
 147#define AXP803_DCDC1_V_OUT_MASK		GENMASK(4, 0)
 148#define AXP803_DCDC2_V_OUT_MASK		GENMASK(6, 0)
 149#define AXP803_DCDC3_V_OUT_MASK		GENMASK(6, 0)
 150#define AXP803_DCDC4_V_OUT_MASK		GENMASK(6, 0)
 151#define AXP803_DCDC5_V_OUT_MASK		GENMASK(6, 0)
 152#define AXP803_DCDC6_V_OUT_MASK		GENMASK(6, 0)
 153
 154#define AXP803_FLDO1_V_OUT_MASK		GENMASK(3, 0)
 155#define AXP803_FLDO2_V_OUT_MASK		GENMASK(3, 0)
 156
 157#define AXP803_DCDC23_POLYPHASE_DUAL	BIT(6)
 158#define AXP803_DCDC56_POLYPHASE_DUAL	BIT(5)
 159
 160#define AXP803_DCDC234_500mV_START	0x00
 161#define AXP803_DCDC234_500mV_STEPS	70
 162#define AXP803_DCDC234_500mV_END	\
 163	(AXP803_DCDC234_500mV_START + AXP803_DCDC234_500mV_STEPS)
 164#define AXP803_DCDC234_1220mV_START	0x47
 165#define AXP803_DCDC234_1220mV_STEPS	4
 166#define AXP803_DCDC234_1220mV_END	\
 167	(AXP803_DCDC234_1220mV_START + AXP803_DCDC234_1220mV_STEPS)
 168#define AXP803_DCDC234_NUM_VOLTAGES	76
 169
 170#define AXP803_DCDC5_800mV_START	0x00
 171#define AXP803_DCDC5_800mV_STEPS	32
 172#define AXP803_DCDC5_800mV_END		\
 173	(AXP803_DCDC5_800mV_START + AXP803_DCDC5_800mV_STEPS)
 174#define AXP803_DCDC5_1140mV_START	0x21
 175#define AXP803_DCDC5_1140mV_STEPS	35
 176#define AXP803_DCDC5_1140mV_END		\
 177	(AXP803_DCDC5_1140mV_START + AXP803_DCDC5_1140mV_STEPS)
 178#define AXP803_DCDC5_NUM_VOLTAGES	69
 179
 180#define AXP803_DCDC6_600mV_START	0x00
 181#define AXP803_DCDC6_600mV_STEPS	50
 182#define AXP803_DCDC6_600mV_END		\
 183	(AXP803_DCDC6_600mV_START + AXP803_DCDC6_600mV_STEPS)
 184#define AXP803_DCDC6_1120mV_START	0x33
 185#define AXP803_DCDC6_1120mV_STEPS	20
 186#define AXP803_DCDC6_1120mV_END		\
 187	(AXP803_DCDC6_1120mV_START + AXP803_DCDC6_1120mV_STEPS)
 188#define AXP803_DCDC6_NUM_VOLTAGES	72
 189
 190#define AXP803_DLDO2_700mV_START	0x00
 191#define AXP803_DLDO2_700mV_STEPS	26
 192#define AXP803_DLDO2_700mV_END		\
 193	(AXP803_DLDO2_700mV_START + AXP803_DLDO2_700mV_STEPS)
 194#define AXP803_DLDO2_3400mV_START	0x1b
 195#define AXP803_DLDO2_3400mV_STEPS	4
 196#define AXP803_DLDO2_3400mV_END		\
 197	(AXP803_DLDO2_3400mV_START + AXP803_DLDO2_3400mV_STEPS)
 198#define AXP803_DLDO2_NUM_VOLTAGES	32
 199
 200#define AXP806_DCDCA_V_CTRL_MASK	GENMASK(6, 0)
 201#define AXP806_DCDCB_V_CTRL_MASK	GENMASK(4, 0)
 202#define AXP806_DCDCC_V_CTRL_MASK	GENMASK(6, 0)
 203#define AXP806_DCDCD_V_CTRL_MASK	GENMASK(5, 0)
 204#define AXP806_DCDCE_V_CTRL_MASK	GENMASK(4, 0)
 205#define AXP806_ALDO1_V_CTRL_MASK	GENMASK(4, 0)
 206#define AXP806_ALDO2_V_CTRL_MASK	GENMASK(4, 0)
 207#define AXP806_ALDO3_V_CTRL_MASK	GENMASK(4, 0)
 208#define AXP806_BLDO1_V_CTRL_MASK	GENMASK(3, 0)
 209#define AXP806_BLDO2_V_CTRL_MASK	GENMASK(3, 0)
 210#define AXP806_BLDO3_V_CTRL_MASK	GENMASK(3, 0)
 211#define AXP806_BLDO4_V_CTRL_MASK	GENMASK(3, 0)
 212#define AXP806_CLDO1_V_CTRL_MASK	GENMASK(4, 0)
 213#define AXP806_CLDO2_V_CTRL_MASK	GENMASK(4, 0)
 214#define AXP806_CLDO3_V_CTRL_MASK	GENMASK(4, 0)
 215
 216#define AXP806_PWR_OUT_DCDCA_MASK	BIT_MASK(0)
 217#define AXP806_PWR_OUT_DCDCB_MASK	BIT_MASK(1)
 218#define AXP806_PWR_OUT_DCDCC_MASK	BIT_MASK(2)
 219#define AXP806_PWR_OUT_DCDCD_MASK	BIT_MASK(3)
 220#define AXP806_PWR_OUT_DCDCE_MASK	BIT_MASK(4)
 221#define AXP806_PWR_OUT_ALDO1_MASK	BIT_MASK(5)
 222#define AXP806_PWR_OUT_ALDO2_MASK	BIT_MASK(6)
 223#define AXP806_PWR_OUT_ALDO3_MASK	BIT_MASK(7)
 224#define AXP806_PWR_OUT_BLDO1_MASK	BIT_MASK(0)
 225#define AXP806_PWR_OUT_BLDO2_MASK	BIT_MASK(1)
 226#define AXP806_PWR_OUT_BLDO3_MASK	BIT_MASK(2)
 227#define AXP806_PWR_OUT_BLDO4_MASK	BIT_MASK(3)
 228#define AXP806_PWR_OUT_CLDO1_MASK	BIT_MASK(4)
 229#define AXP806_PWR_OUT_CLDO2_MASK	BIT_MASK(5)
 230#define AXP806_PWR_OUT_CLDO3_MASK	BIT_MASK(6)
 231#define AXP806_PWR_OUT_SW_MASK		BIT_MASK(7)
 232
 233#define AXP806_DCDCAB_POLYPHASE_DUAL	0x40
 234#define AXP806_DCDCABC_POLYPHASE_TRI	0x80
 235#define AXP806_DCDCABC_POLYPHASE_MASK	GENMASK(7, 6)
 236
 237#define AXP806_DCDCDE_POLYPHASE_DUAL	BIT(5)
 238
 239#define AXP806_DCDCA_600mV_START	0x00
 240#define AXP806_DCDCA_600mV_STEPS	50
 241#define AXP806_DCDCA_600mV_END		\
 242	(AXP806_DCDCA_600mV_START + AXP806_DCDCA_600mV_STEPS)
 243#define AXP806_DCDCA_1120mV_START	0x33
 244#define AXP806_DCDCA_1120mV_STEPS	20
 245#define AXP806_DCDCA_1120mV_END		\
 246	(AXP806_DCDCA_1120mV_START + AXP806_DCDCA_1120mV_STEPS)
 247#define AXP806_DCDCA_NUM_VOLTAGES	72
 248
 249#define AXP806_DCDCD_600mV_START	0x00
 250#define AXP806_DCDCD_600mV_STEPS	45
 251#define AXP806_DCDCD_600mV_END		\
 252	(AXP806_DCDCD_600mV_START + AXP806_DCDCD_600mV_STEPS)
 253#define AXP806_DCDCD_1600mV_START	0x2e
 254#define AXP806_DCDCD_1600mV_STEPS	17
 255#define AXP806_DCDCD_1600mV_END		\
 256	(AXP806_DCDCD_1600mV_START + AXP806_DCDCD_1600mV_STEPS)
 257#define AXP806_DCDCD_NUM_VOLTAGES	64
 258
 259#define AXP809_DCDC4_600mV_START	0x00
 260#define AXP809_DCDC4_600mV_STEPS	47
 261#define AXP809_DCDC4_600mV_END		\
 262	(AXP809_DCDC4_600mV_START + AXP809_DCDC4_600mV_STEPS)
 263#define AXP809_DCDC4_1800mV_START	0x30
 264#define AXP809_DCDC4_1800mV_STEPS	8
 265#define AXP809_DCDC4_1800mV_END		\
 266	(AXP809_DCDC4_1800mV_START + AXP809_DCDC4_1800mV_STEPS)
 267#define AXP809_DCDC4_NUM_VOLTAGES	57
 268
 269#define AXP813_DCDC7_V_OUT_MASK		GENMASK(6, 0)
 270
 271#define AXP813_PWR_OUT_DCDC7_MASK	BIT_MASK(6)
 272
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 273#define AXP_DESC_IO(_family, _id, _match, _supply, _min, _max, _step, _vreg,	\
 274		    _vmask, _ereg, _emask, _enable_val, _disable_val)		\
 275	[_family##_##_id] = {							\
 276		.name		= (_match),					\
 277		.supply_name	= (_supply),					\
 278		.of_match	= of_match_ptr(_match),				\
 279		.regulators_node = of_match_ptr("regulators"),			\
 280		.type		= REGULATOR_VOLTAGE,				\
 281		.id		= _family##_##_id,				\
 282		.n_voltages	= (((_max) - (_min)) / (_step) + 1),		\
 283		.owner		= THIS_MODULE,					\
 284		.min_uV		= (_min) * 1000,				\
 285		.uV_step	= (_step) * 1000,				\
 286		.vsel_reg	= (_vreg),					\
 287		.vsel_mask	= (_vmask),					\
 288		.enable_reg	= (_ereg),					\
 289		.enable_mask	= (_emask),					\
 290		.enable_val	= (_enable_val),				\
 291		.disable_val	= (_disable_val),				\
 292		.ops		= &axp20x_ops,					\
 293	}
 294
 295#define AXP_DESC(_family, _id, _match, _supply, _min, _max, _step, _vreg,	\
 296		 _vmask, _ereg, _emask) 					\
 297	[_family##_##_id] = {							\
 298		.name		= (_match),					\
 299		.supply_name	= (_supply),					\
 300		.of_match	= of_match_ptr(_match),				\
 301		.regulators_node = of_match_ptr("regulators"),			\
 302		.type		= REGULATOR_VOLTAGE,				\
 303		.id		= _family##_##_id,				\
 304		.n_voltages	= (((_max) - (_min)) / (_step) + 1),		\
 305		.owner		= THIS_MODULE,					\
 306		.min_uV		= (_min) * 1000,				\
 307		.uV_step	= (_step) * 1000,				\
 308		.vsel_reg	= (_vreg),					\
 309		.vsel_mask	= (_vmask),					\
 310		.enable_reg	= (_ereg),					\
 311		.enable_mask	= (_emask),					\
 312		.ops		= &axp20x_ops,					\
 313	}
 314
 315#define AXP_DESC_SW(_family, _id, _match, _supply, _ereg, _emask)		\
 316	[_family##_##_id] = {							\
 317		.name		= (_match),					\
 318		.supply_name	= (_supply),					\
 319		.of_match	= of_match_ptr(_match),				\
 320		.regulators_node = of_match_ptr("regulators"),			\
 321		.type		= REGULATOR_VOLTAGE,				\
 322		.id		= _family##_##_id,				\
 323		.owner		= THIS_MODULE,					\
 324		.enable_reg	= (_ereg),					\
 325		.enable_mask	= (_emask),					\
 326		.ops		= &axp20x_ops_sw,				\
 327	}
 328
 329#define AXP_DESC_FIXED(_family, _id, _match, _supply, _volt)			\
 330	[_family##_##_id] = {							\
 331		.name		= (_match),					\
 332		.supply_name	= (_supply),					\
 333		.of_match	= of_match_ptr(_match),				\
 334		.regulators_node = of_match_ptr("regulators"),			\
 335		.type		= REGULATOR_VOLTAGE,				\
 336		.id		= _family##_##_id,				\
 337		.n_voltages	= 1,						\
 338		.owner		= THIS_MODULE,					\
 339		.min_uV		= (_volt) * 1000,				\
 340		.ops		= &axp20x_ops_fixed				\
 341	}
 342
 343#define AXP_DESC_RANGES(_family, _id, _match, _supply, _ranges, _n_voltages,	\
 344			_vreg, _vmask, _ereg, _emask)				\
 345	[_family##_##_id] = {							\
 346		.name		= (_match),					\
 347		.supply_name	= (_supply),					\
 348		.of_match	= of_match_ptr(_match),				\
 349		.regulators_node = of_match_ptr("regulators"),			\
 350		.type		= REGULATOR_VOLTAGE,				\
 351		.id		= _family##_##_id,				\
 352		.n_voltages	= (_n_voltages),				\
 353		.owner		= THIS_MODULE,					\
 354		.vsel_reg	= (_vreg),					\
 355		.vsel_mask	= (_vmask),					\
 356		.enable_reg	= (_ereg),					\
 357		.enable_mask	= (_emask),					\
 358		.linear_ranges	= (_ranges),					\
 359		.n_linear_ranges = ARRAY_SIZE(_ranges),				\
 360		.ops		= &axp20x_ops_range,				\
 361	}
 362
 363static const int axp209_dcdc2_ldo3_slew_rates[] = {
 364	1600,
 365	 800,
 366};
 367
 368static int axp20x_set_ramp_delay(struct regulator_dev *rdev, int ramp)
 369{
 370	struct axp20x_dev *axp20x = rdev_get_drvdata(rdev);
 371	int id = rdev_get_id(rdev);
 372	u8 reg, mask, enable, cfg = 0xff;
 373	const int *slew_rates;
 374	int rate_count = 0;
 375
 376	switch (axp20x->variant) {
 377	case AXP209_ID:
 378		if (id == AXP20X_DCDC2) {
 379			slew_rates = axp209_dcdc2_ldo3_slew_rates;
 380			rate_count = ARRAY_SIZE(axp209_dcdc2_ldo3_slew_rates);
 381			reg = AXP20X_DCDC2_LDO3_V_RAMP;
 382			mask = AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_RATE_MASK |
 383			       AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_EN_MASK;
 384			enable = (ramp > 0) ?
 385				 AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_EN : 0;
 386			break;
 387		}
 388
 389		if (id == AXP20X_LDO3) {
 390			slew_rates = axp209_dcdc2_ldo3_slew_rates;
 391			rate_count = ARRAY_SIZE(axp209_dcdc2_ldo3_slew_rates);
 392			reg = AXP20X_DCDC2_LDO3_V_RAMP;
 393			mask = AXP20X_DCDC2_LDO3_V_RAMP_LDO3_RATE_MASK |
 394			       AXP20X_DCDC2_LDO3_V_RAMP_LDO3_EN_MASK;
 395			enable = (ramp > 0) ?
 396				 AXP20X_DCDC2_LDO3_V_RAMP_LDO3_EN : 0;
 397			break;
 398		}
 399
 400		if (rate_count > 0)
 401			break;
 402
 403		fallthrough;
 404	default:
 405		/* Not supported for this regulator */
 406		return -ENOTSUPP;
 407	}
 408
 409	if (ramp == 0) {
 410		cfg = enable;
 411	} else {
 412		int i;
 413
 414		for (i = 0; i < rate_count; i++) {
 415			if (ramp > slew_rates[i])
 416				break;
 417
 418			if (id == AXP20X_DCDC2)
 419				cfg = AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_RATE(i);
 420			else
 421				cfg = AXP20X_DCDC2_LDO3_V_RAMP_LDO3_RATE(i);
 422		}
 423
 424		if (cfg == 0xff) {
 425			dev_err(axp20x->dev, "unsupported ramp value %d", ramp);
 426			return -EINVAL;
 427		}
 428
 429		cfg |= enable;
 430	}
 431
 432	return regmap_update_bits(axp20x->regmap, reg, mask, cfg);
 433}
 434
 435static int axp20x_regulator_enable_regmap(struct regulator_dev *rdev)
 436{
 437	struct axp20x_dev *axp20x = rdev_get_drvdata(rdev);
 438	int id = rdev_get_id(rdev);
 439
 440	switch (axp20x->variant) {
 441	case AXP209_ID:
 442		if ((id == AXP20X_LDO3) &&
 443		    rdev->constraints && rdev->constraints->soft_start) {
 444			int v_out;
 445			int ret;
 446
 447			/*
 448			 * On some boards, the LDO3 can be overloaded when
 449			 * turning on, causing the entire PMIC to shutdown
 450			 * without warning. Turning it on at the minimal voltage
 451			 * and then setting the voltage to the requested value
 452			 * works reliably.
 453			 */
 454			if (regulator_is_enabled_regmap(rdev))
 455				break;
 456
 457			v_out = regulator_get_voltage_sel_regmap(rdev);
 458			if (v_out < 0)
 459				return v_out;
 460
 461			if (v_out == 0)
 462				break;
 463
 464			ret = regulator_set_voltage_sel_regmap(rdev, 0x00);
 465			/*
 466			 * A small pause is needed between
 467			 * setting the voltage and enabling the LDO to give the
 468			 * internal state machine time to process the request.
 469			 */
 470			usleep_range(1000, 5000);
 471			ret |= regulator_enable_regmap(rdev);
 472			ret |= regulator_set_voltage_sel_regmap(rdev, v_out);
 473
 474			return ret;
 475		}
 476		break;
 477	default:
 478		/* No quirks */
 479		break;
 480	}
 481
 482	return regulator_enable_regmap(rdev);
 483};
 484
 485static const struct regulator_ops axp20x_ops_fixed = {
 486	.list_voltage		= regulator_list_voltage_linear,
 487};
 488
 489static const struct regulator_ops axp20x_ops_range = {
 490	.set_voltage_sel	= regulator_set_voltage_sel_regmap,
 491	.get_voltage_sel	= regulator_get_voltage_sel_regmap,
 492	.list_voltage		= regulator_list_voltage_linear_range,
 493	.enable			= regulator_enable_regmap,
 494	.disable		= regulator_disable_regmap,
 495	.is_enabled		= regulator_is_enabled_regmap,
 496};
 497
 498static const struct regulator_ops axp20x_ops = {
 499	.set_voltage_sel	= regulator_set_voltage_sel_regmap,
 500	.get_voltage_sel	= regulator_get_voltage_sel_regmap,
 501	.list_voltage		= regulator_list_voltage_linear,
 502	.enable			= axp20x_regulator_enable_regmap,
 503	.disable		= regulator_disable_regmap,
 504	.is_enabled		= regulator_is_enabled_regmap,
 505	.set_ramp_delay		= axp20x_set_ramp_delay,
 506};
 507
 508static const struct regulator_ops axp20x_ops_sw = {
 509	.enable			= regulator_enable_regmap,
 510	.disable		= regulator_disable_regmap,
 511	.is_enabled		= regulator_is_enabled_regmap,
 512};
 513
 514static const struct linear_range axp20x_ldo4_ranges[] = {
 515	REGULATOR_LINEAR_RANGE(1250000,
 516			       AXP20X_LDO4_V_OUT_1250mV_START,
 517			       AXP20X_LDO4_V_OUT_1250mV_END,
 518			       0),
 519	REGULATOR_LINEAR_RANGE(1300000,
 520			       AXP20X_LDO4_V_OUT_1300mV_START,
 521			       AXP20X_LDO4_V_OUT_1300mV_END,
 522			       100000),
 523	REGULATOR_LINEAR_RANGE(2500000,
 524			       AXP20X_LDO4_V_OUT_2500mV_START,
 525			       AXP20X_LDO4_V_OUT_2500mV_END,
 526			       0),
 527	REGULATOR_LINEAR_RANGE(2700000,
 528			       AXP20X_LDO4_V_OUT_2700mV_START,
 529			       AXP20X_LDO4_V_OUT_2700mV_END,
 530			       100000),
 531	REGULATOR_LINEAR_RANGE(3000000,
 532			       AXP20X_LDO4_V_OUT_3000mV_START,
 533			       AXP20X_LDO4_V_OUT_3000mV_END,
 534			       100000),
 535};
 536
 537static const struct regulator_desc axp20x_regulators[] = {
 538	AXP_DESC(AXP20X, DCDC2, "dcdc2", "vin2", 700, 2275, 25,
 539		 AXP20X_DCDC2_V_OUT, AXP20X_DCDC2_V_OUT_MASK,
 540		 AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_DCDC2_MASK),
 541	AXP_DESC(AXP20X, DCDC3, "dcdc3", "vin3", 700, 3500, 25,
 542		 AXP20X_DCDC3_V_OUT, AXP20X_DCDC3_V_OUT_MASK,
 543		 AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_DCDC3_MASK),
 544	AXP_DESC_FIXED(AXP20X, LDO1, "ldo1", "acin", 1300),
 545	AXP_DESC(AXP20X, LDO2, "ldo2", "ldo24in", 1800, 3300, 100,
 546		 AXP20X_LDO24_V_OUT, AXP20X_LDO2_V_OUT_MASK,
 547		 AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_LDO2_MASK),
 548	AXP_DESC(AXP20X, LDO3, "ldo3", "ldo3in", 700, 3500, 25,
 549		 AXP20X_LDO3_V_OUT, AXP20X_LDO3_V_OUT_MASK,
 550		 AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_LDO3_MASK),
 551	AXP_DESC_RANGES(AXP20X, LDO4, "ldo4", "ldo24in",
 552			axp20x_ldo4_ranges, AXP20X_LDO4_V_OUT_NUM_VOLTAGES,
 553			AXP20X_LDO24_V_OUT, AXP20X_LDO4_V_OUT_MASK,
 554			AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_LDO4_MASK),
 555	AXP_DESC_IO(AXP20X, LDO5, "ldo5", "ldo5in", 1800, 3300, 100,
 556		    AXP20X_LDO5_V_OUT, AXP20X_LDO5_V_OUT_MASK,
 557		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
 558		    AXP20X_IO_ENABLED, AXP20X_IO_DISABLED),
 559};
 560
 561static const struct regulator_desc axp22x_regulators[] = {
 562	AXP_DESC(AXP22X, DCDC1, "dcdc1", "vin1", 1600, 3400, 100,
 563		 AXP22X_DCDC1_V_OUT, AXP22X_DCDC1_V_OUT_MASK,
 564		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC1_MASK),
 565	AXP_DESC(AXP22X, DCDC2, "dcdc2", "vin2", 600, 1540, 20,
 566		 AXP22X_DCDC2_V_OUT, AXP22X_DCDC2_V_OUT_MASK,
 567		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC2_MASK),
 568	AXP_DESC(AXP22X, DCDC3, "dcdc3", "vin3", 600, 1860, 20,
 569		 AXP22X_DCDC3_V_OUT, AXP22X_DCDC3_V_OUT_MASK,
 570		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC3_MASK),
 571	AXP_DESC(AXP22X, DCDC4, "dcdc4", "vin4", 600, 1540, 20,
 572		 AXP22X_DCDC4_V_OUT, AXP22X_DCDC4_V_OUT_MASK,
 573		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC4_MASK),
 574	AXP_DESC(AXP22X, DCDC5, "dcdc5", "vin5", 1000, 2550, 50,
 575		 AXP22X_DCDC5_V_OUT, AXP22X_DCDC5_V_OUT_MASK,
 576		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC5_MASK),
 577	/* secondary switchable output of DCDC1 */
 578	AXP_DESC_SW(AXP22X, DC1SW, "dc1sw", NULL,
 579		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DC1SW_MASK),
 580	/* LDO regulator internally chained to DCDC5 */
 581	AXP_DESC(AXP22X, DC5LDO, "dc5ldo", NULL, 700, 1400, 100,
 582		 AXP22X_DC5LDO_V_OUT, AXP22X_DC5LDO_V_OUT_MASK,
 583		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DC5LDO_MASK),
 584	AXP_DESC(AXP22X, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
 585		 AXP22X_ALDO1_V_OUT, AXP22X_ALDO1_V_OUT_MASK,
 586		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_ALDO1_MASK),
 587	AXP_DESC(AXP22X, ALDO2, "aldo2", "aldoin", 700, 3300, 100,
 588		 AXP22X_ALDO2_V_OUT, AXP22X_ALDO2_V_OUT_MASK,
 589		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_ALDO2_MASK),
 590	AXP_DESC(AXP22X, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
 591		 AXP22X_ALDO3_V_OUT, AXP22X_ALDO3_V_OUT_MASK,
 592		 AXP22X_PWR_OUT_CTRL3, AXP22X_PWR_OUT_ALDO3_MASK),
 593	AXP_DESC(AXP22X, DLDO1, "dldo1", "dldoin", 700, 3300, 100,
 594		 AXP22X_DLDO1_V_OUT, AXP22X_DLDO1_V_OUT_MASK,
 595		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO1_MASK),
 596	AXP_DESC(AXP22X, DLDO2, "dldo2", "dldoin", 700, 3300, 100,
 597		 AXP22X_DLDO2_V_OUT, AXP22X_DLDO2_V_OUT_MASK,
 598		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO2_MASK),
 599	AXP_DESC(AXP22X, DLDO3, "dldo3", "dldoin", 700, 3300, 100,
 600		 AXP22X_DLDO3_V_OUT, AXP22X_DLDO3_V_OUT_MASK,
 601		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO3_MASK),
 602	AXP_DESC(AXP22X, DLDO4, "dldo4", "dldoin", 700, 3300, 100,
 603		 AXP22X_DLDO4_V_OUT, AXP22X_DLDO4_V_OUT_MASK,
 604		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO4_MASK),
 605	AXP_DESC(AXP22X, ELDO1, "eldo1", "eldoin", 700, 3300, 100,
 606		 AXP22X_ELDO1_V_OUT, AXP22X_ELDO1_V_OUT_MASK,
 607		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO1_MASK),
 608	AXP_DESC(AXP22X, ELDO2, "eldo2", "eldoin", 700, 3300, 100,
 609		 AXP22X_ELDO2_V_OUT, AXP22X_ELDO2_V_OUT_MASK,
 610		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO2_MASK),
 611	AXP_DESC(AXP22X, ELDO3, "eldo3", "eldoin", 700, 3300, 100,
 612		 AXP22X_ELDO3_V_OUT, AXP22X_ELDO3_V_OUT_MASK,
 613		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO3_MASK),
 614	/* Note the datasheet only guarantees reliable operation up to
 615	 * 3.3V, this needs to be enforced via dts provided constraints */
 616	AXP_DESC_IO(AXP22X, LDO_IO0, "ldo_io0", "ips", 700, 3800, 100,
 617		    AXP22X_LDO_IO0_V_OUT, AXP22X_LDO_IO0_V_OUT_MASK,
 618		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
 619		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 620	/* Note the datasheet only guarantees reliable operation up to
 621	 * 3.3V, this needs to be enforced via dts provided constraints */
 622	AXP_DESC_IO(AXP22X, LDO_IO1, "ldo_io1", "ips", 700, 3800, 100,
 623		    AXP22X_LDO_IO1_V_OUT, AXP22X_LDO_IO1_V_OUT_MASK,
 624		    AXP20X_GPIO1_CTRL, AXP20X_GPIO1_FUNC_MASK,
 625		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 626	AXP_DESC_FIXED(AXP22X, RTC_LDO, "rtc_ldo", "ips", 3000),
 627};
 628
 629static const struct regulator_desc axp22x_drivevbus_regulator = {
 630	.name		= "drivevbus",
 631	.supply_name	= "drivevbus",
 632	.of_match	= of_match_ptr("drivevbus"),
 633	.regulators_node = of_match_ptr("regulators"),
 634	.type		= REGULATOR_VOLTAGE,
 635	.owner		= THIS_MODULE,
 636	.enable_reg	= AXP20X_VBUS_IPSOUT_MGMT,
 637	.enable_mask	= AXP20X_VBUS_IPSOUT_MGMT_MASK,
 638	.ops		= &axp20x_ops_sw,
 639};
 640
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 641/* DCDC ranges shared with AXP813 */
 642static const struct linear_range axp803_dcdc234_ranges[] = {
 643	REGULATOR_LINEAR_RANGE(500000,
 644			       AXP803_DCDC234_500mV_START,
 645			       AXP803_DCDC234_500mV_END,
 646			       10000),
 647	REGULATOR_LINEAR_RANGE(1220000,
 648			       AXP803_DCDC234_1220mV_START,
 649			       AXP803_DCDC234_1220mV_END,
 650			       20000),
 651};
 652
 653static const struct linear_range axp803_dcdc5_ranges[] = {
 654	REGULATOR_LINEAR_RANGE(800000,
 655			       AXP803_DCDC5_800mV_START,
 656			       AXP803_DCDC5_800mV_END,
 657			       10000),
 658	REGULATOR_LINEAR_RANGE(1140000,
 659			       AXP803_DCDC5_1140mV_START,
 660			       AXP803_DCDC5_1140mV_END,
 661			       20000),
 662};
 663
 664static const struct linear_range axp803_dcdc6_ranges[] = {
 665	REGULATOR_LINEAR_RANGE(600000,
 666			       AXP803_DCDC6_600mV_START,
 667			       AXP803_DCDC6_600mV_END,
 668			       10000),
 669	REGULATOR_LINEAR_RANGE(1120000,
 670			       AXP803_DCDC6_1120mV_START,
 671			       AXP803_DCDC6_1120mV_END,
 672			       20000),
 673};
 674
 675/* AXP806's CLDO2 and AXP809's DLDO1 share the same range */
 676static const struct linear_range axp803_dldo2_ranges[] = {
 677	REGULATOR_LINEAR_RANGE(700000,
 678			       AXP803_DLDO2_700mV_START,
 679			       AXP803_DLDO2_700mV_END,
 680			       100000),
 681	REGULATOR_LINEAR_RANGE(3400000,
 682			       AXP803_DLDO2_3400mV_START,
 683			       AXP803_DLDO2_3400mV_END,
 684			       200000),
 685};
 686
 687static const struct regulator_desc axp803_regulators[] = {
 688	AXP_DESC(AXP803, DCDC1, "dcdc1", "vin1", 1600, 3400, 100,
 689		 AXP803_DCDC1_V_OUT, AXP803_DCDC1_V_OUT_MASK,
 690		 AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC1_MASK),
 691	AXP_DESC_RANGES(AXP803, DCDC2, "dcdc2", "vin2",
 692			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
 693			AXP803_DCDC2_V_OUT, AXP803_DCDC2_V_OUT_MASK,
 694			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC2_MASK),
 695	AXP_DESC_RANGES(AXP803, DCDC3, "dcdc3", "vin3",
 696			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
 697			AXP803_DCDC3_V_OUT, AXP803_DCDC3_V_OUT_MASK,
 698			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC3_MASK),
 699	AXP_DESC_RANGES(AXP803, DCDC4, "dcdc4", "vin4",
 700			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
 701			AXP803_DCDC4_V_OUT, AXP803_DCDC4_V_OUT_MASK,
 702			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC4_MASK),
 703	AXP_DESC_RANGES(AXP803, DCDC5, "dcdc5", "vin5",
 704			axp803_dcdc5_ranges, AXP803_DCDC5_NUM_VOLTAGES,
 705			AXP803_DCDC5_V_OUT, AXP803_DCDC5_V_OUT_MASK,
 706			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC5_MASK),
 707	AXP_DESC_RANGES(AXP803, DCDC6, "dcdc6", "vin6",
 708			axp803_dcdc6_ranges, AXP803_DCDC6_NUM_VOLTAGES,
 709			AXP803_DCDC6_V_OUT, AXP803_DCDC6_V_OUT_MASK,
 710			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC6_MASK),
 711	/* secondary switchable output of DCDC1 */
 712	AXP_DESC_SW(AXP803, DC1SW, "dc1sw", NULL,
 713		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DC1SW_MASK),
 714	AXP_DESC(AXP803, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
 715		 AXP22X_ALDO1_V_OUT, AXP22X_ALDO1_V_OUT_MASK,
 716		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO1_MASK),
 717	AXP_DESC(AXP803, ALDO2, "aldo2", "aldoin", 700, 3300, 100,
 718		 AXP22X_ALDO2_V_OUT, AXP22X_ALDO2_V_OUT_MASK,
 719		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO2_MASK),
 720	AXP_DESC(AXP803, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
 721		 AXP22X_ALDO3_V_OUT, AXP22X_ALDO3_V_OUT_MASK,
 722		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO3_MASK),
 723	AXP_DESC(AXP803, DLDO1, "dldo1", "dldoin", 700, 3300, 100,
 724		 AXP22X_DLDO1_V_OUT, AXP22X_DLDO1_V_OUT_MASK,
 725		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO1_MASK),
 726	AXP_DESC_RANGES(AXP803, DLDO2, "dldo2", "dldoin",
 727			axp803_dldo2_ranges, AXP803_DLDO2_NUM_VOLTAGES,
 728			AXP22X_DLDO2_V_OUT, AXP22X_DLDO2_V_OUT_MASK,
 729			AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO2_MASK),
 730	AXP_DESC(AXP803, DLDO3, "dldo3", "dldoin", 700, 3300, 100,
 731		 AXP22X_DLDO3_V_OUT, AXP22X_DLDO3_V_OUT_MASK,
 732		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO3_MASK),
 733	AXP_DESC(AXP803, DLDO4, "dldo4", "dldoin", 700, 3300, 100,
 734		 AXP22X_DLDO4_V_OUT, AXP22X_DLDO4_V_OUT_MASK,
 735		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO4_MASK),
 736	AXP_DESC(AXP803, ELDO1, "eldo1", "eldoin", 700, 1900, 50,
 737		 AXP22X_ELDO1_V_OUT, AXP22X_ELDO1_V_OUT_MASK,
 738		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO1_MASK),
 739	AXP_DESC(AXP803, ELDO2, "eldo2", "eldoin", 700, 1900, 50,
 740		 AXP22X_ELDO2_V_OUT, AXP22X_ELDO2_V_OUT_MASK,
 741		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO2_MASK),
 742	AXP_DESC(AXP803, ELDO3, "eldo3", "eldoin", 700, 1900, 50,
 743		 AXP22X_ELDO3_V_OUT, AXP22X_ELDO3_V_OUT_MASK,
 744		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO3_MASK),
 745	AXP_DESC(AXP803, FLDO1, "fldo1", "fldoin", 700, 1450, 50,
 746		 AXP803_FLDO1_V_OUT, AXP803_FLDO1_V_OUT_MASK,
 747		 AXP22X_PWR_OUT_CTRL3, AXP803_PWR_OUT_FLDO1_MASK),
 748	AXP_DESC(AXP803, FLDO2, "fldo2", "fldoin", 700, 1450, 50,
 749		 AXP803_FLDO2_V_OUT, AXP803_FLDO2_V_OUT_MASK,
 750		 AXP22X_PWR_OUT_CTRL3, AXP803_PWR_OUT_FLDO2_MASK),
 751	AXP_DESC_IO(AXP803, LDO_IO0, "ldo-io0", "ips", 700, 3300, 100,
 752		    AXP22X_LDO_IO0_V_OUT, AXP22X_LDO_IO0_V_OUT_MASK,
 753		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
 754		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 755	AXP_DESC_IO(AXP803, LDO_IO1, "ldo-io1", "ips", 700, 3300, 100,
 756		    AXP22X_LDO_IO1_V_OUT, AXP22X_LDO_IO1_V_OUT_MASK,
 757		    AXP20X_GPIO1_CTRL, AXP20X_GPIO1_FUNC_MASK,
 758		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 759	AXP_DESC_FIXED(AXP803, RTC_LDO, "rtc-ldo", "ips", 3000),
 760};
 761
 762static const struct linear_range axp806_dcdca_ranges[] = {
 763	REGULATOR_LINEAR_RANGE(600000,
 764			       AXP806_DCDCA_600mV_START,
 765			       AXP806_DCDCA_600mV_END,
 766			       10000),
 767	REGULATOR_LINEAR_RANGE(1120000,
 768			       AXP806_DCDCA_1120mV_START,
 769			       AXP806_DCDCA_1120mV_END,
 770			       20000),
 771};
 772
 773static const struct linear_range axp806_dcdcd_ranges[] = {
 774	REGULATOR_LINEAR_RANGE(600000,
 775			       AXP806_DCDCD_600mV_START,
 776			       AXP806_DCDCD_600mV_END,
 777			       20000),
 778	REGULATOR_LINEAR_RANGE(1600000,
 779			       AXP806_DCDCD_1600mV_START,
 780			       AXP806_DCDCD_1600mV_END,
 781			       100000),
 782};
 783
 784static const struct regulator_desc axp806_regulators[] = {
 785	AXP_DESC_RANGES(AXP806, DCDCA, "dcdca", "vina",
 786			axp806_dcdca_ranges, AXP806_DCDCA_NUM_VOLTAGES,
 787			AXP806_DCDCA_V_CTRL, AXP806_DCDCA_V_CTRL_MASK,
 788			AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCA_MASK),
 789	AXP_DESC(AXP806, DCDCB, "dcdcb", "vinb", 1000, 2550, 50,
 790		 AXP806_DCDCB_V_CTRL, AXP806_DCDCB_V_CTRL_MASK,
 791		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCB_MASK),
 792	AXP_DESC_RANGES(AXP806, DCDCC, "dcdcc", "vinc",
 793			axp806_dcdca_ranges, AXP806_DCDCA_NUM_VOLTAGES,
 794			AXP806_DCDCC_V_CTRL, AXP806_DCDCC_V_CTRL_MASK,
 795			AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCC_MASK),
 796	AXP_DESC_RANGES(AXP806, DCDCD, "dcdcd", "vind",
 797			axp806_dcdcd_ranges, AXP806_DCDCD_NUM_VOLTAGES,
 798			AXP806_DCDCD_V_CTRL, AXP806_DCDCD_V_CTRL_MASK,
 799			AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCD_MASK),
 800	AXP_DESC(AXP806, DCDCE, "dcdce", "vine", 1100, 3400, 100,
 801		 AXP806_DCDCE_V_CTRL, AXP806_DCDCE_V_CTRL_MASK,
 802		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCE_MASK),
 803	AXP_DESC(AXP806, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
 804		 AXP806_ALDO1_V_CTRL, AXP806_ALDO1_V_CTRL_MASK,
 805		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_ALDO1_MASK),
 806	AXP_DESC(AXP806, ALDO2, "aldo2", "aldoin", 700, 3400, 100,
 807		 AXP806_ALDO2_V_CTRL, AXP806_ALDO2_V_CTRL_MASK,
 808		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_ALDO2_MASK),
 809	AXP_DESC(AXP806, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
 810		 AXP806_ALDO3_V_CTRL, AXP806_ALDO3_V_CTRL_MASK,
 811		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_ALDO3_MASK),
 812	AXP_DESC(AXP806, BLDO1, "bldo1", "bldoin", 700, 1900, 100,
 813		 AXP806_BLDO1_V_CTRL, AXP806_BLDO1_V_CTRL_MASK,
 814		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_BLDO1_MASK),
 815	AXP_DESC(AXP806, BLDO2, "bldo2", "bldoin", 700, 1900, 100,
 816		 AXP806_BLDO2_V_CTRL, AXP806_BLDO2_V_CTRL_MASK,
 817		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_BLDO2_MASK),
 818	AXP_DESC(AXP806, BLDO3, "bldo3", "bldoin", 700, 1900, 100,
 819		 AXP806_BLDO3_V_CTRL, AXP806_BLDO3_V_CTRL_MASK,
 820		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_BLDO3_MASK),
 821	AXP_DESC(AXP806, BLDO4, "bldo4", "bldoin", 700, 1900, 100,
 822		 AXP806_BLDO4_V_CTRL, AXP806_BLDO4_V_CTRL_MASK,
 823		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_BLDO4_MASK),
 824	AXP_DESC(AXP806, CLDO1, "cldo1", "cldoin", 700, 3300, 100,
 825		 AXP806_CLDO1_V_CTRL, AXP806_CLDO1_V_CTRL_MASK,
 826		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_CLDO1_MASK),
 827	AXP_DESC_RANGES(AXP806, CLDO2, "cldo2", "cldoin",
 828			axp803_dldo2_ranges, AXP803_DLDO2_NUM_VOLTAGES,
 829			AXP806_CLDO2_V_CTRL, AXP806_CLDO2_V_CTRL_MASK,
 830			AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_CLDO2_MASK),
 831	AXP_DESC(AXP806, CLDO3, "cldo3", "cldoin", 700, 3300, 100,
 832		 AXP806_CLDO3_V_CTRL, AXP806_CLDO3_V_CTRL_MASK,
 833		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_CLDO3_MASK),
 834	AXP_DESC_SW(AXP806, SW, "sw", "swin",
 835		    AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_SW_MASK),
 836};
 837
 838static const struct linear_range axp809_dcdc4_ranges[] = {
 839	REGULATOR_LINEAR_RANGE(600000,
 840			       AXP809_DCDC4_600mV_START,
 841			       AXP809_DCDC4_600mV_END,
 842			       20000),
 843	REGULATOR_LINEAR_RANGE(1800000,
 844			       AXP809_DCDC4_1800mV_START,
 845			       AXP809_DCDC4_1800mV_END,
 846			       100000),
 847};
 848
 849static const struct regulator_desc axp809_regulators[] = {
 850	AXP_DESC(AXP809, DCDC1, "dcdc1", "vin1", 1600, 3400, 100,
 851		 AXP22X_DCDC1_V_OUT, AXP22X_DCDC1_V_OUT_MASK,
 852		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC1_MASK),
 853	AXP_DESC(AXP809, DCDC2, "dcdc2", "vin2", 600, 1540, 20,
 854		 AXP22X_DCDC2_V_OUT, AXP22X_DCDC2_V_OUT_MASK,
 855		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC2_MASK),
 856	AXP_DESC(AXP809, DCDC3, "dcdc3", "vin3", 600, 1860, 20,
 857		 AXP22X_DCDC3_V_OUT, AXP22X_DCDC3_V_OUT_MASK,
 858		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC3_MASK),
 859	AXP_DESC_RANGES(AXP809, DCDC4, "dcdc4", "vin4",
 860			axp809_dcdc4_ranges, AXP809_DCDC4_NUM_VOLTAGES,
 861			AXP22X_DCDC4_V_OUT, AXP22X_DCDC4_V_OUT_MASK,
 862			AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC4_MASK),
 863	AXP_DESC(AXP809, DCDC5, "dcdc5", "vin5", 1000, 2550, 50,
 864		 AXP22X_DCDC5_V_OUT, AXP22X_DCDC5_V_OUT_MASK,
 865		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC5_MASK),
 866	/* secondary switchable output of DCDC1 */
 867	AXP_DESC_SW(AXP809, DC1SW, "dc1sw", NULL,
 868		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DC1SW_MASK),
 869	/* LDO regulator internally chained to DCDC5 */
 870	AXP_DESC(AXP809, DC5LDO, "dc5ldo", NULL, 700, 1400, 100,
 871		 AXP22X_DC5LDO_V_OUT, AXP22X_DC5LDO_V_OUT_MASK,
 872		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DC5LDO_MASK),
 873	AXP_DESC(AXP809, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
 874		 AXP22X_ALDO1_V_OUT, AXP22X_ALDO1_V_OUT_MASK,
 875		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_ALDO1_MASK),
 876	AXP_DESC(AXP809, ALDO2, "aldo2", "aldoin", 700, 3300, 100,
 877		 AXP22X_ALDO2_V_OUT, AXP22X_ALDO2_V_OUT_MASK,
 878		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_ALDO2_MASK),
 879	AXP_DESC(AXP809, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
 880		 AXP22X_ALDO3_V_OUT, AXP22X_ALDO3_V_OUT_MASK,
 881		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ALDO3_MASK),
 882	AXP_DESC_RANGES(AXP809, DLDO1, "dldo1", "dldoin",
 883			axp803_dldo2_ranges, AXP803_DLDO2_NUM_VOLTAGES,
 884			AXP22X_DLDO1_V_OUT, AXP22X_DLDO1_V_OUT_MASK,
 885			AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO1_MASK),
 886	AXP_DESC(AXP809, DLDO2, "dldo2", "dldoin", 700, 3300, 100,
 887		 AXP22X_DLDO2_V_OUT, AXP22X_DLDO2_V_OUT_MASK,
 888		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO2_MASK),
 889	AXP_DESC(AXP809, ELDO1, "eldo1", "eldoin", 700, 3300, 100,
 890		 AXP22X_ELDO1_V_OUT, AXP22X_ELDO1_V_OUT_MASK,
 891		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO1_MASK),
 892	AXP_DESC(AXP809, ELDO2, "eldo2", "eldoin", 700, 3300, 100,
 893		 AXP22X_ELDO2_V_OUT, AXP22X_ELDO2_V_OUT_MASK,
 894		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO2_MASK),
 895	AXP_DESC(AXP809, ELDO3, "eldo3", "eldoin", 700, 3300, 100,
 896		 AXP22X_ELDO3_V_OUT, AXP22X_ELDO3_V_OUT_MASK,
 897		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO3_MASK),
 898	/*
 899	 * Note the datasheet only guarantees reliable operation up to
 900	 * 3.3V, this needs to be enforced via dts provided constraints
 901	 */
 902	AXP_DESC_IO(AXP809, LDO_IO0, "ldo_io0", "ips", 700, 3800, 100,
 903		    AXP22X_LDO_IO0_V_OUT, AXP22X_LDO_IO0_V_OUT_MASK,
 904		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
 905		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 906	/*
 907	 * Note the datasheet only guarantees reliable operation up to
 908	 * 3.3V, this needs to be enforced via dts provided constraints
 909	 */
 910	AXP_DESC_IO(AXP809, LDO_IO1, "ldo_io1", "ips", 700, 3800, 100,
 911		    AXP22X_LDO_IO1_V_OUT, AXP22X_LDO_IO1_V_OUT_MASK,
 912		    AXP20X_GPIO1_CTRL, AXP20X_GPIO1_FUNC_MASK,
 913		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 914	AXP_DESC_FIXED(AXP809, RTC_LDO, "rtc_ldo", "ips", 1800),
 915	AXP_DESC_SW(AXP809, SW, "sw", "swin",
 916		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_SW_MASK),
 917};
 918
 919static const struct regulator_desc axp813_regulators[] = {
 920	AXP_DESC(AXP813, DCDC1, "dcdc1", "vin1", 1600, 3400, 100,
 921		 AXP803_DCDC1_V_OUT, AXP803_DCDC1_V_OUT_MASK,
 922		 AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC1_MASK),
 923	AXP_DESC_RANGES(AXP813, DCDC2, "dcdc2", "vin2",
 924			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
 925			AXP803_DCDC2_V_OUT, AXP803_DCDC2_V_OUT_MASK,
 926			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC2_MASK),
 927	AXP_DESC_RANGES(AXP813, DCDC3, "dcdc3", "vin3",
 928			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
 929			AXP803_DCDC3_V_OUT, AXP803_DCDC3_V_OUT_MASK,
 930			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC3_MASK),
 931	AXP_DESC_RANGES(AXP813, DCDC4, "dcdc4", "vin4",
 932			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
 933			AXP803_DCDC4_V_OUT, AXP803_DCDC4_V_OUT_MASK,
 934			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC4_MASK),
 935	AXP_DESC_RANGES(AXP813, DCDC5, "dcdc5", "vin5",
 936			axp803_dcdc5_ranges, AXP803_DCDC5_NUM_VOLTAGES,
 937			AXP803_DCDC5_V_OUT, AXP803_DCDC5_V_OUT_MASK,
 938			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC5_MASK),
 939	AXP_DESC_RANGES(AXP813, DCDC6, "dcdc6", "vin6",
 940			axp803_dcdc6_ranges, AXP803_DCDC6_NUM_VOLTAGES,
 941			AXP803_DCDC6_V_OUT, AXP803_DCDC6_V_OUT_MASK,
 942			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC6_MASK),
 943	AXP_DESC_RANGES(AXP813, DCDC7, "dcdc7", "vin7",
 944			axp803_dcdc6_ranges, AXP803_DCDC6_NUM_VOLTAGES,
 945			AXP813_DCDC7_V_OUT, AXP813_DCDC7_V_OUT_MASK,
 946			AXP22X_PWR_OUT_CTRL1, AXP813_PWR_OUT_DCDC7_MASK),
 947	AXP_DESC(AXP813, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
 948		 AXP22X_ALDO1_V_OUT, AXP22X_ALDO1_V_OUT_MASK,
 949		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO1_MASK),
 950	AXP_DESC(AXP813, ALDO2, "aldo2", "aldoin", 700, 3300, 100,
 951		 AXP22X_ALDO2_V_OUT, AXP22X_ALDO2_V_OUT_MASK,
 952		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO2_MASK),
 953	AXP_DESC(AXP813, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
 954		 AXP22X_ALDO3_V_OUT, AXP22X_ALDO3_V_OUT_MASK,
 955		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO3_MASK),
 956	AXP_DESC(AXP813, DLDO1, "dldo1", "dldoin", 700, 3300, 100,
 957		 AXP22X_DLDO1_V_OUT, AXP22X_DLDO1_V_OUT_MASK,
 958		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO1_MASK),
 959	AXP_DESC_RANGES(AXP813, DLDO2, "dldo2", "dldoin",
 960			axp803_dldo2_ranges, AXP803_DLDO2_NUM_VOLTAGES,
 961			AXP22X_DLDO2_V_OUT, AXP22X_DLDO2_V_OUT_MASK,
 962			AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO2_MASK),
 963	AXP_DESC(AXP813, DLDO3, "dldo3", "dldoin", 700, 3300, 100,
 964		 AXP22X_DLDO3_V_OUT, AXP22X_DLDO3_V_OUT_MASK,
 965		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO3_MASK),
 966	AXP_DESC(AXP813, DLDO4, "dldo4", "dldoin", 700, 3300, 100,
 967		 AXP22X_DLDO4_V_OUT, AXP22X_DLDO4_V_OUT_MASK,
 968		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO4_MASK),
 969	AXP_DESC(AXP813, ELDO1, "eldo1", "eldoin", 700, 1900, 50,
 970		 AXP22X_ELDO1_V_OUT, AXP22X_ELDO1_V_OUT_MASK,
 971		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO1_MASK),
 972	AXP_DESC(AXP813, ELDO2, "eldo2", "eldoin", 700, 1900, 50,
 973		 AXP22X_ELDO2_V_OUT, AXP22X_ELDO2_V_OUT_MASK,
 974		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO2_MASK),
 975	AXP_DESC(AXP813, ELDO3, "eldo3", "eldoin", 700, 1900, 50,
 976		 AXP22X_ELDO3_V_OUT, AXP22X_ELDO3_V_OUT_MASK,
 977		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO3_MASK),
 978	/* to do / check ... */
 979	AXP_DESC(AXP813, FLDO1, "fldo1", "fldoin", 700, 1450, 50,
 980		 AXP803_FLDO1_V_OUT, AXP803_FLDO1_V_OUT_MASK,
 981		 AXP22X_PWR_OUT_CTRL3, AXP803_PWR_OUT_FLDO1_MASK),
 982	AXP_DESC(AXP813, FLDO2, "fldo2", "fldoin", 700, 1450, 50,
 983		 AXP803_FLDO2_V_OUT, AXP803_FLDO2_V_OUT_MASK,
 984		 AXP22X_PWR_OUT_CTRL3, AXP803_PWR_OUT_FLDO2_MASK),
 985	/*
 986	 * TODO: FLDO3 = {DCDC5, FLDOIN} / 2
 987	 *
 988	 * This means FLDO3 effectively switches supplies at runtime,
 989	 * something the regulator subsystem does not support.
 990	 */
 991	AXP_DESC_FIXED(AXP813, RTC_LDO, "rtc-ldo", "ips", 1800),
 992	AXP_DESC_IO(AXP813, LDO_IO0, "ldo-io0", "ips", 700, 3300, 100,
 993		    AXP22X_LDO_IO0_V_OUT, AXP22X_LDO_IO0_V_OUT_MASK,
 994		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
 995		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 996	AXP_DESC_IO(AXP813, LDO_IO1, "ldo-io1", "ips", 700, 3300, 100,
 997		    AXP22X_LDO_IO1_V_OUT, AXP22X_LDO_IO1_V_OUT_MASK,
 998		    AXP20X_GPIO1_CTRL, AXP20X_GPIO1_FUNC_MASK,
 999		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
1000	AXP_DESC_SW(AXP813, SW, "sw", "swin",
1001		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DC1SW_MASK),
1002};
1003
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1004static int axp20x_set_dcdc_freq(struct platform_device *pdev, u32 dcdcfreq)
1005{
1006	struct axp20x_dev *axp20x = dev_get_drvdata(pdev->dev.parent);
1007	unsigned int reg = AXP20X_DCDC_FREQ;
1008	u32 min, max, def, step;
1009
1010	switch (axp20x->variant) {
1011	case AXP202_ID:
1012	case AXP209_ID:
1013		min = 750;
1014		max = 1875;
1015		def = 1500;
1016		step = 75;
1017		break;
1018	case AXP803_ID:
1019	case AXP813_ID:
1020		/*
1021		 * AXP803/AXP813 DCDC work frequency setting has the same
1022		 * range and step as AXP22X, but at a different register.
1023		 * (See include/linux/mfd/axp20x.h)
1024		 */
1025		reg = AXP803_DCDC_FREQ_CTRL;
1026		fallthrough;	/* to the check below */
1027	case AXP806_ID:
1028		/*
1029		 * AXP806 also have DCDC work frequency setting register at a
1030		 * different position.
1031		 */
1032		if (axp20x->variant == AXP806_ID)
1033			reg = AXP806_DCDC_FREQ_CTRL;
1034		fallthrough;
1035	case AXP221_ID:
1036	case AXP223_ID:
1037	case AXP809_ID:
1038		min = 1800;
1039		max = 4050;
1040		def = 3000;
1041		step = 150;
1042		break;
 
 
 
 
 
 
 
 
 
 
1043	default:
1044		dev_err(&pdev->dev,
1045			"Setting DCDC frequency for unsupported AXP variant\n");
1046		return -EINVAL;
1047	}
1048
1049	if (dcdcfreq == 0)
1050		dcdcfreq = def;
1051
1052	if (dcdcfreq < min) {
1053		dcdcfreq = min;
1054		dev_warn(&pdev->dev, "DCDC frequency too low. Set to %ukHz\n",
1055			 min);
1056	}
1057
1058	if (dcdcfreq > max) {
1059		dcdcfreq = max;
1060		dev_warn(&pdev->dev, "DCDC frequency too high. Set to %ukHz\n",
1061			 max);
1062	}
1063
1064	dcdcfreq = (dcdcfreq - min) / step;
1065
1066	return regmap_update_bits(axp20x->regmap, reg,
1067				  AXP20X_FREQ_DCDC_MASK, dcdcfreq);
1068}
1069
1070static int axp20x_regulator_parse_dt(struct platform_device *pdev)
1071{
1072	struct device_node *np, *regulators;
1073	int ret = 0;
1074	u32 dcdcfreq = 0;
1075
1076	np = of_node_get(pdev->dev.parent->of_node);
1077	if (!np)
1078		return 0;
1079
1080	regulators = of_get_child_by_name(np, "regulators");
1081	if (!regulators) {
1082		dev_warn(&pdev->dev, "regulators node not found\n");
1083	} else {
1084		of_property_read_u32(regulators, "x-powers,dcdc-freq", &dcdcfreq);
1085		ret = axp20x_set_dcdc_freq(pdev, dcdcfreq);
1086		if (ret < 0) {
1087			dev_err(&pdev->dev, "Error setting dcdc frequency: %d\n", ret);
1088		}
1089		of_node_put(regulators);
1090	}
1091
1092	of_node_put(np);
1093	return ret;
1094}
1095
1096static int axp20x_set_dcdc_workmode(struct regulator_dev *rdev, int id, u32 workmode)
1097{
1098	struct axp20x_dev *axp20x = rdev_get_drvdata(rdev);
1099	unsigned int reg = AXP20X_DCDC_MODE;
1100	unsigned int mask;
1101
1102	switch (axp20x->variant) {
1103	case AXP202_ID:
1104	case AXP209_ID:
1105		if ((id != AXP20X_DCDC2) && (id != AXP20X_DCDC3))
1106			return -EINVAL;
1107
1108		mask = AXP20X_WORKMODE_DCDC2_MASK;
1109		if (id == AXP20X_DCDC3)
1110			mask = AXP20X_WORKMODE_DCDC3_MASK;
1111
1112		workmode <<= ffs(mask) - 1;
1113		break;
1114
1115	case AXP806_ID:
1116		/*
1117		 * AXP806 DCDC regulator IDs have the same range as AXP22X.
1118		 * (See include/linux/mfd/axp20x.h)
1119		 */
1120		reg = AXP806_DCDC_MODE_CTRL2;
1121		fallthrough;	/* to the check below */
1122	case AXP221_ID:
1123	case AXP223_ID:
1124	case AXP809_ID:
1125		if (id < AXP22X_DCDC1 || id > AXP22X_DCDC5)
1126			return -EINVAL;
1127
1128		mask = AXP22X_WORKMODE_DCDCX_MASK(id - AXP22X_DCDC1);
1129		workmode <<= id - AXP22X_DCDC1;
1130		break;
1131
1132	case AXP803_ID:
1133		if (id < AXP803_DCDC1 || id > AXP803_DCDC6)
1134			return -EINVAL;
1135
1136		mask = AXP22X_WORKMODE_DCDCX_MASK(id - AXP803_DCDC1);
1137		workmode <<= id - AXP803_DCDC1;
1138		break;
1139
1140	case AXP813_ID:
1141		if (id < AXP813_DCDC1 || id > AXP813_DCDC7)
1142			return -EINVAL;
1143
1144		mask = AXP22X_WORKMODE_DCDCX_MASK(id - AXP813_DCDC1);
1145		workmode <<= id - AXP813_DCDC1;
1146		break;
1147
 
 
 
 
 
 
 
 
 
1148	default:
1149		/* should not happen */
1150		WARN_ON(1);
1151		return -EINVAL;
1152	}
1153
1154	return regmap_update_bits(rdev->regmap, reg, mask, workmode);
1155}
1156
1157/*
1158 * This function checks whether a regulator is part of a poly-phase
1159 * output setup based on the registers settings. Returns true if it is.
1160 */
1161static bool axp20x_is_polyphase_slave(struct axp20x_dev *axp20x, int id)
1162{
1163	u32 reg = 0;
1164
1165	/*
1166	 * Currently in our supported AXP variants, only AXP803, AXP806,
1167	 * and AXP813 have polyphase regulators.
1168	 */
1169	switch (axp20x->variant) {
1170	case AXP803_ID:
1171	case AXP813_ID:
1172		regmap_read(axp20x->regmap, AXP803_POLYPHASE_CTRL, &reg);
1173
1174		switch (id) {
1175		case AXP803_DCDC3:
1176			return !!(reg & AXP803_DCDC23_POLYPHASE_DUAL);
1177		case AXP803_DCDC6:
1178			return !!(reg & AXP803_DCDC56_POLYPHASE_DUAL);
1179		}
1180		break;
1181
1182	case AXP806_ID:
1183		regmap_read(axp20x->regmap, AXP806_DCDC_MODE_CTRL2, &reg);
1184
1185		switch (id) {
1186		case AXP806_DCDCB:
1187			return (((reg & AXP806_DCDCABC_POLYPHASE_MASK) ==
1188				AXP806_DCDCAB_POLYPHASE_DUAL) ||
1189				((reg & AXP806_DCDCABC_POLYPHASE_MASK) ==
1190				AXP806_DCDCABC_POLYPHASE_TRI));
1191		case AXP806_DCDCC:
1192			return ((reg & AXP806_DCDCABC_POLYPHASE_MASK) ==
1193				AXP806_DCDCABC_POLYPHASE_TRI);
1194		case AXP806_DCDCE:
1195			return !!(reg & AXP806_DCDCDE_POLYPHASE_DUAL);
1196		}
1197		break;
1198
 
 
 
 
 
 
 
 
 
 
 
1199	default:
1200		return false;
1201	}
1202
1203	return false;
1204}
1205
1206static int axp20x_regulator_probe(struct platform_device *pdev)
1207{
1208	struct regulator_dev *rdev;
1209	struct axp20x_dev *axp20x = dev_get_drvdata(pdev->dev.parent);
1210	const struct regulator_desc *regulators;
1211	struct regulator_config config = {
1212		.dev = pdev->dev.parent,
1213		.regmap = axp20x->regmap,
1214		.driver_data = axp20x,
1215	};
1216	int ret, i, nregulators;
1217	u32 workmode;
1218	const char *dcdc1_name = axp22x_regulators[AXP22X_DCDC1].name;
1219	const char *dcdc5_name = axp22x_regulators[AXP22X_DCDC5].name;
 
1220	bool drivevbus = false;
1221
1222	switch (axp20x->variant) {
1223	case AXP202_ID:
1224	case AXP209_ID:
1225		regulators = axp20x_regulators;
1226		nregulators = AXP20X_REG_ID_MAX;
1227		break;
1228	case AXP221_ID:
1229	case AXP223_ID:
1230		regulators = axp22x_regulators;
1231		nregulators = AXP22X_REG_ID_MAX;
1232		drivevbus = of_property_read_bool(pdev->dev.parent->of_node,
1233						  "x-powers,drive-vbus-en");
1234		break;
 
 
 
 
1235	case AXP803_ID:
1236		regulators = axp803_regulators;
1237		nregulators = AXP803_REG_ID_MAX;
1238		drivevbus = of_property_read_bool(pdev->dev.parent->of_node,
1239						  "x-powers,drive-vbus-en");
1240		break;
1241	case AXP806_ID:
1242		regulators = axp806_regulators;
1243		nregulators = AXP806_REG_ID_MAX;
1244		break;
1245	case AXP809_ID:
1246		regulators = axp809_regulators;
1247		nregulators = AXP809_REG_ID_MAX;
1248		break;
1249	case AXP813_ID:
1250		regulators = axp813_regulators;
1251		nregulators = AXP813_REG_ID_MAX;
1252		drivevbus = of_property_read_bool(pdev->dev.parent->of_node,
1253						  "x-powers,drive-vbus-en");
1254		break;
 
 
 
 
1255	default:
1256		dev_err(&pdev->dev, "Unsupported AXP variant: %ld\n",
1257			axp20x->variant);
1258		return -EINVAL;
1259	}
1260
1261	/* This only sets the dcdc freq. Ignore any errors */
1262	axp20x_regulator_parse_dt(pdev);
1263
1264	for (i = 0; i < nregulators; i++) {
1265		const struct regulator_desc *desc = &regulators[i];
1266		struct regulator_desc *new_desc;
1267
1268		/*
1269		 * If this regulator is a slave in a poly-phase setup,
1270		 * skip it, as its controls are bound to the master
1271		 * regulator and won't work.
1272		 */
1273		if (axp20x_is_polyphase_slave(axp20x, i))
1274			continue;
1275
1276		/* Support for AXP813's FLDO3 is not implemented */
1277		if (axp20x->variant == AXP813_ID && i == AXP813_FLDO3)
1278			continue;
1279
1280		/*
1281		 * Regulators DC1SW and DC5LDO are connected internally,
1282		 * so we have to handle their supply names separately.
 
1283		 *
1284		 * We always register the regulators in proper sequence,
1285		 * so the supply names are correctly read. See the last
1286		 * part of this loop to see where we save the DT defined
1287		 * name.
1288		 */
1289		if ((regulators == axp22x_regulators && i == AXP22X_DC1SW) ||
1290		    (regulators == axp803_regulators && i == AXP803_DC1SW) ||
1291		    (regulators == axp809_regulators && i == AXP809_DC1SW)) {
 
1292			new_desc = devm_kzalloc(&pdev->dev, sizeof(*desc),
1293						GFP_KERNEL);
1294			if (!new_desc)
1295				return -ENOMEM;
1296
1297			*new_desc = regulators[i];
1298			new_desc->supply_name = dcdc1_name;
1299			desc = new_desc;
1300		}
1301
1302		if ((regulators == axp22x_regulators && i == AXP22X_DC5LDO) ||
1303		    (regulators == axp809_regulators && i == AXP809_DC5LDO)) {
 
1304			new_desc = devm_kzalloc(&pdev->dev, sizeof(*desc),
1305						GFP_KERNEL);
1306			if (!new_desc)
1307				return -ENOMEM;
1308
1309			*new_desc = regulators[i];
1310			new_desc->supply_name = dcdc5_name;
1311			desc = new_desc;
1312		}
1313
 
 
 
 
 
 
 
 
 
 
 
 
1314		rdev = devm_regulator_register(&pdev->dev, desc, &config);
1315		if (IS_ERR(rdev)) {
1316			dev_err(&pdev->dev, "Failed to register %s\n",
1317				regulators[i].name);
1318
1319			return PTR_ERR(rdev);
1320		}
1321
1322		ret = of_property_read_u32(rdev->dev.of_node,
1323					   "x-powers,dcdc-workmode",
1324					   &workmode);
1325		if (!ret) {
1326			if (axp20x_set_dcdc_workmode(rdev, i, workmode))
1327				dev_err(&pdev->dev, "Failed to set workmode on %s\n",
1328					rdev->desc->name);
1329		}
1330
1331		/*
1332		 * Save AXP22X DCDC1 / DCDC5 regulator names for later.
1333		 */
1334		if ((regulators == axp22x_regulators && i == AXP22X_DCDC1) ||
1335		    (regulators == axp809_regulators && i == AXP809_DCDC1))
 
1336			of_property_read_string(rdev->dev.of_node,
1337						"regulator-name",
1338						&dcdc1_name);
1339
1340		if ((regulators == axp22x_regulators && i == AXP22X_DCDC5) ||
1341		    (regulators == axp809_regulators && i == AXP809_DCDC5))
 
1342			of_property_read_string(rdev->dev.of_node,
1343						"regulator-name",
1344						&dcdc5_name);
 
 
 
 
 
1345	}
1346
1347	if (drivevbus) {
1348		/* Change N_VBUSEN sense pin to DRIVEVBUS output pin */
1349		regmap_update_bits(axp20x->regmap, AXP20X_OVER_TMP,
1350				   AXP22X_MISC_N_VBUSEN_FUNC, 0);
1351		rdev = devm_regulator_register(&pdev->dev,
1352					       &axp22x_drivevbus_regulator,
1353					       &config);
1354		if (IS_ERR(rdev)) {
1355			dev_err(&pdev->dev, "Failed to register drivevbus\n");
1356			return PTR_ERR(rdev);
1357		}
1358	}
1359
1360	return 0;
1361}
1362
1363static struct platform_driver axp20x_regulator_driver = {
1364	.probe	= axp20x_regulator_probe,
1365	.driver	= {
1366		.name		= "axp20x-regulator",
 
1367	},
1368};
1369
1370module_platform_driver(axp20x_regulator_driver);
1371
1372MODULE_LICENSE("GPL v2");
1373MODULE_AUTHOR("Carlo Caione <carlo@caione.org>");
1374MODULE_DESCRIPTION("Regulator Driver for AXP20X PMIC");
1375MODULE_ALIAS("platform:axp20x-regulator");
v6.8
   1/*
   2 * AXP20x regulators driver.
   3 *
   4 * Copyright (C) 2013 Carlo Caione <carlo@caione.org>
   5 *
   6 * This file is subject to the terms and conditions of the GNU General
   7 * Public License. See the file "COPYING" in the main directory of this
   8 * archive for more details.
   9 *
  10 * This program is distributed in the hope that it will be useful,
  11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13 * GNU General Public License for more details.
  14 */
  15
  16#include <linux/bitops.h>
  17#include <linux/delay.h>
  18#include <linux/err.h>
  19#include <linux/init.h>
  20#include <linux/mfd/axp20x.h>
  21#include <linux/module.h>
  22#include <linux/of.h>
 
  23#include <linux/platform_device.h>
  24#include <linux/regmap.h>
  25#include <linux/regulator/driver.h>
  26#include <linux/regulator/machine.h>
  27#include <linux/regulator/of_regulator.h>
  28
  29#define AXP20X_GPIO0_FUNC_MASK		GENMASK(3, 0)
  30#define AXP20X_GPIO1_FUNC_MASK		GENMASK(3, 0)
  31
  32#define AXP20X_IO_ENABLED		0x03
  33#define AXP20X_IO_DISABLED		0x07
  34
  35#define AXP20X_WORKMODE_DCDC2_MASK	BIT_MASK(2)
  36#define AXP20X_WORKMODE_DCDC3_MASK	BIT_MASK(1)
  37
  38#define AXP20X_FREQ_DCDC_MASK		GENMASK(3, 0)
  39
  40#define AXP20X_VBUS_IPSOUT_MGMT_MASK	BIT_MASK(2)
  41
  42#define AXP20X_DCDC2_V_OUT_MASK		GENMASK(5, 0)
  43#define AXP20X_DCDC3_V_OUT_MASK		GENMASK(7, 0)
  44#define AXP20X_LDO2_V_OUT_MASK		GENMASK(7, 4)
  45#define AXP20X_LDO3_V_OUT_MASK		GENMASK(6, 0)
  46#define AXP20X_LDO4_V_OUT_MASK		GENMASK(3, 0)
  47#define AXP20X_LDO5_V_OUT_MASK		GENMASK(7, 4)
  48
  49#define AXP20X_PWR_OUT_EXTEN_MASK	BIT_MASK(0)
  50#define AXP20X_PWR_OUT_DCDC3_MASK	BIT_MASK(1)
  51#define AXP20X_PWR_OUT_LDO2_MASK	BIT_MASK(2)
  52#define AXP20X_PWR_OUT_LDO4_MASK	BIT_MASK(3)
  53#define AXP20X_PWR_OUT_DCDC2_MASK	BIT_MASK(4)
  54#define AXP20X_PWR_OUT_LDO3_MASK	BIT_MASK(6)
  55
  56#define AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_RATE_MASK	BIT_MASK(0)
  57#define AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_RATE(x) \
  58	((x) << 0)
  59#define AXP20X_DCDC2_LDO3_V_RAMP_LDO3_RATE_MASK		BIT_MASK(1)
  60#define AXP20X_DCDC2_LDO3_V_RAMP_LDO3_RATE(x) \
  61	((x) << 1)
  62#define AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_EN_MASK		BIT_MASK(2)
  63#define AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_EN		BIT(2)
  64#define AXP20X_DCDC2_LDO3_V_RAMP_LDO3_EN_MASK		BIT_MASK(3)
  65#define AXP20X_DCDC2_LDO3_V_RAMP_LDO3_EN		BIT(3)
  66
  67#define AXP20X_LDO4_V_OUT_1250mV_START	0x0
  68#define AXP20X_LDO4_V_OUT_1250mV_STEPS	0
  69#define AXP20X_LDO4_V_OUT_1250mV_END	\
  70	(AXP20X_LDO4_V_OUT_1250mV_START + AXP20X_LDO4_V_OUT_1250mV_STEPS)
  71#define AXP20X_LDO4_V_OUT_1300mV_START	0x1
  72#define AXP20X_LDO4_V_OUT_1300mV_STEPS	7
  73#define AXP20X_LDO4_V_OUT_1300mV_END	\
  74	(AXP20X_LDO4_V_OUT_1300mV_START + AXP20X_LDO4_V_OUT_1300mV_STEPS)
  75#define AXP20X_LDO4_V_OUT_2500mV_START	0x9
  76#define AXP20X_LDO4_V_OUT_2500mV_STEPS	0
  77#define AXP20X_LDO4_V_OUT_2500mV_END	\
  78	(AXP20X_LDO4_V_OUT_2500mV_START + AXP20X_LDO4_V_OUT_2500mV_STEPS)
  79#define AXP20X_LDO4_V_OUT_2700mV_START	0xa
  80#define AXP20X_LDO4_V_OUT_2700mV_STEPS	1
  81#define AXP20X_LDO4_V_OUT_2700mV_END	\
  82	(AXP20X_LDO4_V_OUT_2700mV_START + AXP20X_LDO4_V_OUT_2700mV_STEPS)
  83#define AXP20X_LDO4_V_OUT_3000mV_START	0xc
  84#define AXP20X_LDO4_V_OUT_3000mV_STEPS	3
  85#define AXP20X_LDO4_V_OUT_3000mV_END	\
  86	(AXP20X_LDO4_V_OUT_3000mV_START + AXP20X_LDO4_V_OUT_3000mV_STEPS)
  87#define AXP20X_LDO4_V_OUT_NUM_VOLTAGES	16
  88
  89#define AXP22X_IO_ENABLED		0x03
  90#define AXP22X_IO_DISABLED		0x04
  91
  92#define AXP22X_WORKMODE_DCDCX_MASK(x)	BIT_MASK(x)
  93
  94#define AXP22X_MISC_N_VBUSEN_FUNC	BIT(4)
  95
  96#define AXP22X_DCDC1_V_OUT_MASK		GENMASK(4, 0)
  97#define AXP22X_DCDC2_V_OUT_MASK		GENMASK(5, 0)
  98#define AXP22X_DCDC3_V_OUT_MASK		GENMASK(5, 0)
  99#define AXP22X_DCDC4_V_OUT_MASK		GENMASK(5, 0)
 100#define AXP22X_DCDC5_V_OUT_MASK		GENMASK(4, 0)
 101#define AXP22X_DC5LDO_V_OUT_MASK	GENMASK(2, 0)
 102#define AXP22X_ALDO1_V_OUT_MASK		GENMASK(4, 0)
 103#define AXP22X_ALDO2_V_OUT_MASK		GENMASK(4, 0)
 104#define AXP22X_ALDO3_V_OUT_MASK		GENMASK(4, 0)
 105#define AXP22X_DLDO1_V_OUT_MASK		GENMASK(4, 0)
 106#define AXP22X_DLDO2_V_OUT_MASK		GENMASK(4, 0)
 107#define AXP22X_DLDO3_V_OUT_MASK		GENMASK(4, 0)
 108#define AXP22X_DLDO4_V_OUT_MASK		GENMASK(4, 0)
 109#define AXP22X_ELDO1_V_OUT_MASK		GENMASK(4, 0)
 110#define AXP22X_ELDO2_V_OUT_MASK		GENMASK(4, 0)
 111#define AXP22X_ELDO3_V_OUT_MASK		GENMASK(4, 0)
 112#define AXP22X_LDO_IO0_V_OUT_MASK	GENMASK(4, 0)
 113#define AXP22X_LDO_IO1_V_OUT_MASK	GENMASK(4, 0)
 114
 115#define AXP22X_PWR_OUT_DC5LDO_MASK	BIT_MASK(0)
 116#define AXP22X_PWR_OUT_DCDC1_MASK	BIT_MASK(1)
 117#define AXP22X_PWR_OUT_DCDC2_MASK	BIT_MASK(2)
 118#define AXP22X_PWR_OUT_DCDC3_MASK	BIT_MASK(3)
 119#define AXP22X_PWR_OUT_DCDC4_MASK	BIT_MASK(4)
 120#define AXP22X_PWR_OUT_DCDC5_MASK	BIT_MASK(5)
 121#define AXP22X_PWR_OUT_ALDO1_MASK	BIT_MASK(6)
 122#define AXP22X_PWR_OUT_ALDO2_MASK	BIT_MASK(7)
 123
 124#define AXP22X_PWR_OUT_SW_MASK		BIT_MASK(6)
 125#define AXP22X_PWR_OUT_DC1SW_MASK	BIT_MASK(7)
 126
 127#define AXP22X_PWR_OUT_ELDO1_MASK	BIT_MASK(0)
 128#define AXP22X_PWR_OUT_ELDO2_MASK	BIT_MASK(1)
 129#define AXP22X_PWR_OUT_ELDO3_MASK	BIT_MASK(2)
 130#define AXP22X_PWR_OUT_DLDO1_MASK	BIT_MASK(3)
 131#define AXP22X_PWR_OUT_DLDO2_MASK	BIT_MASK(4)
 132#define AXP22X_PWR_OUT_DLDO3_MASK	BIT_MASK(5)
 133#define AXP22X_PWR_OUT_DLDO4_MASK	BIT_MASK(6)
 134#define AXP22X_PWR_OUT_ALDO3_MASK	BIT_MASK(7)
 135
 136#define AXP313A_DCDC1_NUM_VOLTAGES	107
 137#define AXP313A_DCDC23_NUM_VOLTAGES	88
 138#define AXP313A_DCDC_V_OUT_MASK		GENMASK(6, 0)
 139#define AXP313A_LDO_V_OUT_MASK		GENMASK(4, 0)
 140
 141#define AXP803_PWR_OUT_DCDC1_MASK	BIT_MASK(0)
 142#define AXP803_PWR_OUT_DCDC2_MASK	BIT_MASK(1)
 143#define AXP803_PWR_OUT_DCDC3_MASK	BIT_MASK(2)
 144#define AXP803_PWR_OUT_DCDC4_MASK	BIT_MASK(3)
 145#define AXP803_PWR_OUT_DCDC5_MASK	BIT_MASK(4)
 146#define AXP803_PWR_OUT_DCDC6_MASK	BIT_MASK(5)
 147
 148#define AXP803_PWR_OUT_FLDO1_MASK	BIT_MASK(2)
 149#define AXP803_PWR_OUT_FLDO2_MASK	BIT_MASK(3)
 150
 151#define AXP803_DCDC1_V_OUT_MASK		GENMASK(4, 0)
 152#define AXP803_DCDC2_V_OUT_MASK		GENMASK(6, 0)
 153#define AXP803_DCDC3_V_OUT_MASK		GENMASK(6, 0)
 154#define AXP803_DCDC4_V_OUT_MASK		GENMASK(6, 0)
 155#define AXP803_DCDC5_V_OUT_MASK		GENMASK(6, 0)
 156#define AXP803_DCDC6_V_OUT_MASK		GENMASK(6, 0)
 157
 158#define AXP803_FLDO1_V_OUT_MASK		GENMASK(3, 0)
 159#define AXP803_FLDO2_V_OUT_MASK		GENMASK(3, 0)
 160
 161#define AXP803_DCDC23_POLYPHASE_DUAL	BIT(6)
 162#define AXP803_DCDC56_POLYPHASE_DUAL	BIT(5)
 163
 164#define AXP803_DCDC234_500mV_START	0x00
 165#define AXP803_DCDC234_500mV_STEPS	70
 166#define AXP803_DCDC234_500mV_END	\
 167	(AXP803_DCDC234_500mV_START + AXP803_DCDC234_500mV_STEPS)
 168#define AXP803_DCDC234_1220mV_START	0x47
 169#define AXP803_DCDC234_1220mV_STEPS	4
 170#define AXP803_DCDC234_1220mV_END	\
 171	(AXP803_DCDC234_1220mV_START + AXP803_DCDC234_1220mV_STEPS)
 172#define AXP803_DCDC234_NUM_VOLTAGES	76
 173
 174#define AXP803_DCDC5_800mV_START	0x00
 175#define AXP803_DCDC5_800mV_STEPS	32
 176#define AXP803_DCDC5_800mV_END		\
 177	(AXP803_DCDC5_800mV_START + AXP803_DCDC5_800mV_STEPS)
 178#define AXP803_DCDC5_1140mV_START	0x21
 179#define AXP803_DCDC5_1140mV_STEPS	35
 180#define AXP803_DCDC5_1140mV_END		\
 181	(AXP803_DCDC5_1140mV_START + AXP803_DCDC5_1140mV_STEPS)
 182#define AXP803_DCDC5_NUM_VOLTAGES	69
 183
 184#define AXP803_DCDC6_600mV_START	0x00
 185#define AXP803_DCDC6_600mV_STEPS	50
 186#define AXP803_DCDC6_600mV_END		\
 187	(AXP803_DCDC6_600mV_START + AXP803_DCDC6_600mV_STEPS)
 188#define AXP803_DCDC6_1120mV_START	0x33
 189#define AXP803_DCDC6_1120mV_STEPS	20
 190#define AXP803_DCDC6_1120mV_END		\
 191	(AXP803_DCDC6_1120mV_START + AXP803_DCDC6_1120mV_STEPS)
 192#define AXP803_DCDC6_NUM_VOLTAGES	72
 193
 194#define AXP803_DLDO2_700mV_START	0x00
 195#define AXP803_DLDO2_700mV_STEPS	26
 196#define AXP803_DLDO2_700mV_END		\
 197	(AXP803_DLDO2_700mV_START + AXP803_DLDO2_700mV_STEPS)
 198#define AXP803_DLDO2_3400mV_START	0x1b
 199#define AXP803_DLDO2_3400mV_STEPS	4
 200#define AXP803_DLDO2_3400mV_END		\
 201	(AXP803_DLDO2_3400mV_START + AXP803_DLDO2_3400mV_STEPS)
 202#define AXP803_DLDO2_NUM_VOLTAGES	32
 203
 204#define AXP806_DCDCA_V_CTRL_MASK	GENMASK(6, 0)
 205#define AXP806_DCDCB_V_CTRL_MASK	GENMASK(4, 0)
 206#define AXP806_DCDCC_V_CTRL_MASK	GENMASK(6, 0)
 207#define AXP806_DCDCD_V_CTRL_MASK	GENMASK(5, 0)
 208#define AXP806_DCDCE_V_CTRL_MASK	GENMASK(4, 0)
 209#define AXP806_ALDO1_V_CTRL_MASK	GENMASK(4, 0)
 210#define AXP806_ALDO2_V_CTRL_MASK	GENMASK(4, 0)
 211#define AXP806_ALDO3_V_CTRL_MASK	GENMASK(4, 0)
 212#define AXP806_BLDO1_V_CTRL_MASK	GENMASK(3, 0)
 213#define AXP806_BLDO2_V_CTRL_MASK	GENMASK(3, 0)
 214#define AXP806_BLDO3_V_CTRL_MASK	GENMASK(3, 0)
 215#define AXP806_BLDO4_V_CTRL_MASK	GENMASK(3, 0)
 216#define AXP806_CLDO1_V_CTRL_MASK	GENMASK(4, 0)
 217#define AXP806_CLDO2_V_CTRL_MASK	GENMASK(4, 0)
 218#define AXP806_CLDO3_V_CTRL_MASK	GENMASK(4, 0)
 219
 220#define AXP806_PWR_OUT_DCDCA_MASK	BIT_MASK(0)
 221#define AXP806_PWR_OUT_DCDCB_MASK	BIT_MASK(1)
 222#define AXP806_PWR_OUT_DCDCC_MASK	BIT_MASK(2)
 223#define AXP806_PWR_OUT_DCDCD_MASK	BIT_MASK(3)
 224#define AXP806_PWR_OUT_DCDCE_MASK	BIT_MASK(4)
 225#define AXP806_PWR_OUT_ALDO1_MASK	BIT_MASK(5)
 226#define AXP806_PWR_OUT_ALDO2_MASK	BIT_MASK(6)
 227#define AXP806_PWR_OUT_ALDO3_MASK	BIT_MASK(7)
 228#define AXP806_PWR_OUT_BLDO1_MASK	BIT_MASK(0)
 229#define AXP806_PWR_OUT_BLDO2_MASK	BIT_MASK(1)
 230#define AXP806_PWR_OUT_BLDO3_MASK	BIT_MASK(2)
 231#define AXP806_PWR_OUT_BLDO4_MASK	BIT_MASK(3)
 232#define AXP806_PWR_OUT_CLDO1_MASK	BIT_MASK(4)
 233#define AXP806_PWR_OUT_CLDO2_MASK	BIT_MASK(5)
 234#define AXP806_PWR_OUT_CLDO3_MASK	BIT_MASK(6)
 235#define AXP806_PWR_OUT_SW_MASK		BIT_MASK(7)
 236
 237#define AXP806_DCDCAB_POLYPHASE_DUAL	0x40
 238#define AXP806_DCDCABC_POLYPHASE_TRI	0x80
 239#define AXP806_DCDCABC_POLYPHASE_MASK	GENMASK(7, 6)
 240
 241#define AXP806_DCDCDE_POLYPHASE_DUAL	BIT(5)
 242
 243#define AXP806_DCDCA_600mV_START	0x00
 244#define AXP806_DCDCA_600mV_STEPS	50
 245#define AXP806_DCDCA_600mV_END		\
 246	(AXP806_DCDCA_600mV_START + AXP806_DCDCA_600mV_STEPS)
 247#define AXP806_DCDCA_1120mV_START	0x33
 248#define AXP806_DCDCA_1120mV_STEPS	20
 249#define AXP806_DCDCA_1120mV_END		\
 250	(AXP806_DCDCA_1120mV_START + AXP806_DCDCA_1120mV_STEPS)
 251#define AXP806_DCDCA_NUM_VOLTAGES	72
 252
 253#define AXP806_DCDCD_600mV_START	0x00
 254#define AXP806_DCDCD_600mV_STEPS	45
 255#define AXP806_DCDCD_600mV_END		\
 256	(AXP806_DCDCD_600mV_START + AXP806_DCDCD_600mV_STEPS)
 257#define AXP806_DCDCD_1600mV_START	0x2e
 258#define AXP806_DCDCD_1600mV_STEPS	17
 259#define AXP806_DCDCD_1600mV_END		\
 260	(AXP806_DCDCD_1600mV_START + AXP806_DCDCD_1600mV_STEPS)
 261#define AXP806_DCDCD_NUM_VOLTAGES	64
 262
 263#define AXP809_DCDC4_600mV_START	0x00
 264#define AXP809_DCDC4_600mV_STEPS	47
 265#define AXP809_DCDC4_600mV_END		\
 266	(AXP809_DCDC4_600mV_START + AXP809_DCDC4_600mV_STEPS)
 267#define AXP809_DCDC4_1800mV_START	0x30
 268#define AXP809_DCDC4_1800mV_STEPS	8
 269#define AXP809_DCDC4_1800mV_END		\
 270	(AXP809_DCDC4_1800mV_START + AXP809_DCDC4_1800mV_STEPS)
 271#define AXP809_DCDC4_NUM_VOLTAGES	57
 272
 273#define AXP813_DCDC7_V_OUT_MASK		GENMASK(6, 0)
 274
 275#define AXP813_PWR_OUT_DCDC7_MASK	BIT_MASK(6)
 276
 277#define AXP15060_DCDC1_V_CTRL_MASK		GENMASK(4, 0)
 278#define AXP15060_DCDC2_V_CTRL_MASK		GENMASK(6, 0)
 279#define AXP15060_DCDC3_V_CTRL_MASK		GENMASK(6, 0)
 280#define AXP15060_DCDC4_V_CTRL_MASK		GENMASK(6, 0)
 281#define AXP15060_DCDC5_V_CTRL_MASK		GENMASK(6, 0)
 282#define AXP15060_DCDC6_V_CTRL_MASK		GENMASK(4, 0)
 283#define AXP15060_ALDO1_V_CTRL_MASK		GENMASK(4, 0)
 284#define AXP15060_ALDO2_V_CTRL_MASK		GENMASK(4, 0)
 285#define AXP15060_ALDO3_V_CTRL_MASK		GENMASK(4, 0)
 286#define AXP15060_ALDO4_V_CTRL_MASK		GENMASK(4, 0)
 287#define AXP15060_ALDO5_V_CTRL_MASK		GENMASK(4, 0)
 288#define AXP15060_BLDO1_V_CTRL_MASK		GENMASK(4, 0)
 289#define AXP15060_BLDO2_V_CTRL_MASK		GENMASK(4, 0)
 290#define AXP15060_BLDO3_V_CTRL_MASK		GENMASK(4, 0)
 291#define AXP15060_BLDO4_V_CTRL_MASK		GENMASK(4, 0)
 292#define AXP15060_BLDO5_V_CTRL_MASK		GENMASK(4, 0)
 293#define AXP15060_CLDO1_V_CTRL_MASK		GENMASK(4, 0)
 294#define AXP15060_CLDO2_V_CTRL_MASK		GENMASK(4, 0)
 295#define AXP15060_CLDO3_V_CTRL_MASK		GENMASK(4, 0)
 296#define AXP15060_CLDO4_V_CTRL_MASK		GENMASK(5, 0)
 297#define AXP15060_CPUSLDO_V_CTRL_MASK		GENMASK(3, 0)
 298
 299#define AXP15060_PWR_OUT_DCDC1_MASK	BIT_MASK(0)
 300#define AXP15060_PWR_OUT_DCDC2_MASK	BIT_MASK(1)
 301#define AXP15060_PWR_OUT_DCDC3_MASK	BIT_MASK(2)
 302#define AXP15060_PWR_OUT_DCDC4_MASK	BIT_MASK(3)
 303#define AXP15060_PWR_OUT_DCDC5_MASK	BIT_MASK(4)
 304#define AXP15060_PWR_OUT_DCDC6_MASK	BIT_MASK(5)
 305#define AXP15060_PWR_OUT_ALDO1_MASK	BIT_MASK(0)
 306#define AXP15060_PWR_OUT_ALDO2_MASK	BIT_MASK(1)
 307#define AXP15060_PWR_OUT_ALDO3_MASK	BIT_MASK(2)
 308#define AXP15060_PWR_OUT_ALDO4_MASK	BIT_MASK(3)
 309#define AXP15060_PWR_OUT_ALDO5_MASK	BIT_MASK(4)
 310#define AXP15060_PWR_OUT_BLDO1_MASK	BIT_MASK(5)
 311#define AXP15060_PWR_OUT_BLDO2_MASK	BIT_MASK(6)
 312#define AXP15060_PWR_OUT_BLDO3_MASK	BIT_MASK(7)
 313#define AXP15060_PWR_OUT_BLDO4_MASK	BIT_MASK(0)
 314#define AXP15060_PWR_OUT_BLDO5_MASK	BIT_MASK(1)
 315#define AXP15060_PWR_OUT_CLDO1_MASK	BIT_MASK(2)
 316#define AXP15060_PWR_OUT_CLDO2_MASK	BIT_MASK(3)
 317#define AXP15060_PWR_OUT_CLDO3_MASK	BIT_MASK(4)
 318#define AXP15060_PWR_OUT_CLDO4_MASK	BIT_MASK(5)
 319#define AXP15060_PWR_OUT_CPUSLDO_MASK	BIT_MASK(6)
 320#define AXP15060_PWR_OUT_SW_MASK		BIT_MASK(7)
 321
 322#define AXP15060_DCDC23_POLYPHASE_DUAL_MASK		BIT_MASK(6)
 323#define AXP15060_DCDC46_POLYPHASE_DUAL_MASK		BIT_MASK(7)
 324
 325#define AXP15060_DCDC234_500mV_START	0x00
 326#define AXP15060_DCDC234_500mV_STEPS	70
 327#define AXP15060_DCDC234_500mV_END		\
 328	(AXP15060_DCDC234_500mV_START + AXP15060_DCDC234_500mV_STEPS)
 329#define AXP15060_DCDC234_1220mV_START	0x47
 330#define AXP15060_DCDC234_1220mV_STEPS	16
 331#define AXP15060_DCDC234_1220mV_END		\
 332	(AXP15060_DCDC234_1220mV_START + AXP15060_DCDC234_1220mV_STEPS)
 333#define AXP15060_DCDC234_NUM_VOLTAGES	88
 334
 335#define AXP15060_DCDC5_800mV_START	0x00
 336#define AXP15060_DCDC5_800mV_STEPS	32
 337#define AXP15060_DCDC5_800mV_END		\
 338	(AXP15060_DCDC5_800mV_START + AXP15060_DCDC5_800mV_STEPS)
 339#define AXP15060_DCDC5_1140mV_START	0x21
 340#define AXP15060_DCDC5_1140mV_STEPS	35
 341#define AXP15060_DCDC5_1140mV_END		\
 342	(AXP15060_DCDC5_1140mV_START + AXP15060_DCDC5_1140mV_STEPS)
 343#define AXP15060_DCDC5_NUM_VOLTAGES	69
 344
 345#define AXP_DESC_IO(_family, _id, _match, _supply, _min, _max, _step, _vreg,	\
 346		    _vmask, _ereg, _emask, _enable_val, _disable_val)		\
 347	[_family##_##_id] = {							\
 348		.name		= (_match),					\
 349		.supply_name	= (_supply),					\
 350		.of_match	= of_match_ptr(_match),				\
 351		.regulators_node = of_match_ptr("regulators"),			\
 352		.type		= REGULATOR_VOLTAGE,				\
 353		.id		= _family##_##_id,				\
 354		.n_voltages	= (((_max) - (_min)) / (_step) + 1),		\
 355		.owner		= THIS_MODULE,					\
 356		.min_uV		= (_min) * 1000,				\
 357		.uV_step	= (_step) * 1000,				\
 358		.vsel_reg	= (_vreg),					\
 359		.vsel_mask	= (_vmask),					\
 360		.enable_reg	= (_ereg),					\
 361		.enable_mask	= (_emask),					\
 362		.enable_val	= (_enable_val),				\
 363		.disable_val	= (_disable_val),				\
 364		.ops		= &axp20x_ops,					\
 365	}
 366
 367#define AXP_DESC(_family, _id, _match, _supply, _min, _max, _step, _vreg,	\
 368		 _vmask, _ereg, _emask) 					\
 369	[_family##_##_id] = {							\
 370		.name		= (_match),					\
 371		.supply_name	= (_supply),					\
 372		.of_match	= of_match_ptr(_match),				\
 373		.regulators_node = of_match_ptr("regulators"),			\
 374		.type		= REGULATOR_VOLTAGE,				\
 375		.id		= _family##_##_id,				\
 376		.n_voltages	= (((_max) - (_min)) / (_step) + 1),		\
 377		.owner		= THIS_MODULE,					\
 378		.min_uV		= (_min) * 1000,				\
 379		.uV_step	= (_step) * 1000,				\
 380		.vsel_reg	= (_vreg),					\
 381		.vsel_mask	= (_vmask),					\
 382		.enable_reg	= (_ereg),					\
 383		.enable_mask	= (_emask),					\
 384		.ops		= &axp20x_ops,					\
 385	}
 386
 387#define AXP_DESC_SW(_family, _id, _match, _supply, _ereg, _emask)		\
 388	[_family##_##_id] = {							\
 389		.name		= (_match),					\
 390		.supply_name	= (_supply),					\
 391		.of_match	= of_match_ptr(_match),				\
 392		.regulators_node = of_match_ptr("regulators"),			\
 393		.type		= REGULATOR_VOLTAGE,				\
 394		.id		= _family##_##_id,				\
 395		.owner		= THIS_MODULE,					\
 396		.enable_reg	= (_ereg),					\
 397		.enable_mask	= (_emask),					\
 398		.ops		= &axp20x_ops_sw,				\
 399	}
 400
 401#define AXP_DESC_FIXED(_family, _id, _match, _supply, _volt)			\
 402	[_family##_##_id] = {							\
 403		.name		= (_match),					\
 404		.supply_name	= (_supply),					\
 405		.of_match	= of_match_ptr(_match),				\
 406		.regulators_node = of_match_ptr("regulators"),			\
 407		.type		= REGULATOR_VOLTAGE,				\
 408		.id		= _family##_##_id,				\
 409		.n_voltages	= 1,						\
 410		.owner		= THIS_MODULE,					\
 411		.min_uV		= (_volt) * 1000,				\
 412		.ops		= &axp20x_ops_fixed				\
 413	}
 414
 415#define AXP_DESC_RANGES(_family, _id, _match, _supply, _ranges, _n_voltages,	\
 416			_vreg, _vmask, _ereg, _emask)				\
 417	[_family##_##_id] = {							\
 418		.name		= (_match),					\
 419		.supply_name	= (_supply),					\
 420		.of_match	= of_match_ptr(_match),				\
 421		.regulators_node = of_match_ptr("regulators"),			\
 422		.type		= REGULATOR_VOLTAGE,				\
 423		.id		= _family##_##_id,				\
 424		.n_voltages	= (_n_voltages),				\
 425		.owner		= THIS_MODULE,					\
 426		.vsel_reg	= (_vreg),					\
 427		.vsel_mask	= (_vmask),					\
 428		.enable_reg	= (_ereg),					\
 429		.enable_mask	= (_emask),					\
 430		.linear_ranges	= (_ranges),					\
 431		.n_linear_ranges = ARRAY_SIZE(_ranges),				\
 432		.ops		= &axp20x_ops_range,				\
 433	}
 434
 435static const int axp209_dcdc2_ldo3_slew_rates[] = {
 436	1600,
 437	 800,
 438};
 439
 440static int axp20x_set_ramp_delay(struct regulator_dev *rdev, int ramp)
 441{
 442	struct axp20x_dev *axp20x = rdev_get_drvdata(rdev);
 443	int id = rdev_get_id(rdev);
 444	u8 reg, mask, enable, cfg = 0xff;
 445	const int *slew_rates;
 446	int rate_count = 0;
 447
 448	switch (axp20x->variant) {
 449	case AXP209_ID:
 450		if (id == AXP20X_DCDC2) {
 451			slew_rates = axp209_dcdc2_ldo3_slew_rates;
 452			rate_count = ARRAY_SIZE(axp209_dcdc2_ldo3_slew_rates);
 453			reg = AXP20X_DCDC2_LDO3_V_RAMP;
 454			mask = AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_RATE_MASK |
 455			       AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_EN_MASK;
 456			enable = (ramp > 0) ?
 457				 AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_EN : 0;
 458			break;
 459		}
 460
 461		if (id == AXP20X_LDO3) {
 462			slew_rates = axp209_dcdc2_ldo3_slew_rates;
 463			rate_count = ARRAY_SIZE(axp209_dcdc2_ldo3_slew_rates);
 464			reg = AXP20X_DCDC2_LDO3_V_RAMP;
 465			mask = AXP20X_DCDC2_LDO3_V_RAMP_LDO3_RATE_MASK |
 466			       AXP20X_DCDC2_LDO3_V_RAMP_LDO3_EN_MASK;
 467			enable = (ramp > 0) ?
 468				 AXP20X_DCDC2_LDO3_V_RAMP_LDO3_EN : 0;
 469			break;
 470		}
 471
 472		if (rate_count > 0)
 473			break;
 474
 475		fallthrough;
 476	default:
 477		/* Not supported for this regulator */
 478		return -ENOTSUPP;
 479	}
 480
 481	if (ramp == 0) {
 482		cfg = enable;
 483	} else {
 484		int i;
 485
 486		for (i = 0; i < rate_count; i++) {
 487			if (ramp > slew_rates[i])
 488				break;
 489
 490			if (id == AXP20X_DCDC2)
 491				cfg = AXP20X_DCDC2_LDO3_V_RAMP_DCDC2_RATE(i);
 492			else
 493				cfg = AXP20X_DCDC2_LDO3_V_RAMP_LDO3_RATE(i);
 494		}
 495
 496		if (cfg == 0xff) {
 497			dev_err(axp20x->dev, "unsupported ramp value %d", ramp);
 498			return -EINVAL;
 499		}
 500
 501		cfg |= enable;
 502	}
 503
 504	return regmap_update_bits(axp20x->regmap, reg, mask, cfg);
 505}
 506
 507static int axp20x_regulator_enable_regmap(struct regulator_dev *rdev)
 508{
 509	struct axp20x_dev *axp20x = rdev_get_drvdata(rdev);
 510	int id = rdev_get_id(rdev);
 511
 512	switch (axp20x->variant) {
 513	case AXP209_ID:
 514		if ((id == AXP20X_LDO3) &&
 515		    rdev->constraints && rdev->constraints->soft_start) {
 516			int v_out;
 517			int ret;
 518
 519			/*
 520			 * On some boards, the LDO3 can be overloaded when
 521			 * turning on, causing the entire PMIC to shutdown
 522			 * without warning. Turning it on at the minimal voltage
 523			 * and then setting the voltage to the requested value
 524			 * works reliably.
 525			 */
 526			if (regulator_is_enabled_regmap(rdev))
 527				break;
 528
 529			v_out = regulator_get_voltage_sel_regmap(rdev);
 530			if (v_out < 0)
 531				return v_out;
 532
 533			if (v_out == 0)
 534				break;
 535
 536			ret = regulator_set_voltage_sel_regmap(rdev, 0x00);
 537			/*
 538			 * A small pause is needed between
 539			 * setting the voltage and enabling the LDO to give the
 540			 * internal state machine time to process the request.
 541			 */
 542			usleep_range(1000, 5000);
 543			ret |= regulator_enable_regmap(rdev);
 544			ret |= regulator_set_voltage_sel_regmap(rdev, v_out);
 545
 546			return ret;
 547		}
 548		break;
 549	default:
 550		/* No quirks */
 551		break;
 552	}
 553
 554	return regulator_enable_regmap(rdev);
 555};
 556
 557static const struct regulator_ops axp20x_ops_fixed = {
 558	.list_voltage		= regulator_list_voltage_linear,
 559};
 560
 561static const struct regulator_ops axp20x_ops_range = {
 562	.set_voltage_sel	= regulator_set_voltage_sel_regmap,
 563	.get_voltage_sel	= regulator_get_voltage_sel_regmap,
 564	.list_voltage		= regulator_list_voltage_linear_range,
 565	.enable			= regulator_enable_regmap,
 566	.disable		= regulator_disable_regmap,
 567	.is_enabled		= regulator_is_enabled_regmap,
 568};
 569
 570static const struct regulator_ops axp20x_ops = {
 571	.set_voltage_sel	= regulator_set_voltage_sel_regmap,
 572	.get_voltage_sel	= regulator_get_voltage_sel_regmap,
 573	.list_voltage		= regulator_list_voltage_linear,
 574	.enable			= axp20x_regulator_enable_regmap,
 575	.disable		= regulator_disable_regmap,
 576	.is_enabled		= regulator_is_enabled_regmap,
 577	.set_ramp_delay		= axp20x_set_ramp_delay,
 578};
 579
 580static const struct regulator_ops axp20x_ops_sw = {
 581	.enable			= regulator_enable_regmap,
 582	.disable		= regulator_disable_regmap,
 583	.is_enabled		= regulator_is_enabled_regmap,
 584};
 585
 586static const struct linear_range axp20x_ldo4_ranges[] = {
 587	REGULATOR_LINEAR_RANGE(1250000,
 588			       AXP20X_LDO4_V_OUT_1250mV_START,
 589			       AXP20X_LDO4_V_OUT_1250mV_END,
 590			       0),
 591	REGULATOR_LINEAR_RANGE(1300000,
 592			       AXP20X_LDO4_V_OUT_1300mV_START,
 593			       AXP20X_LDO4_V_OUT_1300mV_END,
 594			       100000),
 595	REGULATOR_LINEAR_RANGE(2500000,
 596			       AXP20X_LDO4_V_OUT_2500mV_START,
 597			       AXP20X_LDO4_V_OUT_2500mV_END,
 598			       0),
 599	REGULATOR_LINEAR_RANGE(2700000,
 600			       AXP20X_LDO4_V_OUT_2700mV_START,
 601			       AXP20X_LDO4_V_OUT_2700mV_END,
 602			       100000),
 603	REGULATOR_LINEAR_RANGE(3000000,
 604			       AXP20X_LDO4_V_OUT_3000mV_START,
 605			       AXP20X_LDO4_V_OUT_3000mV_END,
 606			       100000),
 607};
 608
 609static const struct regulator_desc axp20x_regulators[] = {
 610	AXP_DESC(AXP20X, DCDC2, "dcdc2", "vin2", 700, 2275, 25,
 611		 AXP20X_DCDC2_V_OUT, AXP20X_DCDC2_V_OUT_MASK,
 612		 AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_DCDC2_MASK),
 613	AXP_DESC(AXP20X, DCDC3, "dcdc3", "vin3", 700, 3500, 25,
 614		 AXP20X_DCDC3_V_OUT, AXP20X_DCDC3_V_OUT_MASK,
 615		 AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_DCDC3_MASK),
 616	AXP_DESC_FIXED(AXP20X, LDO1, "ldo1", "acin", 1300),
 617	AXP_DESC(AXP20X, LDO2, "ldo2", "ldo24in", 1800, 3300, 100,
 618		 AXP20X_LDO24_V_OUT, AXP20X_LDO2_V_OUT_MASK,
 619		 AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_LDO2_MASK),
 620	AXP_DESC(AXP20X, LDO3, "ldo3", "ldo3in", 700, 3500, 25,
 621		 AXP20X_LDO3_V_OUT, AXP20X_LDO3_V_OUT_MASK,
 622		 AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_LDO3_MASK),
 623	AXP_DESC_RANGES(AXP20X, LDO4, "ldo4", "ldo24in",
 624			axp20x_ldo4_ranges, AXP20X_LDO4_V_OUT_NUM_VOLTAGES,
 625			AXP20X_LDO24_V_OUT, AXP20X_LDO4_V_OUT_MASK,
 626			AXP20X_PWR_OUT_CTRL, AXP20X_PWR_OUT_LDO4_MASK),
 627	AXP_DESC_IO(AXP20X, LDO5, "ldo5", "ldo5in", 1800, 3300, 100,
 628		    AXP20X_LDO5_V_OUT, AXP20X_LDO5_V_OUT_MASK,
 629		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
 630		    AXP20X_IO_ENABLED, AXP20X_IO_DISABLED),
 631};
 632
 633static const struct regulator_desc axp22x_regulators[] = {
 634	AXP_DESC(AXP22X, DCDC1, "dcdc1", "vin1", 1600, 3400, 100,
 635		 AXP22X_DCDC1_V_OUT, AXP22X_DCDC1_V_OUT_MASK,
 636		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC1_MASK),
 637	AXP_DESC(AXP22X, DCDC2, "dcdc2", "vin2", 600, 1540, 20,
 638		 AXP22X_DCDC2_V_OUT, AXP22X_DCDC2_V_OUT_MASK,
 639		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC2_MASK),
 640	AXP_DESC(AXP22X, DCDC3, "dcdc3", "vin3", 600, 1860, 20,
 641		 AXP22X_DCDC3_V_OUT, AXP22X_DCDC3_V_OUT_MASK,
 642		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC3_MASK),
 643	AXP_DESC(AXP22X, DCDC4, "dcdc4", "vin4", 600, 1540, 20,
 644		 AXP22X_DCDC4_V_OUT, AXP22X_DCDC4_V_OUT_MASK,
 645		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC4_MASK),
 646	AXP_DESC(AXP22X, DCDC5, "dcdc5", "vin5", 1000, 2550, 50,
 647		 AXP22X_DCDC5_V_OUT, AXP22X_DCDC5_V_OUT_MASK,
 648		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC5_MASK),
 649	/* secondary switchable output of DCDC1 */
 650	AXP_DESC_SW(AXP22X, DC1SW, "dc1sw", NULL,
 651		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DC1SW_MASK),
 652	/* LDO regulator internally chained to DCDC5 */
 653	AXP_DESC(AXP22X, DC5LDO, "dc5ldo", NULL, 700, 1400, 100,
 654		 AXP22X_DC5LDO_V_OUT, AXP22X_DC5LDO_V_OUT_MASK,
 655		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DC5LDO_MASK),
 656	AXP_DESC(AXP22X, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
 657		 AXP22X_ALDO1_V_OUT, AXP22X_ALDO1_V_OUT_MASK,
 658		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_ALDO1_MASK),
 659	AXP_DESC(AXP22X, ALDO2, "aldo2", "aldoin", 700, 3300, 100,
 660		 AXP22X_ALDO2_V_OUT, AXP22X_ALDO2_V_OUT_MASK,
 661		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_ALDO2_MASK),
 662	AXP_DESC(AXP22X, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
 663		 AXP22X_ALDO3_V_OUT, AXP22X_ALDO3_V_OUT_MASK,
 664		 AXP22X_PWR_OUT_CTRL3, AXP22X_PWR_OUT_ALDO3_MASK),
 665	AXP_DESC(AXP22X, DLDO1, "dldo1", "dldoin", 700, 3300, 100,
 666		 AXP22X_DLDO1_V_OUT, AXP22X_DLDO1_V_OUT_MASK,
 667		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO1_MASK),
 668	AXP_DESC(AXP22X, DLDO2, "dldo2", "dldoin", 700, 3300, 100,
 669		 AXP22X_DLDO2_V_OUT, AXP22X_DLDO2_V_OUT_MASK,
 670		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO2_MASK),
 671	AXP_DESC(AXP22X, DLDO3, "dldo3", "dldoin", 700, 3300, 100,
 672		 AXP22X_DLDO3_V_OUT, AXP22X_DLDO3_V_OUT_MASK,
 673		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO3_MASK),
 674	AXP_DESC(AXP22X, DLDO4, "dldo4", "dldoin", 700, 3300, 100,
 675		 AXP22X_DLDO4_V_OUT, AXP22X_DLDO4_V_OUT_MASK,
 676		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO4_MASK),
 677	AXP_DESC(AXP22X, ELDO1, "eldo1", "eldoin", 700, 3300, 100,
 678		 AXP22X_ELDO1_V_OUT, AXP22X_ELDO1_V_OUT_MASK,
 679		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO1_MASK),
 680	AXP_DESC(AXP22X, ELDO2, "eldo2", "eldoin", 700, 3300, 100,
 681		 AXP22X_ELDO2_V_OUT, AXP22X_ELDO2_V_OUT_MASK,
 682		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO2_MASK),
 683	AXP_DESC(AXP22X, ELDO3, "eldo3", "eldoin", 700, 3300, 100,
 684		 AXP22X_ELDO3_V_OUT, AXP22X_ELDO3_V_OUT_MASK,
 685		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO3_MASK),
 686	/* Note the datasheet only guarantees reliable operation up to
 687	 * 3.3V, this needs to be enforced via dts provided constraints */
 688	AXP_DESC_IO(AXP22X, LDO_IO0, "ldo_io0", "ips", 700, 3800, 100,
 689		    AXP22X_LDO_IO0_V_OUT, AXP22X_LDO_IO0_V_OUT_MASK,
 690		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
 691		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 692	/* Note the datasheet only guarantees reliable operation up to
 693	 * 3.3V, this needs to be enforced via dts provided constraints */
 694	AXP_DESC_IO(AXP22X, LDO_IO1, "ldo_io1", "ips", 700, 3800, 100,
 695		    AXP22X_LDO_IO1_V_OUT, AXP22X_LDO_IO1_V_OUT_MASK,
 696		    AXP20X_GPIO1_CTRL, AXP20X_GPIO1_FUNC_MASK,
 697		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 698	AXP_DESC_FIXED(AXP22X, RTC_LDO, "rtc_ldo", "ips", 3000),
 699};
 700
 701static const struct regulator_desc axp22x_drivevbus_regulator = {
 702	.name		= "drivevbus",
 703	.supply_name	= "drivevbus",
 704	.of_match	= of_match_ptr("drivevbus"),
 705	.regulators_node = of_match_ptr("regulators"),
 706	.type		= REGULATOR_VOLTAGE,
 707	.owner		= THIS_MODULE,
 708	.enable_reg	= AXP20X_VBUS_IPSOUT_MGMT,
 709	.enable_mask	= AXP20X_VBUS_IPSOUT_MGMT_MASK,
 710	.ops		= &axp20x_ops_sw,
 711};
 712
 713static const struct linear_range axp313a_dcdc1_ranges[] = {
 714	REGULATOR_LINEAR_RANGE(500000,   0,  70,  10000),
 715	REGULATOR_LINEAR_RANGE(1220000, 71,  87,  20000),
 716	REGULATOR_LINEAR_RANGE(1600000, 88, 106, 100000),
 717};
 718
 719static const struct linear_range axp313a_dcdc2_ranges[] = {
 720	REGULATOR_LINEAR_RANGE(500000,   0, 70, 10000),
 721	REGULATOR_LINEAR_RANGE(1220000, 71, 87, 20000),
 722};
 723
 724/*
 725 * This is deviating from the datasheet. The values here are taken from the
 726 * BSP driver and have been confirmed by measurements.
 727 */
 728static const struct linear_range axp313a_dcdc3_ranges[] = {
 729	REGULATOR_LINEAR_RANGE(500000,   0,  70, 10000),
 730	REGULATOR_LINEAR_RANGE(1220000, 71, 102, 20000),
 731};
 732
 733static const struct regulator_desc axp313a_regulators[] = {
 734	AXP_DESC_RANGES(AXP313A, DCDC1, "dcdc1", "vin1",
 735			axp313a_dcdc1_ranges, AXP313A_DCDC1_NUM_VOLTAGES,
 736			AXP313A_DCDC1_CONRTOL, AXP313A_DCDC_V_OUT_MASK,
 737			AXP313A_OUTPUT_CONTROL, BIT(0)),
 738	AXP_DESC_RANGES(AXP313A, DCDC2, "dcdc2", "vin2",
 739			axp313a_dcdc2_ranges, AXP313A_DCDC23_NUM_VOLTAGES,
 740			AXP313A_DCDC2_CONRTOL, AXP313A_DCDC_V_OUT_MASK,
 741			AXP313A_OUTPUT_CONTROL, BIT(1)),
 742	AXP_DESC_RANGES(AXP313A, DCDC3, "dcdc3", "vin3",
 743			axp313a_dcdc3_ranges, AXP313A_DCDC23_NUM_VOLTAGES,
 744			AXP313A_DCDC3_CONRTOL, AXP313A_DCDC_V_OUT_MASK,
 745			AXP313A_OUTPUT_CONTROL, BIT(2)),
 746	AXP_DESC(AXP313A, ALDO1, "aldo1", "vin1", 500, 3500, 100,
 747		 AXP313A_ALDO1_CONRTOL, AXP313A_LDO_V_OUT_MASK,
 748		 AXP313A_OUTPUT_CONTROL, BIT(3)),
 749	AXP_DESC(AXP313A, DLDO1, "dldo1", "vin1", 500, 3500, 100,
 750		 AXP313A_DLDO1_CONRTOL, AXP313A_LDO_V_OUT_MASK,
 751		 AXP313A_OUTPUT_CONTROL, BIT(4)),
 752	AXP_DESC_FIXED(AXP313A, RTC_LDO, "rtc-ldo", "vin1", 1800),
 753};
 754
 755/* DCDC ranges shared with AXP813 */
 756static const struct linear_range axp803_dcdc234_ranges[] = {
 757	REGULATOR_LINEAR_RANGE(500000,
 758			       AXP803_DCDC234_500mV_START,
 759			       AXP803_DCDC234_500mV_END,
 760			       10000),
 761	REGULATOR_LINEAR_RANGE(1220000,
 762			       AXP803_DCDC234_1220mV_START,
 763			       AXP803_DCDC234_1220mV_END,
 764			       20000),
 765};
 766
 767static const struct linear_range axp803_dcdc5_ranges[] = {
 768	REGULATOR_LINEAR_RANGE(800000,
 769			       AXP803_DCDC5_800mV_START,
 770			       AXP803_DCDC5_800mV_END,
 771			       10000),
 772	REGULATOR_LINEAR_RANGE(1140000,
 773			       AXP803_DCDC5_1140mV_START,
 774			       AXP803_DCDC5_1140mV_END,
 775			       20000),
 776};
 777
 778static const struct linear_range axp803_dcdc6_ranges[] = {
 779	REGULATOR_LINEAR_RANGE(600000,
 780			       AXP803_DCDC6_600mV_START,
 781			       AXP803_DCDC6_600mV_END,
 782			       10000),
 783	REGULATOR_LINEAR_RANGE(1120000,
 784			       AXP803_DCDC6_1120mV_START,
 785			       AXP803_DCDC6_1120mV_END,
 786			       20000),
 787};
 788
 789/* AXP806's CLDO2 and AXP809's DLDO1 share the same range */
 790static const struct linear_range axp803_dldo2_ranges[] = {
 791	REGULATOR_LINEAR_RANGE(700000,
 792			       AXP803_DLDO2_700mV_START,
 793			       AXP803_DLDO2_700mV_END,
 794			       100000),
 795	REGULATOR_LINEAR_RANGE(3400000,
 796			       AXP803_DLDO2_3400mV_START,
 797			       AXP803_DLDO2_3400mV_END,
 798			       200000),
 799};
 800
 801static const struct regulator_desc axp803_regulators[] = {
 802	AXP_DESC(AXP803, DCDC1, "dcdc1", "vin1", 1600, 3400, 100,
 803		 AXP803_DCDC1_V_OUT, AXP803_DCDC1_V_OUT_MASK,
 804		 AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC1_MASK),
 805	AXP_DESC_RANGES(AXP803, DCDC2, "dcdc2", "vin2",
 806			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
 807			AXP803_DCDC2_V_OUT, AXP803_DCDC2_V_OUT_MASK,
 808			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC2_MASK),
 809	AXP_DESC_RANGES(AXP803, DCDC3, "dcdc3", "vin3",
 810			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
 811			AXP803_DCDC3_V_OUT, AXP803_DCDC3_V_OUT_MASK,
 812			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC3_MASK),
 813	AXP_DESC_RANGES(AXP803, DCDC4, "dcdc4", "vin4",
 814			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
 815			AXP803_DCDC4_V_OUT, AXP803_DCDC4_V_OUT_MASK,
 816			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC4_MASK),
 817	AXP_DESC_RANGES(AXP803, DCDC5, "dcdc5", "vin5",
 818			axp803_dcdc5_ranges, AXP803_DCDC5_NUM_VOLTAGES,
 819			AXP803_DCDC5_V_OUT, AXP803_DCDC5_V_OUT_MASK,
 820			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC5_MASK),
 821	AXP_DESC_RANGES(AXP803, DCDC6, "dcdc6", "vin6",
 822			axp803_dcdc6_ranges, AXP803_DCDC6_NUM_VOLTAGES,
 823			AXP803_DCDC6_V_OUT, AXP803_DCDC6_V_OUT_MASK,
 824			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC6_MASK),
 825	/* secondary switchable output of DCDC1 */
 826	AXP_DESC_SW(AXP803, DC1SW, "dc1sw", NULL,
 827		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DC1SW_MASK),
 828	AXP_DESC(AXP803, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
 829		 AXP22X_ALDO1_V_OUT, AXP22X_ALDO1_V_OUT_MASK,
 830		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO1_MASK),
 831	AXP_DESC(AXP803, ALDO2, "aldo2", "aldoin", 700, 3300, 100,
 832		 AXP22X_ALDO2_V_OUT, AXP22X_ALDO2_V_OUT_MASK,
 833		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO2_MASK),
 834	AXP_DESC(AXP803, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
 835		 AXP22X_ALDO3_V_OUT, AXP22X_ALDO3_V_OUT_MASK,
 836		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO3_MASK),
 837	AXP_DESC(AXP803, DLDO1, "dldo1", "dldoin", 700, 3300, 100,
 838		 AXP22X_DLDO1_V_OUT, AXP22X_DLDO1_V_OUT_MASK,
 839		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO1_MASK),
 840	AXP_DESC_RANGES(AXP803, DLDO2, "dldo2", "dldoin",
 841			axp803_dldo2_ranges, AXP803_DLDO2_NUM_VOLTAGES,
 842			AXP22X_DLDO2_V_OUT, AXP22X_DLDO2_V_OUT_MASK,
 843			AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO2_MASK),
 844	AXP_DESC(AXP803, DLDO3, "dldo3", "dldoin", 700, 3300, 100,
 845		 AXP22X_DLDO3_V_OUT, AXP22X_DLDO3_V_OUT_MASK,
 846		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO3_MASK),
 847	AXP_DESC(AXP803, DLDO4, "dldo4", "dldoin", 700, 3300, 100,
 848		 AXP22X_DLDO4_V_OUT, AXP22X_DLDO4_V_OUT_MASK,
 849		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO4_MASK),
 850	AXP_DESC(AXP803, ELDO1, "eldo1", "eldoin", 700, 1900, 50,
 851		 AXP22X_ELDO1_V_OUT, AXP22X_ELDO1_V_OUT_MASK,
 852		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO1_MASK),
 853	AXP_DESC(AXP803, ELDO2, "eldo2", "eldoin", 700, 1900, 50,
 854		 AXP22X_ELDO2_V_OUT, AXP22X_ELDO2_V_OUT_MASK,
 855		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO2_MASK),
 856	AXP_DESC(AXP803, ELDO3, "eldo3", "eldoin", 700, 1900, 50,
 857		 AXP22X_ELDO3_V_OUT, AXP22X_ELDO3_V_OUT_MASK,
 858		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO3_MASK),
 859	AXP_DESC(AXP803, FLDO1, "fldo1", "fldoin", 700, 1450, 50,
 860		 AXP803_FLDO1_V_OUT, AXP803_FLDO1_V_OUT_MASK,
 861		 AXP22X_PWR_OUT_CTRL3, AXP803_PWR_OUT_FLDO1_MASK),
 862	AXP_DESC(AXP803, FLDO2, "fldo2", "fldoin", 700, 1450, 50,
 863		 AXP803_FLDO2_V_OUT, AXP803_FLDO2_V_OUT_MASK,
 864		 AXP22X_PWR_OUT_CTRL3, AXP803_PWR_OUT_FLDO2_MASK),
 865	AXP_DESC_IO(AXP803, LDO_IO0, "ldo-io0", "ips", 700, 3300, 100,
 866		    AXP22X_LDO_IO0_V_OUT, AXP22X_LDO_IO0_V_OUT_MASK,
 867		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
 868		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 869	AXP_DESC_IO(AXP803, LDO_IO1, "ldo-io1", "ips", 700, 3300, 100,
 870		    AXP22X_LDO_IO1_V_OUT, AXP22X_LDO_IO1_V_OUT_MASK,
 871		    AXP20X_GPIO1_CTRL, AXP20X_GPIO1_FUNC_MASK,
 872		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
 873	AXP_DESC_FIXED(AXP803, RTC_LDO, "rtc-ldo", "ips", 3000),
 874};
 875
 876static const struct linear_range axp806_dcdca_ranges[] = {
 877	REGULATOR_LINEAR_RANGE(600000,
 878			       AXP806_DCDCA_600mV_START,
 879			       AXP806_DCDCA_600mV_END,
 880			       10000),
 881	REGULATOR_LINEAR_RANGE(1120000,
 882			       AXP806_DCDCA_1120mV_START,
 883			       AXP806_DCDCA_1120mV_END,
 884			       20000),
 885};
 886
 887static const struct linear_range axp806_dcdcd_ranges[] = {
 888	REGULATOR_LINEAR_RANGE(600000,
 889			       AXP806_DCDCD_600mV_START,
 890			       AXP806_DCDCD_600mV_END,
 891			       20000),
 892	REGULATOR_LINEAR_RANGE(1600000,
 893			       AXP806_DCDCD_1600mV_START,
 894			       AXP806_DCDCD_1600mV_END,
 895			       100000),
 896};
 897
 898static const struct regulator_desc axp806_regulators[] = {
 899	AXP_DESC_RANGES(AXP806, DCDCA, "dcdca", "vina",
 900			axp806_dcdca_ranges, AXP806_DCDCA_NUM_VOLTAGES,
 901			AXP806_DCDCA_V_CTRL, AXP806_DCDCA_V_CTRL_MASK,
 902			AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCA_MASK),
 903	AXP_DESC(AXP806, DCDCB, "dcdcb", "vinb", 1000, 2550, 50,
 904		 AXP806_DCDCB_V_CTRL, AXP806_DCDCB_V_CTRL_MASK,
 905		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCB_MASK),
 906	AXP_DESC_RANGES(AXP806, DCDCC, "dcdcc", "vinc",
 907			axp806_dcdca_ranges, AXP806_DCDCA_NUM_VOLTAGES,
 908			AXP806_DCDCC_V_CTRL, AXP806_DCDCC_V_CTRL_MASK,
 909			AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCC_MASK),
 910	AXP_DESC_RANGES(AXP806, DCDCD, "dcdcd", "vind",
 911			axp806_dcdcd_ranges, AXP806_DCDCD_NUM_VOLTAGES,
 912			AXP806_DCDCD_V_CTRL, AXP806_DCDCD_V_CTRL_MASK,
 913			AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCD_MASK),
 914	AXP_DESC(AXP806, DCDCE, "dcdce", "vine", 1100, 3400, 100,
 915		 AXP806_DCDCE_V_CTRL, AXP806_DCDCE_V_CTRL_MASK,
 916		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_DCDCE_MASK),
 917	AXP_DESC(AXP806, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
 918		 AXP806_ALDO1_V_CTRL, AXP806_ALDO1_V_CTRL_MASK,
 919		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_ALDO1_MASK),
 920	AXP_DESC(AXP806, ALDO2, "aldo2", "aldoin", 700, 3400, 100,
 921		 AXP806_ALDO2_V_CTRL, AXP806_ALDO2_V_CTRL_MASK,
 922		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_ALDO2_MASK),
 923	AXP_DESC(AXP806, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
 924		 AXP806_ALDO3_V_CTRL, AXP806_ALDO3_V_CTRL_MASK,
 925		 AXP806_PWR_OUT_CTRL1, AXP806_PWR_OUT_ALDO3_MASK),
 926	AXP_DESC(AXP806, BLDO1, "bldo1", "bldoin", 700, 1900, 100,
 927		 AXP806_BLDO1_V_CTRL, AXP806_BLDO1_V_CTRL_MASK,
 928		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_BLDO1_MASK),
 929	AXP_DESC(AXP806, BLDO2, "bldo2", "bldoin", 700, 1900, 100,
 930		 AXP806_BLDO2_V_CTRL, AXP806_BLDO2_V_CTRL_MASK,
 931		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_BLDO2_MASK),
 932	AXP_DESC(AXP806, BLDO3, "bldo3", "bldoin", 700, 1900, 100,
 933		 AXP806_BLDO3_V_CTRL, AXP806_BLDO3_V_CTRL_MASK,
 934		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_BLDO3_MASK),
 935	AXP_DESC(AXP806, BLDO4, "bldo4", "bldoin", 700, 1900, 100,
 936		 AXP806_BLDO4_V_CTRL, AXP806_BLDO4_V_CTRL_MASK,
 937		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_BLDO4_MASK),
 938	AXP_DESC(AXP806, CLDO1, "cldo1", "cldoin", 700, 3300, 100,
 939		 AXP806_CLDO1_V_CTRL, AXP806_CLDO1_V_CTRL_MASK,
 940		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_CLDO1_MASK),
 941	AXP_DESC_RANGES(AXP806, CLDO2, "cldo2", "cldoin",
 942			axp803_dldo2_ranges, AXP803_DLDO2_NUM_VOLTAGES,
 943			AXP806_CLDO2_V_CTRL, AXP806_CLDO2_V_CTRL_MASK,
 944			AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_CLDO2_MASK),
 945	AXP_DESC(AXP806, CLDO3, "cldo3", "cldoin", 700, 3300, 100,
 946		 AXP806_CLDO3_V_CTRL, AXP806_CLDO3_V_CTRL_MASK,
 947		 AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_CLDO3_MASK),
 948	AXP_DESC_SW(AXP806, SW, "sw", "swin",
 949		    AXP806_PWR_OUT_CTRL2, AXP806_PWR_OUT_SW_MASK),
 950};
 951
 952static const struct linear_range axp809_dcdc4_ranges[] = {
 953	REGULATOR_LINEAR_RANGE(600000,
 954			       AXP809_DCDC4_600mV_START,
 955			       AXP809_DCDC4_600mV_END,
 956			       20000),
 957	REGULATOR_LINEAR_RANGE(1800000,
 958			       AXP809_DCDC4_1800mV_START,
 959			       AXP809_DCDC4_1800mV_END,
 960			       100000),
 961};
 962
 963static const struct regulator_desc axp809_regulators[] = {
 964	AXP_DESC(AXP809, DCDC1, "dcdc1", "vin1", 1600, 3400, 100,
 965		 AXP22X_DCDC1_V_OUT, AXP22X_DCDC1_V_OUT_MASK,
 966		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC1_MASK),
 967	AXP_DESC(AXP809, DCDC2, "dcdc2", "vin2", 600, 1540, 20,
 968		 AXP22X_DCDC2_V_OUT, AXP22X_DCDC2_V_OUT_MASK,
 969		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC2_MASK),
 970	AXP_DESC(AXP809, DCDC3, "dcdc3", "vin3", 600, 1860, 20,
 971		 AXP22X_DCDC3_V_OUT, AXP22X_DCDC3_V_OUT_MASK,
 972		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC3_MASK),
 973	AXP_DESC_RANGES(AXP809, DCDC4, "dcdc4", "vin4",
 974			axp809_dcdc4_ranges, AXP809_DCDC4_NUM_VOLTAGES,
 975			AXP22X_DCDC4_V_OUT, AXP22X_DCDC4_V_OUT_MASK,
 976			AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC4_MASK),
 977	AXP_DESC(AXP809, DCDC5, "dcdc5", "vin5", 1000, 2550, 50,
 978		 AXP22X_DCDC5_V_OUT, AXP22X_DCDC5_V_OUT_MASK,
 979		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DCDC5_MASK),
 980	/* secondary switchable output of DCDC1 */
 981	AXP_DESC_SW(AXP809, DC1SW, "dc1sw", NULL,
 982		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DC1SW_MASK),
 983	/* LDO regulator internally chained to DCDC5 */
 984	AXP_DESC(AXP809, DC5LDO, "dc5ldo", NULL, 700, 1400, 100,
 985		 AXP22X_DC5LDO_V_OUT, AXP22X_DC5LDO_V_OUT_MASK,
 986		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_DC5LDO_MASK),
 987	AXP_DESC(AXP809, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
 988		 AXP22X_ALDO1_V_OUT, AXP22X_ALDO1_V_OUT_MASK,
 989		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_ALDO1_MASK),
 990	AXP_DESC(AXP809, ALDO2, "aldo2", "aldoin", 700, 3300, 100,
 991		 AXP22X_ALDO2_V_OUT, AXP22X_ALDO2_V_OUT_MASK,
 992		 AXP22X_PWR_OUT_CTRL1, AXP22X_PWR_OUT_ALDO2_MASK),
 993	AXP_DESC(AXP809, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
 994		 AXP22X_ALDO3_V_OUT, AXP22X_ALDO3_V_OUT_MASK,
 995		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ALDO3_MASK),
 996	AXP_DESC_RANGES(AXP809, DLDO1, "dldo1", "dldoin",
 997			axp803_dldo2_ranges, AXP803_DLDO2_NUM_VOLTAGES,
 998			AXP22X_DLDO1_V_OUT, AXP22X_DLDO1_V_OUT_MASK,
 999			AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO1_MASK),
1000	AXP_DESC(AXP809, DLDO2, "dldo2", "dldoin", 700, 3300, 100,
1001		 AXP22X_DLDO2_V_OUT, AXP22X_DLDO2_V_OUT_MASK,
1002		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO2_MASK),
1003	AXP_DESC(AXP809, ELDO1, "eldo1", "eldoin", 700, 3300, 100,
1004		 AXP22X_ELDO1_V_OUT, AXP22X_ELDO1_V_OUT_MASK,
1005		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO1_MASK),
1006	AXP_DESC(AXP809, ELDO2, "eldo2", "eldoin", 700, 3300, 100,
1007		 AXP22X_ELDO2_V_OUT, AXP22X_ELDO2_V_OUT_MASK,
1008		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO2_MASK),
1009	AXP_DESC(AXP809, ELDO3, "eldo3", "eldoin", 700, 3300, 100,
1010		 AXP22X_ELDO3_V_OUT, AXP22X_ELDO3_V_OUT_MASK,
1011		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO3_MASK),
1012	/*
1013	 * Note the datasheet only guarantees reliable operation up to
1014	 * 3.3V, this needs to be enforced via dts provided constraints
1015	 */
1016	AXP_DESC_IO(AXP809, LDO_IO0, "ldo_io0", "ips", 700, 3800, 100,
1017		    AXP22X_LDO_IO0_V_OUT, AXP22X_LDO_IO0_V_OUT_MASK,
1018		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
1019		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
1020	/*
1021	 * Note the datasheet only guarantees reliable operation up to
1022	 * 3.3V, this needs to be enforced via dts provided constraints
1023	 */
1024	AXP_DESC_IO(AXP809, LDO_IO1, "ldo_io1", "ips", 700, 3800, 100,
1025		    AXP22X_LDO_IO1_V_OUT, AXP22X_LDO_IO1_V_OUT_MASK,
1026		    AXP20X_GPIO1_CTRL, AXP20X_GPIO1_FUNC_MASK,
1027		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
1028	AXP_DESC_FIXED(AXP809, RTC_LDO, "rtc_ldo", "ips", 1800),
1029	AXP_DESC_SW(AXP809, SW, "sw", "swin",
1030		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_SW_MASK),
1031};
1032
1033static const struct regulator_desc axp813_regulators[] = {
1034	AXP_DESC(AXP813, DCDC1, "dcdc1", "vin1", 1600, 3400, 100,
1035		 AXP803_DCDC1_V_OUT, AXP803_DCDC1_V_OUT_MASK,
1036		 AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC1_MASK),
1037	AXP_DESC_RANGES(AXP813, DCDC2, "dcdc2", "vin2",
1038			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
1039			AXP803_DCDC2_V_OUT, AXP803_DCDC2_V_OUT_MASK,
1040			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC2_MASK),
1041	AXP_DESC_RANGES(AXP813, DCDC3, "dcdc3", "vin3",
1042			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
1043			AXP803_DCDC3_V_OUT, AXP803_DCDC3_V_OUT_MASK,
1044			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC3_MASK),
1045	AXP_DESC_RANGES(AXP813, DCDC4, "dcdc4", "vin4",
1046			axp803_dcdc234_ranges, AXP803_DCDC234_NUM_VOLTAGES,
1047			AXP803_DCDC4_V_OUT, AXP803_DCDC4_V_OUT_MASK,
1048			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC4_MASK),
1049	AXP_DESC_RANGES(AXP813, DCDC5, "dcdc5", "vin5",
1050			axp803_dcdc5_ranges, AXP803_DCDC5_NUM_VOLTAGES,
1051			AXP803_DCDC5_V_OUT, AXP803_DCDC5_V_OUT_MASK,
1052			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC5_MASK),
1053	AXP_DESC_RANGES(AXP813, DCDC6, "dcdc6", "vin6",
1054			axp803_dcdc6_ranges, AXP803_DCDC6_NUM_VOLTAGES,
1055			AXP803_DCDC6_V_OUT, AXP803_DCDC6_V_OUT_MASK,
1056			AXP22X_PWR_OUT_CTRL1, AXP803_PWR_OUT_DCDC6_MASK),
1057	AXP_DESC_RANGES(AXP813, DCDC7, "dcdc7", "vin7",
1058			axp803_dcdc6_ranges, AXP803_DCDC6_NUM_VOLTAGES,
1059			AXP813_DCDC7_V_OUT, AXP813_DCDC7_V_OUT_MASK,
1060			AXP22X_PWR_OUT_CTRL1, AXP813_PWR_OUT_DCDC7_MASK),
1061	AXP_DESC(AXP813, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
1062		 AXP22X_ALDO1_V_OUT, AXP22X_ALDO1_V_OUT_MASK,
1063		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO1_MASK),
1064	AXP_DESC(AXP813, ALDO2, "aldo2", "aldoin", 700, 3300, 100,
1065		 AXP22X_ALDO2_V_OUT, AXP22X_ALDO2_V_OUT_MASK,
1066		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO2_MASK),
1067	AXP_DESC(AXP813, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
1068		 AXP22X_ALDO3_V_OUT, AXP22X_ALDO3_V_OUT_MASK,
1069		 AXP22X_PWR_OUT_CTRL3, AXP806_PWR_OUT_ALDO3_MASK),
1070	AXP_DESC(AXP813, DLDO1, "dldo1", "dldoin", 700, 3300, 100,
1071		 AXP22X_DLDO1_V_OUT, AXP22X_DLDO1_V_OUT_MASK,
1072		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO1_MASK),
1073	AXP_DESC_RANGES(AXP813, DLDO2, "dldo2", "dldoin",
1074			axp803_dldo2_ranges, AXP803_DLDO2_NUM_VOLTAGES,
1075			AXP22X_DLDO2_V_OUT, AXP22X_DLDO2_V_OUT_MASK,
1076			AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO2_MASK),
1077	AXP_DESC(AXP813, DLDO3, "dldo3", "dldoin", 700, 3300, 100,
1078		 AXP22X_DLDO3_V_OUT, AXP22X_DLDO3_V_OUT_MASK,
1079		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO3_MASK),
1080	AXP_DESC(AXP813, DLDO4, "dldo4", "dldoin", 700, 3300, 100,
1081		 AXP22X_DLDO4_V_OUT, AXP22X_DLDO4_V_OUT_MASK,
1082		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DLDO4_MASK),
1083	AXP_DESC(AXP813, ELDO1, "eldo1", "eldoin", 700, 1900, 50,
1084		 AXP22X_ELDO1_V_OUT, AXP22X_ELDO1_V_OUT_MASK,
1085		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO1_MASK),
1086	AXP_DESC(AXP813, ELDO2, "eldo2", "eldoin", 700, 1900, 50,
1087		 AXP22X_ELDO2_V_OUT, AXP22X_ELDO2_V_OUT_MASK,
1088		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO2_MASK),
1089	AXP_DESC(AXP813, ELDO3, "eldo3", "eldoin", 700, 1900, 50,
1090		 AXP22X_ELDO3_V_OUT, AXP22X_ELDO3_V_OUT_MASK,
1091		 AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_ELDO3_MASK),
1092	/* to do / check ... */
1093	AXP_DESC(AXP813, FLDO1, "fldo1", "fldoin", 700, 1450, 50,
1094		 AXP803_FLDO1_V_OUT, AXP803_FLDO1_V_OUT_MASK,
1095		 AXP22X_PWR_OUT_CTRL3, AXP803_PWR_OUT_FLDO1_MASK),
1096	AXP_DESC(AXP813, FLDO2, "fldo2", "fldoin", 700, 1450, 50,
1097		 AXP803_FLDO2_V_OUT, AXP803_FLDO2_V_OUT_MASK,
1098		 AXP22X_PWR_OUT_CTRL3, AXP803_PWR_OUT_FLDO2_MASK),
1099	/*
1100	 * TODO: FLDO3 = {DCDC5, FLDOIN} / 2
1101	 *
1102	 * This means FLDO3 effectively switches supplies at runtime,
1103	 * something the regulator subsystem does not support.
1104	 */
1105	AXP_DESC_FIXED(AXP813, RTC_LDO, "rtc-ldo", "ips", 1800),
1106	AXP_DESC_IO(AXP813, LDO_IO0, "ldo-io0", "ips", 700, 3300, 100,
1107		    AXP22X_LDO_IO0_V_OUT, AXP22X_LDO_IO0_V_OUT_MASK,
1108		    AXP20X_GPIO0_CTRL, AXP20X_GPIO0_FUNC_MASK,
1109		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
1110	AXP_DESC_IO(AXP813, LDO_IO1, "ldo-io1", "ips", 700, 3300, 100,
1111		    AXP22X_LDO_IO1_V_OUT, AXP22X_LDO_IO1_V_OUT_MASK,
1112		    AXP20X_GPIO1_CTRL, AXP20X_GPIO1_FUNC_MASK,
1113		    AXP22X_IO_ENABLED, AXP22X_IO_DISABLED),
1114	AXP_DESC_SW(AXP813, SW, "sw", "swin",
1115		    AXP22X_PWR_OUT_CTRL2, AXP22X_PWR_OUT_DC1SW_MASK),
1116};
1117
1118static const struct linear_range axp15060_dcdc234_ranges[] = {
1119	REGULATOR_LINEAR_RANGE(500000,
1120			       AXP15060_DCDC234_500mV_START,
1121			       AXP15060_DCDC234_500mV_END,
1122			       10000),
1123	REGULATOR_LINEAR_RANGE(1220000,
1124			       AXP15060_DCDC234_1220mV_START,
1125			       AXP15060_DCDC234_1220mV_END,
1126			       20000),
1127};
1128
1129static const struct linear_range axp15060_dcdc5_ranges[] = {
1130	REGULATOR_LINEAR_RANGE(800000,
1131			       AXP15060_DCDC5_800mV_START,
1132			       AXP15060_DCDC5_800mV_END,
1133			       10000),
1134	REGULATOR_LINEAR_RANGE(1140000,
1135			       AXP15060_DCDC5_1140mV_START,
1136			       AXP15060_DCDC5_1140mV_END,
1137			       20000),
1138};
1139
1140static const struct regulator_desc axp15060_regulators[] = {
1141	AXP_DESC(AXP15060, DCDC1, "dcdc1", "vin1", 1500, 3400, 100,
1142		 AXP15060_DCDC1_V_CTRL, AXP15060_DCDC1_V_CTRL_MASK,
1143		 AXP15060_PWR_OUT_CTRL1, AXP15060_PWR_OUT_DCDC1_MASK),
1144	AXP_DESC_RANGES(AXP15060, DCDC2, "dcdc2", "vin2",
1145			axp15060_dcdc234_ranges, AXP15060_DCDC234_NUM_VOLTAGES,
1146			AXP15060_DCDC2_V_CTRL, AXP15060_DCDC2_V_CTRL_MASK,
1147			AXP15060_PWR_OUT_CTRL1, AXP15060_PWR_OUT_DCDC2_MASK),
1148	AXP_DESC_RANGES(AXP15060, DCDC3, "dcdc3", "vin3",
1149			axp15060_dcdc234_ranges, AXP15060_DCDC234_NUM_VOLTAGES,
1150			AXP15060_DCDC3_V_CTRL, AXP15060_DCDC3_V_CTRL_MASK,
1151			AXP15060_PWR_OUT_CTRL1, AXP15060_PWR_OUT_DCDC3_MASK),
1152	AXP_DESC_RANGES(AXP15060, DCDC4, "dcdc4", "vin4",
1153			axp15060_dcdc234_ranges, AXP15060_DCDC234_NUM_VOLTAGES,
1154			AXP15060_DCDC4_V_CTRL, AXP15060_DCDC4_V_CTRL_MASK,
1155			AXP15060_PWR_OUT_CTRL1, AXP15060_PWR_OUT_DCDC4_MASK),
1156	AXP_DESC_RANGES(AXP15060, DCDC5, "dcdc5", "vin5",
1157			axp15060_dcdc5_ranges, AXP15060_DCDC5_NUM_VOLTAGES,
1158			AXP15060_DCDC5_V_CTRL, AXP15060_DCDC5_V_CTRL_MASK,
1159			AXP15060_PWR_OUT_CTRL1, AXP15060_PWR_OUT_DCDC5_MASK),
1160	AXP_DESC(AXP15060, DCDC6, "dcdc6", "vin6", 500, 3400, 100,
1161		 AXP15060_DCDC6_V_CTRL, AXP15060_DCDC6_V_CTRL_MASK,
1162		 AXP15060_PWR_OUT_CTRL1, AXP15060_PWR_OUT_DCDC6_MASK),
1163	AXP_DESC(AXP15060, ALDO1, "aldo1", "aldoin", 700, 3300, 100,
1164		 AXP15060_ALDO1_V_CTRL, AXP15060_ALDO1_V_CTRL_MASK,
1165		 AXP15060_PWR_OUT_CTRL2, AXP15060_PWR_OUT_ALDO1_MASK),
1166	AXP_DESC(AXP15060, ALDO2, "aldo2", "aldoin", 700, 3300, 100,
1167		 AXP15060_ALDO2_V_CTRL, AXP15060_ALDO2_V_CTRL_MASK,
1168		 AXP15060_PWR_OUT_CTRL2, AXP15060_PWR_OUT_ALDO2_MASK),
1169	AXP_DESC(AXP15060, ALDO3, "aldo3", "aldoin", 700, 3300, 100,
1170		 AXP15060_ALDO3_V_CTRL, AXP15060_ALDO3_V_CTRL_MASK,
1171		 AXP15060_PWR_OUT_CTRL2, AXP15060_PWR_OUT_ALDO3_MASK),
1172	AXP_DESC(AXP15060, ALDO4, "aldo4", "aldoin", 700, 3300, 100,
1173		 AXP15060_ALDO4_V_CTRL, AXP15060_ALDO4_V_CTRL_MASK,
1174		 AXP15060_PWR_OUT_CTRL2, AXP15060_PWR_OUT_ALDO4_MASK),
1175	AXP_DESC(AXP15060, ALDO5, "aldo5", "aldoin", 700, 3300, 100,
1176		 AXP15060_ALDO5_V_CTRL, AXP15060_ALDO5_V_CTRL_MASK,
1177		 AXP15060_PWR_OUT_CTRL2, AXP15060_PWR_OUT_ALDO5_MASK),
1178	AXP_DESC(AXP15060, BLDO1, "bldo1", "bldoin", 700, 3300, 100,
1179		 AXP15060_BLDO1_V_CTRL, AXP15060_BLDO1_V_CTRL_MASK,
1180		 AXP15060_PWR_OUT_CTRL2, AXP15060_PWR_OUT_BLDO1_MASK),
1181	AXP_DESC(AXP15060, BLDO2, "bldo2", "bldoin", 700, 3300, 100,
1182		 AXP15060_BLDO2_V_CTRL, AXP15060_BLDO2_V_CTRL_MASK,
1183		 AXP15060_PWR_OUT_CTRL2, AXP15060_PWR_OUT_BLDO2_MASK),
1184	AXP_DESC(AXP15060, BLDO3, "bldo3", "bldoin", 700, 3300, 100,
1185		 AXP15060_BLDO3_V_CTRL, AXP15060_BLDO3_V_CTRL_MASK,
1186		 AXP15060_PWR_OUT_CTRL2, AXP15060_PWR_OUT_BLDO3_MASK),
1187	AXP_DESC(AXP15060, BLDO4, "bldo4", "bldoin", 700, 3300, 100,
1188		 AXP15060_BLDO4_V_CTRL, AXP15060_BLDO4_V_CTRL_MASK,
1189		 AXP15060_PWR_OUT_CTRL3, AXP15060_PWR_OUT_BLDO4_MASK),
1190	AXP_DESC(AXP15060, BLDO5, "bldo5", "bldoin", 700, 3300, 100,
1191		 AXP15060_BLDO5_V_CTRL, AXP15060_BLDO5_V_CTRL_MASK,
1192		 AXP15060_PWR_OUT_CTRL3, AXP15060_PWR_OUT_BLDO5_MASK),
1193	AXP_DESC(AXP15060, CLDO1, "cldo1", "cldoin", 700, 3300, 100,
1194		 AXP15060_CLDO1_V_CTRL, AXP15060_CLDO1_V_CTRL_MASK,
1195		 AXP15060_PWR_OUT_CTRL3, AXP15060_PWR_OUT_CLDO1_MASK),
1196	AXP_DESC(AXP15060, CLDO2, "cldo2", "cldoin", 700, 3300, 100,
1197		 AXP15060_CLDO2_V_CTRL, AXP15060_CLDO2_V_CTRL_MASK,
1198		 AXP15060_PWR_OUT_CTRL3, AXP15060_PWR_OUT_CLDO2_MASK),
1199	AXP_DESC(AXP15060, CLDO3, "cldo3", "cldoin", 700, 3300, 100,
1200		 AXP15060_CLDO3_V_CTRL, AXP15060_CLDO3_V_CTRL_MASK,
1201		 AXP15060_PWR_OUT_CTRL3, AXP15060_PWR_OUT_CLDO3_MASK),
1202	AXP_DESC(AXP15060, CLDO4, "cldo4", "cldoin", 700, 4200, 100,
1203		 AXP15060_CLDO4_V_CTRL, AXP15060_CLDO4_V_CTRL_MASK,
1204		 AXP15060_PWR_OUT_CTRL3, AXP15060_PWR_OUT_CLDO4_MASK),
1205	/* Supply comes from DCDC5 */
1206	AXP_DESC(AXP15060, CPUSLDO, "cpusldo", NULL, 700, 1400, 50,
1207		 AXP15060_CPUSLDO_V_CTRL, AXP15060_CPUSLDO_V_CTRL_MASK,
1208		 AXP15060_PWR_OUT_CTRL3, AXP15060_PWR_OUT_CPUSLDO_MASK),
1209	/* Supply comes from DCDC1 */
1210	AXP_DESC_SW(AXP15060, SW, "sw", NULL,
1211		    AXP15060_PWR_OUT_CTRL3, AXP15060_PWR_OUT_SW_MASK),
1212	/* Supply comes from ALDO1 */
1213	AXP_DESC_FIXED(AXP15060, RTC_LDO, "rtc-ldo", NULL, 1800),
1214};
1215
1216static int axp20x_set_dcdc_freq(struct platform_device *pdev, u32 dcdcfreq)
1217{
1218	struct axp20x_dev *axp20x = dev_get_drvdata(pdev->dev.parent);
1219	unsigned int reg = AXP20X_DCDC_FREQ;
1220	u32 min, max, def, step;
1221
1222	switch (axp20x->variant) {
1223	case AXP202_ID:
1224	case AXP209_ID:
1225		min = 750;
1226		max = 1875;
1227		def = 1500;
1228		step = 75;
1229		break;
1230	case AXP803_ID:
1231	case AXP813_ID:
1232		/*
1233		 * AXP803/AXP813 DCDC work frequency setting has the same
1234		 * range and step as AXP22X, but at a different register.
1235		 * (See include/linux/mfd/axp20x.h)
1236		 */
1237		reg = AXP803_DCDC_FREQ_CTRL;
1238		fallthrough;	/* to the check below */
1239	case AXP806_ID:
1240		/*
1241		 * AXP806 also have DCDC work frequency setting register at a
1242		 * different position.
1243		 */
1244		if (axp20x->variant == AXP806_ID)
1245			reg = AXP806_DCDC_FREQ_CTRL;
1246		fallthrough;
1247	case AXP221_ID:
1248	case AXP223_ID:
1249	case AXP809_ID:
1250		min = 1800;
1251		max = 4050;
1252		def = 3000;
1253		step = 150;
1254		break;
1255	case AXP313A_ID:
1256	case AXP15060_ID:
1257		/* The DCDC PWM frequency seems to be fixed to 3 MHz. */
1258		if (dcdcfreq != 0) {
1259			dev_err(&pdev->dev,
1260				"DCDC frequency on this PMIC is fixed to 3 MHz.\n");
1261			return -EINVAL;
1262		}
1263
1264		return 0;
1265	default:
1266		dev_err(&pdev->dev,
1267			"Setting DCDC frequency for unsupported AXP variant\n");
1268		return -EINVAL;
1269	}
1270
1271	if (dcdcfreq == 0)
1272		dcdcfreq = def;
1273
1274	if (dcdcfreq < min) {
1275		dcdcfreq = min;
1276		dev_warn(&pdev->dev, "DCDC frequency too low. Set to %ukHz\n",
1277			 min);
1278	}
1279
1280	if (dcdcfreq > max) {
1281		dcdcfreq = max;
1282		dev_warn(&pdev->dev, "DCDC frequency too high. Set to %ukHz\n",
1283			 max);
1284	}
1285
1286	dcdcfreq = (dcdcfreq - min) / step;
1287
1288	return regmap_update_bits(axp20x->regmap, reg,
1289				  AXP20X_FREQ_DCDC_MASK, dcdcfreq);
1290}
1291
1292static int axp20x_regulator_parse_dt(struct platform_device *pdev)
1293{
1294	struct device_node *np, *regulators;
1295	int ret = 0;
1296	u32 dcdcfreq = 0;
1297
1298	np = of_node_get(pdev->dev.parent->of_node);
1299	if (!np)
1300		return 0;
1301
1302	regulators = of_get_child_by_name(np, "regulators");
1303	if (!regulators) {
1304		dev_warn(&pdev->dev, "regulators node not found\n");
1305	} else {
1306		of_property_read_u32(regulators, "x-powers,dcdc-freq", &dcdcfreq);
1307		ret = axp20x_set_dcdc_freq(pdev, dcdcfreq);
1308		if (ret < 0) {
1309			dev_err(&pdev->dev, "Error setting dcdc frequency: %d\n", ret);
1310		}
1311		of_node_put(regulators);
1312	}
1313
1314	of_node_put(np);
1315	return ret;
1316}
1317
1318static int axp20x_set_dcdc_workmode(struct regulator_dev *rdev, int id, u32 workmode)
1319{
1320	struct axp20x_dev *axp20x = rdev_get_drvdata(rdev);
1321	unsigned int reg = AXP20X_DCDC_MODE;
1322	unsigned int mask;
1323
1324	switch (axp20x->variant) {
1325	case AXP202_ID:
1326	case AXP209_ID:
1327		if ((id != AXP20X_DCDC2) && (id != AXP20X_DCDC3))
1328			return -EINVAL;
1329
1330		mask = AXP20X_WORKMODE_DCDC2_MASK;
1331		if (id == AXP20X_DCDC3)
1332			mask = AXP20X_WORKMODE_DCDC3_MASK;
1333
1334		workmode <<= ffs(mask) - 1;
1335		break;
1336
1337	case AXP806_ID:
1338		/*
1339		 * AXP806 DCDC regulator IDs have the same range as AXP22X.
1340		 * (See include/linux/mfd/axp20x.h)
1341		 */
1342		reg = AXP806_DCDC_MODE_CTRL2;
1343		fallthrough;	/* to the check below */
1344	case AXP221_ID:
1345	case AXP223_ID:
1346	case AXP809_ID:
1347		if (id < AXP22X_DCDC1 || id > AXP22X_DCDC5)
1348			return -EINVAL;
1349
1350		mask = AXP22X_WORKMODE_DCDCX_MASK(id - AXP22X_DCDC1);
1351		workmode <<= id - AXP22X_DCDC1;
1352		break;
1353
1354	case AXP803_ID:
1355		if (id < AXP803_DCDC1 || id > AXP803_DCDC6)
1356			return -EINVAL;
1357
1358		mask = AXP22X_WORKMODE_DCDCX_MASK(id - AXP803_DCDC1);
1359		workmode <<= id - AXP803_DCDC1;
1360		break;
1361
1362	case AXP813_ID:
1363		if (id < AXP813_DCDC1 || id > AXP813_DCDC7)
1364			return -EINVAL;
1365
1366		mask = AXP22X_WORKMODE_DCDCX_MASK(id - AXP813_DCDC1);
1367		workmode <<= id - AXP813_DCDC1;
1368		break;
1369
1370	case AXP15060_ID:
1371		reg = AXP15060_DCDC_MODE_CTRL2;
1372		if (id < AXP15060_DCDC1 || id > AXP15060_DCDC6)
1373			return -EINVAL;
1374
1375		mask = AXP22X_WORKMODE_DCDCX_MASK(id - AXP15060_DCDC1);
1376		workmode <<= id - AXP15060_DCDC1;
1377		break;
1378
1379	default:
1380		/* should not happen */
1381		WARN_ON(1);
1382		return -EINVAL;
1383	}
1384
1385	return regmap_update_bits(rdev->regmap, reg, mask, workmode);
1386}
1387
1388/*
1389 * This function checks whether a regulator is part of a poly-phase
1390 * output setup based on the registers settings. Returns true if it is.
1391 */
1392static bool axp20x_is_polyphase_slave(struct axp20x_dev *axp20x, int id)
1393{
1394	u32 reg = 0;
1395
1396	/*
1397	 * Currently in our supported AXP variants, only AXP803, AXP806,
1398	 * AXP813 and AXP15060 have polyphase regulators.
1399	 */
1400	switch (axp20x->variant) {
1401	case AXP803_ID:
1402	case AXP813_ID:
1403		regmap_read(axp20x->regmap, AXP803_POLYPHASE_CTRL, &reg);
1404
1405		switch (id) {
1406		case AXP803_DCDC3:
1407			return !!(reg & AXP803_DCDC23_POLYPHASE_DUAL);
1408		case AXP803_DCDC6:
1409			return !!(reg & AXP803_DCDC56_POLYPHASE_DUAL);
1410		}
1411		break;
1412
1413	case AXP806_ID:
1414		regmap_read(axp20x->regmap, AXP806_DCDC_MODE_CTRL2, &reg);
1415
1416		switch (id) {
1417		case AXP806_DCDCB:
1418			return (((reg & AXP806_DCDCABC_POLYPHASE_MASK) ==
1419				AXP806_DCDCAB_POLYPHASE_DUAL) ||
1420				((reg & AXP806_DCDCABC_POLYPHASE_MASK) ==
1421				AXP806_DCDCABC_POLYPHASE_TRI));
1422		case AXP806_DCDCC:
1423			return ((reg & AXP806_DCDCABC_POLYPHASE_MASK) ==
1424				AXP806_DCDCABC_POLYPHASE_TRI);
1425		case AXP806_DCDCE:
1426			return !!(reg & AXP806_DCDCDE_POLYPHASE_DUAL);
1427		}
1428		break;
1429
1430	case AXP15060_ID:
1431		regmap_read(axp20x->regmap, AXP15060_DCDC_MODE_CTRL1, &reg);
1432
1433		switch (id) {
1434		case AXP15060_DCDC3:
1435			return !!(reg & AXP15060_DCDC23_POLYPHASE_DUAL_MASK);
1436		case AXP15060_DCDC6:
1437			return !!(reg & AXP15060_DCDC46_POLYPHASE_DUAL_MASK);
1438		}
1439		break;
1440
1441	default:
1442		return false;
1443	}
1444
1445	return false;
1446}
1447
1448static int axp20x_regulator_probe(struct platform_device *pdev)
1449{
1450	struct regulator_dev *rdev;
1451	struct axp20x_dev *axp20x = dev_get_drvdata(pdev->dev.parent);
1452	const struct regulator_desc *regulators;
1453	struct regulator_config config = {
1454		.dev = pdev->dev.parent,
1455		.regmap = axp20x->regmap,
1456		.driver_data = axp20x,
1457	};
1458	int ret, i, nregulators;
1459	u32 workmode;
1460	const char *dcdc1_name = axp22x_regulators[AXP22X_DCDC1].name;
1461	const char *dcdc5_name = axp22x_regulators[AXP22X_DCDC5].name;
1462	const char *aldo1_name = axp15060_regulators[AXP15060_ALDO1].name;
1463	bool drivevbus = false;
1464
1465	switch (axp20x->variant) {
1466	case AXP202_ID:
1467	case AXP209_ID:
1468		regulators = axp20x_regulators;
1469		nregulators = AXP20X_REG_ID_MAX;
1470		break;
1471	case AXP221_ID:
1472	case AXP223_ID:
1473		regulators = axp22x_regulators;
1474		nregulators = AXP22X_REG_ID_MAX;
1475		drivevbus = of_property_read_bool(pdev->dev.parent->of_node,
1476						  "x-powers,drive-vbus-en");
1477		break;
1478	case AXP313A_ID:
1479		regulators = axp313a_regulators;
1480		nregulators = AXP313A_REG_ID_MAX;
1481		break;
1482	case AXP803_ID:
1483		regulators = axp803_regulators;
1484		nregulators = AXP803_REG_ID_MAX;
1485		drivevbus = of_property_read_bool(pdev->dev.parent->of_node,
1486						  "x-powers,drive-vbus-en");
1487		break;
1488	case AXP806_ID:
1489		regulators = axp806_regulators;
1490		nregulators = AXP806_REG_ID_MAX;
1491		break;
1492	case AXP809_ID:
1493		regulators = axp809_regulators;
1494		nregulators = AXP809_REG_ID_MAX;
1495		break;
1496	case AXP813_ID:
1497		regulators = axp813_regulators;
1498		nregulators = AXP813_REG_ID_MAX;
1499		drivevbus = of_property_read_bool(pdev->dev.parent->of_node,
1500						  "x-powers,drive-vbus-en");
1501		break;
1502	case AXP15060_ID:
1503		regulators = axp15060_regulators;
1504		nregulators = AXP15060_REG_ID_MAX;
1505		break;
1506	default:
1507		dev_err(&pdev->dev, "Unsupported AXP variant: %ld\n",
1508			axp20x->variant);
1509		return -EINVAL;
1510	}
1511
1512	/* This only sets the dcdc freq. Ignore any errors */
1513	axp20x_regulator_parse_dt(pdev);
1514
1515	for (i = 0; i < nregulators; i++) {
1516		const struct regulator_desc *desc = &regulators[i];
1517		struct regulator_desc *new_desc;
1518
1519		/*
1520		 * If this regulator is a slave in a poly-phase setup,
1521		 * skip it, as its controls are bound to the master
1522		 * regulator and won't work.
1523		 */
1524		if (axp20x_is_polyphase_slave(axp20x, i))
1525			continue;
1526
1527		/* Support for AXP813's FLDO3 is not implemented */
1528		if (axp20x->variant == AXP813_ID && i == AXP813_FLDO3)
1529			continue;
1530
1531		/*
1532		 * Regulators DC1SW, DC5LDO and RTCLDO on AXP15060 are
1533		 * connected internally, so we have to handle their supply
1534		 * names separately.
1535		 *
1536		 * We always register the regulators in proper sequence,
1537		 * so the supply names are correctly read. See the last
1538		 * part of this loop to see where we save the DT defined
1539		 * name.
1540		 */
1541		if ((regulators == axp22x_regulators && i == AXP22X_DC1SW) ||
1542		    (regulators == axp803_regulators && i == AXP803_DC1SW) ||
1543		    (regulators == axp809_regulators && i == AXP809_DC1SW) ||
1544		    (regulators == axp15060_regulators && i == AXP15060_SW)) {
1545			new_desc = devm_kzalloc(&pdev->dev, sizeof(*desc),
1546						GFP_KERNEL);
1547			if (!new_desc)
1548				return -ENOMEM;
1549
1550			*new_desc = regulators[i];
1551			new_desc->supply_name = dcdc1_name;
1552			desc = new_desc;
1553		}
1554
1555		if ((regulators == axp22x_regulators && i == AXP22X_DC5LDO) ||
1556		    (regulators == axp809_regulators && i == AXP809_DC5LDO) ||
1557		    (regulators == axp15060_regulators && i == AXP15060_CPUSLDO)) {
1558			new_desc = devm_kzalloc(&pdev->dev, sizeof(*desc),
1559						GFP_KERNEL);
1560			if (!new_desc)
1561				return -ENOMEM;
1562
1563			*new_desc = regulators[i];
1564			new_desc->supply_name = dcdc5_name;
1565			desc = new_desc;
1566		}
1567
1568
1569		if (regulators == axp15060_regulators && i == AXP15060_RTC_LDO) {
1570			new_desc = devm_kzalloc(&pdev->dev, sizeof(*desc),
1571						GFP_KERNEL);
1572			if (!new_desc)
1573				return -ENOMEM;
1574
1575			*new_desc = regulators[i];
1576			new_desc->supply_name = aldo1_name;
1577			desc = new_desc;
1578		}
1579
1580		rdev = devm_regulator_register(&pdev->dev, desc, &config);
1581		if (IS_ERR(rdev)) {
1582			dev_err(&pdev->dev, "Failed to register %s\n",
1583				regulators[i].name);
1584
1585			return PTR_ERR(rdev);
1586		}
1587
1588		ret = of_property_read_u32(rdev->dev.of_node,
1589					   "x-powers,dcdc-workmode",
1590					   &workmode);
1591		if (!ret) {
1592			if (axp20x_set_dcdc_workmode(rdev, i, workmode))
1593				dev_err(&pdev->dev, "Failed to set workmode on %s\n",
1594					rdev->desc->name);
1595		}
1596
1597		/*
1598		 * Save AXP22X DCDC1 / DCDC5 / AXP15060 ALDO1 regulator names for later.
1599		 */
1600		if ((regulators == axp22x_regulators && i == AXP22X_DCDC1) ||
1601		    (regulators == axp809_regulators && i == AXP809_DCDC1) ||
1602		    (regulators == axp15060_regulators && i == AXP15060_DCDC1))
1603			of_property_read_string(rdev->dev.of_node,
1604						"regulator-name",
1605						&dcdc1_name);
1606
1607		if ((regulators == axp22x_regulators && i == AXP22X_DCDC5) ||
1608		    (regulators == axp809_regulators && i == AXP809_DCDC5) ||
1609		    (regulators == axp15060_regulators && i == AXP15060_DCDC5))
1610			of_property_read_string(rdev->dev.of_node,
1611						"regulator-name",
1612						&dcdc5_name);
1613
1614		if (regulators == axp15060_regulators && i == AXP15060_ALDO1)
1615			of_property_read_string(rdev->dev.of_node,
1616						"regulator-name",
1617						&aldo1_name);
1618	}
1619
1620	if (drivevbus) {
1621		/* Change N_VBUSEN sense pin to DRIVEVBUS output pin */
1622		regmap_update_bits(axp20x->regmap, AXP20X_OVER_TMP,
1623				   AXP22X_MISC_N_VBUSEN_FUNC, 0);
1624		rdev = devm_regulator_register(&pdev->dev,
1625					       &axp22x_drivevbus_regulator,
1626					       &config);
1627		if (IS_ERR(rdev)) {
1628			dev_err(&pdev->dev, "Failed to register drivevbus\n");
1629			return PTR_ERR(rdev);
1630		}
1631	}
1632
1633	return 0;
1634}
1635
1636static struct platform_driver axp20x_regulator_driver = {
1637	.probe	= axp20x_regulator_probe,
1638	.driver	= {
1639		.name		= "axp20x-regulator",
1640		.probe_type	= PROBE_PREFER_ASYNCHRONOUS,
1641	},
1642};
1643
1644module_platform_driver(axp20x_regulator_driver);
1645
1646MODULE_LICENSE("GPL v2");
1647MODULE_AUTHOR("Carlo Caione <carlo@caione.org>");
1648MODULE_DESCRIPTION("Regulator Driver for AXP20X PMIC");
1649MODULE_ALIAS("platform:axp20x-regulator");