2018-08-07 18:18:25 +02:00
// SPDX-License-Identifier: GPL-2.0+
//
// max77686.c - Regulator driver for the Maxim 77686
//
// Copyright (C) 2012 Samsung Electronics
// Chiwoong Byun <woong.byun@samsung.com>
// Jonghwa Lee <jonghwa3.lee@samsung.com>
//
// This driver is based on max8997.c
2012-06-01 13:17:14 +09:00
# include <linux/kernel.h>
# include <linux/bug.h>
# include <linux/err.h>
2018-11-15 09:01:19 +01:00
# include <linux/gpio/consumer.h>
2012-06-01 13:17:14 +09:00
# include <linux/slab.h>
# include <linux/platform_device.h>
# include <linux/regulator/driver.h>
# include <linux/regulator/machine.h>
2012-07-05 09:28:25 +05:30
# include <linux/regulator/of_regulator.h>
2012-06-01 13:17:14 +09:00
# include <linux/mfd/max77686.h>
# include <linux/mfd/max77686-private.h>
# define MAX77686_LDO_MINUV 800000
# define MAX77686_LDO_UVSTEP 50000
# define MAX77686_LDO_LOW_MINUV 800000
# define MAX77686_LDO_LOW_UVSTEP 25000
# define MAX77686_BUCK_MINUV 750000
# define MAX77686_BUCK_UVSTEP 50000
2016-04-29 12:59:51 +02:00
# define MAX77686_BUCK_ENABLE_TIME 40 /* us */
# define MAX77686_DVS_ENABLE_TIME 22 /* us */
2012-06-19 13:23:42 +05:30
# define MAX77686_RAMP_DELAY 100000 /* uV/us */
# define MAX77686_DVS_RAMP_DELAY 27500 /* uV/us */
2012-06-01 13:17:14 +09:00
# define MAX77686_DVS_MINUV 600000
# define MAX77686_DVS_UVSTEP 12500
2015-01-05 12:48:43 +01:00
/*
* Value for configuring buck [ 89 ] and LDO { 20 , 21 , 22 } as GPIO control .
* It is the same as ' off ' for other regulators .
*/
# define MAX77686_GPIO_CONTROL 0x0
2014-10-27 13:11:47 +01:00
/*
* Values used for configuring LDOs and bucks .
* Forcing low power mode : LDO1 , 3 - 5 , 9 , 13 , 17 - 26
*/
# define MAX77686_LDO_LOWPOWER 0x1
/*
* On / off controlled by PWRREQ :
* - LDO2 , 6 - 8 , 10 - 12 , 14 - 16
* - buck [ 1234 ]
*/
# define MAX77686_OFF_PWRREQ 0x1
/* Low power mode controlled by PWRREQ: All LDOs */
# define MAX77686_LDO_LOWPOWER_PWRREQ 0x2
/* Forcing low power mode: buck[234] */
# define MAX77686_BUCK_LOWPOWER 0x2
# define MAX77686_NORMAL 0x3
2012-06-01 13:17:14 +09:00
# define MAX77686_OPMODE_SHIFT 6
# define MAX77686_OPMODE_BUCK234_SHIFT 4
# define MAX77686_OPMODE_MASK 0x3
# define MAX77686_VSEL_MASK 0x3F
# define MAX77686_DVS_VSEL_MASK 0xFF
# define MAX77686_RAMP_RATE_MASK 0xC0
# define MAX77686_REGULATORS MAX77686_REG_MAX
# define MAX77686_LDOS 26
enum max77686_ramp_rate {
RAMP_RATE_13P75MV ,
RAMP_RATE_27P5MV ,
RAMP_RATE_55MV ,
RAMP_RATE_NO_CTRL , /* 100mV/us */
} ;
struct max77686_data {
2018-11-15 09:01:19 +01:00
struct device * dev ;
2015-05-18 10:01:03 -07:00
DECLARE_BITMAP ( gpio_enabled , MAX77686_REGULATORS ) ;
2015-01-05 12:48:43 +01:00
2014-11-04 09:49:41 +01:00
/* Array indexed by regulator id */
2012-10-16 17:24:18 +05:30
unsigned int opmode [ MAX77686_REGULATORS ] ;
2012-06-01 13:17:14 +09:00
} ;
2014-10-27 13:11:48 +01:00
static unsigned int max77686_get_opmode_shift ( int id )
{
switch ( id ) {
case MAX77686_BUCK1 :
case MAX77686_BUCK5 . . . MAX77686_BUCK9 :
return 0 ;
case MAX77686_BUCK2 . . . MAX77686_BUCK4 :
return MAX77686_OPMODE_BUCK234_SHIFT ;
default :
/* all LDOs */
return MAX77686_OPMODE_SHIFT ;
}
}
2015-01-05 12:48:43 +01:00
/*
* When regulator is configured for GPIO control then it
* replaces " normal " mode . Any change from low power mode to normal
* should actually change to GPIO control .
* Map normal mode to proper value for such regulators .
*/
static unsigned int max77686_map_normal_mode ( struct max77686_data * max77686 ,
int id )
{
switch ( id ) {
case MAX77686_BUCK8 :
case MAX77686_BUCK9 :
case MAX77686_LDO20 . . . MAX77686_LDO22 :
2015-05-18 10:01:03 -07:00
if ( test_bit ( id , max77686 - > gpio_enabled ) )
2015-01-05 12:48:43 +01:00
return MAX77686_GPIO_CONTROL ;
}
return MAX77686_NORMAL ;
}
regulator: max77686: Add suspend disable for some LDOs
Some LDOs of Maxim 77686 PMIC support disabling during system suspend
(LDO{2,6,7,8,10,11,12,14,15,16}). This was already implemented as part
of set_suspend_mode function. In that case the mode was one of:
- disable,
- normal mode,
- low power mode.
However there are no bindings for setting the mode during suspend.
Add suspend disable for LDO regulators supporting this. Re-use existing
max77686_buck_set_suspend_disable() function. This helps reducing
energy consumption during system sleep.
Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Reviewed-by: Javier Martinez Canillas <javier.martinez@collabora.co.uk>
Signed-off-by: Mark Brown <broonie@kernel.org>
2014-10-29 12:14:52 +01:00
/* Some BUCKs and LDOs supports Normal[ON/OFF] mode during suspend */
static int max77686_set_suspend_disable ( struct regulator_dev * rdev )
2012-10-16 17:24:19 +05:30
{
2014-10-27 13:11:48 +01:00
unsigned int val , shift ;
2012-10-16 17:24:19 +05:30
struct max77686_data * max77686 = rdev_get_drvdata ( rdev ) ;
2013-04-27 16:18:16 +08:00
int ret , id = rdev_get_id ( rdev ) ;
2012-10-16 17:24:19 +05:30
2014-10-27 13:11:48 +01:00
shift = max77686_get_opmode_shift ( id ) ;
val = MAX77686_OFF_PWRREQ ;
2012-10-16 17:24:19 +05:30
2013-04-27 16:18:16 +08:00
ret = regmap_update_bits ( rdev - > regmap , rdev - > desc - > enable_reg ,
2014-10-27 13:11:48 +01:00
rdev - > desc - > enable_mask , val < < shift ) ;
2013-04-27 16:18:16 +08:00
if ( ret )
return ret ;
2013-02-13 17:52:26 -02:00
max77686 - > opmode [ id ] = val ;
2013-04-27 16:18:16 +08:00
return 0 ;
2012-10-16 17:24:19 +05:30
}
/* Some LDOs supports [LPM/Normal]ON mode during suspend state */
static int max77686_set_suspend_mode ( struct regulator_dev * rdev ,
unsigned int mode )
{
struct max77686_data * max77686 = rdev_get_drvdata ( rdev ) ;
unsigned int val ;
2013-04-27 16:18:16 +08:00
int ret , id = rdev_get_id ( rdev ) ;
2012-10-16 17:24:19 +05:30
/* BUCK[5-9] doesn't support this feature */
2013-02-13 17:52:26 -02:00
if ( id > = MAX77686_BUCK5 )
2012-10-16 17:24:19 +05:30
return 0 ;
switch ( mode ) {
case REGULATOR_MODE_IDLE : /* ON in LP Mode */
2014-10-27 13:11:48 +01:00
val = MAX77686_LDO_LOWPOWER_PWRREQ ;
2012-10-16 17:24:19 +05:30
break ;
case REGULATOR_MODE_NORMAL : /* ON in Normal Mode */
2015-01-05 12:48:43 +01:00
val = max77686_map_normal_mode ( max77686 , id ) ;
2012-10-16 17:24:19 +05:30
break ;
default :
pr_warn ( " %s: regulator_suspend_mode : 0x%x not supported \n " ,
rdev - > desc - > name , mode ) ;
return - EINVAL ;
}
2013-04-27 16:18:16 +08:00
ret = regmap_update_bits ( rdev - > regmap , rdev - > desc - > enable_reg ,
2014-10-27 13:11:48 +01:00
rdev - > desc - > enable_mask ,
val < < MAX77686_OPMODE_SHIFT ) ;
2013-04-27 16:18:16 +08:00
if ( ret )
return ret ;
2013-02-13 17:52:26 -02:00
max77686 - > opmode [ id ] = val ;
2013-04-27 16:18:16 +08:00
return 0 ;
2012-10-16 17:24:19 +05:30
}
/* Some LDOs supports LPM-ON/OFF/Normal-ON mode during suspend state */
static int max77686_ldo_set_suspend_mode ( struct regulator_dev * rdev ,
unsigned int mode )
{
unsigned int val ;
struct max77686_data * max77686 = rdev_get_drvdata ( rdev ) ;
2015-01-05 12:48:43 +01:00
int ret , id = rdev_get_id ( rdev ) ;
2012-10-16 17:24:19 +05:30
switch ( mode ) {
case REGULATOR_MODE_STANDBY : /* switch off */
2014-10-27 13:11:48 +01:00
val = MAX77686_OFF_PWRREQ ;
2012-10-16 17:24:19 +05:30
break ;
case REGULATOR_MODE_IDLE : /* ON in LP Mode */
2014-10-27 13:11:48 +01:00
val = MAX77686_LDO_LOWPOWER_PWRREQ ;
2012-10-16 17:24:19 +05:30
break ;
case REGULATOR_MODE_NORMAL : /* ON in Normal Mode */
2015-01-05 12:48:43 +01:00
val = max77686_map_normal_mode ( max77686 , id ) ;
2012-10-16 17:24:19 +05:30
break ;
default :
pr_warn ( " %s: regulator_suspend_mode : 0x%x not supported \n " ,
rdev - > desc - > name , mode ) ;
return - EINVAL ;
}
2013-04-27 16:18:16 +08:00
ret = regmap_update_bits ( rdev - > regmap , rdev - > desc - > enable_reg ,
2014-10-27 13:11:48 +01:00
rdev - > desc - > enable_mask ,
val < < MAX77686_OPMODE_SHIFT ) ;
2013-04-27 16:18:16 +08:00
if ( ret )
return ret ;
2015-01-05 12:48:43 +01:00
max77686 - > opmode [ id ] = val ;
2013-04-27 16:18:16 +08:00
return 0 ;
2012-10-16 17:24:19 +05:30
}
2012-10-22 09:39:28 +05:30
static int max77686_enable ( struct regulator_dev * rdev )
2012-10-16 17:24:18 +05:30
{
struct max77686_data * max77686 = rdev_get_drvdata ( rdev ) ;
2014-10-27 13:11:48 +01:00
unsigned int shift ;
int id = rdev_get_id ( rdev ) ;
shift = max77686_get_opmode_shift ( id ) ;
2012-10-16 17:24:18 +05:30
regulator: max77686: Add suspend disable for some LDOs
Some LDOs of Maxim 77686 PMIC support disabling during system suspend
(LDO{2,6,7,8,10,11,12,14,15,16}). This was already implemented as part
of set_suspend_mode function. In that case the mode was one of:
- disable,
- normal mode,
- low power mode.
However there are no bindings for setting the mode during suspend.
Add suspend disable for LDO regulators supporting this. Re-use existing
max77686_buck_set_suspend_disable() function. This helps reducing
energy consumption during system sleep.
Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Reviewed-by: Javier Martinez Canillas <javier.martinez@collabora.co.uk>
Signed-off-by: Mark Brown <broonie@kernel.org>
2014-10-29 12:14:52 +01:00
if ( max77686 - > opmode [ id ] = = MAX77686_OFF_PWRREQ )
2015-01-05 12:48:43 +01:00
max77686 - > opmode [ id ] = max77686_map_normal_mode ( max77686 , id ) ;
regulator: max77686: Add suspend disable for some LDOs
Some LDOs of Maxim 77686 PMIC support disabling during system suspend
(LDO{2,6,7,8,10,11,12,14,15,16}). This was already implemented as part
of set_suspend_mode function. In that case the mode was one of:
- disable,
- normal mode,
- low power mode.
However there are no bindings for setting the mode during suspend.
Add suspend disable for LDO regulators supporting this. Re-use existing
max77686_buck_set_suspend_disable() function. This helps reducing
energy consumption during system sleep.
Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Reviewed-by: Javier Martinez Canillas <javier.martinez@collabora.co.uk>
Signed-off-by: Mark Brown <broonie@kernel.org>
2014-10-29 12:14:52 +01:00
2012-10-16 17:24:18 +05:30
return regmap_update_bits ( rdev - > regmap , rdev - > desc - > enable_reg ,
rdev - > desc - > enable_mask ,
2014-10-27 13:11:48 +01:00
max77686 - > opmode [ id ] < < shift ) ;
2012-10-16 17:24:18 +05:30
}
2012-06-20 10:50:51 +05:30
static int max77686_set_ramp_delay ( struct regulator_dev * rdev , int ramp_delay )
{
unsigned int ramp_value = RAMP_RATE_NO_CTRL ;
switch ( ramp_delay ) {
case 1 . . . 13750 :
ramp_value = RAMP_RATE_13P75MV ;
break ;
case 13751 . . . 27500 :
ramp_value = RAMP_RATE_27P5MV ;
break ;
case 27501 . . . 55000 :
ramp_value = RAMP_RATE_55MV ;
break ;
case 55001 . . . 100000 :
break ;
default :
pr_warn ( " %s: ramp_delay: %d not supported, setting 100000 \n " ,
rdev - > desc - > name , ramp_delay ) ;
}
return regmap_update_bits ( rdev - > regmap , rdev - > desc - > enable_reg ,
MAX77686_RAMP_RATE_MASK , ramp_value < < 6 ) ;
}
2015-01-05 12:48:43 +01:00
static int max77686_of_parse_cb ( struct device_node * np ,
const struct regulator_desc * desc ,
struct regulator_config * config )
{
struct max77686_data * max77686 = config - > driver_data ;
2018-12-06 13:43:43 +01:00
int ret ;
2015-01-05 12:48:43 +01:00
switch ( desc - > id ) {
case MAX77686_BUCK8 :
case MAX77686_BUCK9 :
case MAX77686_LDO20 . . . MAX77686_LDO22 :
2018-12-06 13:43:43 +01:00
config - > ena_gpiod = gpiod_get_from_of_node ( np ,
2018-11-15 09:01:19 +01:00
" maxim,ena " ,
0 ,
GPIOD_OUT_HIGH | GPIOD_FLAGS_BIT_NONEXCLUSIVE ,
" max77686-regulator " ) ;
if ( IS_ERR ( config - > ena_gpiod ) )
config - > ena_gpiod = NULL ;
2015-01-05 12:48:43 +01:00
break ;
default :
return 0 ;
}
2018-11-15 09:01:19 +01:00
if ( config - > ena_gpiod ) {
2015-05-18 10:01:03 -07:00
set_bit ( desc - > id , max77686 - > gpio_enabled ) ;
2015-01-05 12:48:43 +01:00
2018-12-06 13:43:43 +01:00
ret = regmap_update_bits ( config - > regmap , desc - > enable_reg ,
desc - > enable_mask ,
MAX77686_GPIO_CONTROL ) ;
if ( ret ) {
gpiod_put ( config - > ena_gpiod ) ;
config - > ena_gpiod = NULL ;
}
2015-01-05 12:48:43 +01:00
}
return 0 ;
}
2017-01-28 19:52:24 +05:30
static const struct regulator_ops max77686_ops = {
2012-06-01 13:17:14 +09:00
. list_voltage = regulator_list_voltage_linear ,
2012-06-03 22:46:14 +08:00
. map_voltage = regulator_map_voltage_linear ,
2012-06-01 13:17:14 +09:00
. is_enabled = regulator_is_enabled_regmap ,
2012-10-16 17:24:18 +05:30
. enable = max77686_enable ,
2012-06-01 13:17:14 +09:00
. disable = regulator_disable_regmap ,
. get_voltage_sel = regulator_get_voltage_sel_regmap ,
. set_voltage_sel = regulator_set_voltage_sel_regmap ,
2012-06-19 13:23:42 +05:30
. set_voltage_time_sel = regulator_set_voltage_time_sel ,
2012-10-16 17:24:19 +05:30
. set_suspend_mode = max77686_set_suspend_mode ,
} ;
2017-01-28 19:52:24 +05:30
static const struct regulator_ops max77686_ldo_ops = {
2012-10-16 17:24:19 +05:30
. list_voltage = regulator_list_voltage_linear ,
. map_voltage = regulator_map_voltage_linear ,
. is_enabled = regulator_is_enabled_regmap ,
. enable = max77686_enable ,
2012-06-01 13:17:14 +09:00
. disable = regulator_disable_regmap ,
. get_voltage_sel = regulator_get_voltage_sel_regmap ,
. set_voltage_sel = regulator_set_voltage_sel_regmap ,
2012-06-19 13:23:42 +05:30
. set_voltage_time_sel = regulator_set_voltage_time_sel ,
2012-10-16 17:24:19 +05:30
. set_suspend_mode = max77686_ldo_set_suspend_mode ,
regulator: max77686: Add suspend disable for some LDOs
Some LDOs of Maxim 77686 PMIC support disabling during system suspend
(LDO{2,6,7,8,10,11,12,14,15,16}). This was already implemented as part
of set_suspend_mode function. In that case the mode was one of:
- disable,
- normal mode,
- low power mode.
However there are no bindings for setting the mode during suspend.
Add suspend disable for LDO regulators supporting this. Re-use existing
max77686_buck_set_suspend_disable() function. This helps reducing
energy consumption during system sleep.
Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Reviewed-by: Javier Martinez Canillas <javier.martinez@collabora.co.uk>
Signed-off-by: Mark Brown <broonie@kernel.org>
2014-10-29 12:14:52 +01:00
. set_suspend_disable = max77686_set_suspend_disable ,
2012-10-16 17:24:19 +05:30
} ;
2017-01-28 19:52:24 +05:30
static const struct regulator_ops max77686_buck1_ops = {
2012-10-16 17:24:19 +05:30
. list_voltage = regulator_list_voltage_linear ,
. map_voltage = regulator_map_voltage_linear ,
. is_enabled = regulator_is_enabled_regmap ,
. enable = max77686_enable ,
. disable = regulator_disable_regmap ,
. get_voltage_sel = regulator_get_voltage_sel_regmap ,
. set_voltage_sel = regulator_set_voltage_sel_regmap ,
. set_voltage_time_sel = regulator_set_voltage_time_sel ,
regulator: max77686: Add suspend disable for some LDOs
Some LDOs of Maxim 77686 PMIC support disabling during system suspend
(LDO{2,6,7,8,10,11,12,14,15,16}). This was already implemented as part
of set_suspend_mode function. In that case the mode was one of:
- disable,
- normal mode,
- low power mode.
However there are no bindings for setting the mode during suspend.
Add suspend disable for LDO regulators supporting this. Re-use existing
max77686_buck_set_suspend_disable() function. This helps reducing
energy consumption during system sleep.
Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Reviewed-by: Javier Martinez Canillas <javier.martinez@collabora.co.uk>
Signed-off-by: Mark Brown <broonie@kernel.org>
2014-10-29 12:14:52 +01:00
. set_suspend_disable = max77686_set_suspend_disable ,
2012-06-01 13:17:14 +09:00
} ;
2017-01-28 19:52:24 +05:30
static const struct regulator_ops max77686_buck_dvs_ops = {
2012-06-01 13:17:14 +09:00
. list_voltage = regulator_list_voltage_linear ,
2012-06-03 22:46:14 +08:00
. map_voltage = regulator_map_voltage_linear ,
2012-06-01 13:17:14 +09:00
. is_enabled = regulator_is_enabled_regmap ,
2012-10-16 17:24:18 +05:30
. enable = max77686_enable ,
2012-06-01 13:17:14 +09:00
. disable = regulator_disable_regmap ,
. get_voltage_sel = regulator_get_voltage_sel_regmap ,
. set_voltage_sel = regulator_set_voltage_sel_regmap ,
2012-06-19 13:23:42 +05:30
. set_voltage_time_sel = regulator_set_voltage_time_sel ,
2012-06-20 10:50:51 +05:30
. set_ramp_delay = max77686_set_ramp_delay ,
regulator: max77686: Add suspend disable for some LDOs
Some LDOs of Maxim 77686 PMIC support disabling during system suspend
(LDO{2,6,7,8,10,11,12,14,15,16}). This was already implemented as part
of set_suspend_mode function. In that case the mode was one of:
- disable,
- normal mode,
- low power mode.
However there are no bindings for setting the mode during suspend.
Add suspend disable for LDO regulators supporting this. Re-use existing
max77686_buck_set_suspend_disable() function. This helps reducing
energy consumption during system sleep.
Signed-off-by: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Reviewed-by: Javier Martinez Canillas <javier.martinez@collabora.co.uk>
Signed-off-by: Mark Brown <broonie@kernel.org>
2014-10-29 12:14:52 +01:00
. set_suspend_disable = max77686_set_suspend_disable ,
2012-06-01 13:17:14 +09:00
} ;
# define regulator_desc_ldo(num) { \
. name = " LDO " # num , \
2014-11-05 10:47:50 +01:00
. of_match = of_match_ptr ( " LDO " # num ) , \
. regulators_node = of_match_ptr ( " voltage-regulators " ) , \
2015-01-05 12:48:43 +01:00
. of_parse_cb = max77686_of_parse_cb , \
2012-06-01 13:17:14 +09:00
. id = MAX77686_LDO # # num , \
. ops = & max77686_ops , \
. type = REGULATOR_VOLTAGE , \
. owner = THIS_MODULE , \
. min_uV = MAX77686_LDO_MINUV , \
. uV_step = MAX77686_LDO_UVSTEP , \
2012-06-19 13:23:42 +05:30
. ramp_delay = MAX77686_RAMP_DELAY , \
2012-06-01 13:17:14 +09:00
. n_voltages = MAX77686_VSEL_MASK + 1 , \
. vsel_reg = MAX77686_REG_LDO1CTRL1 + num - 1 , \
. vsel_mask = MAX77686_VSEL_MASK , \
. enable_reg = MAX77686_REG_LDO1CTRL1 + num - 1 , \
. enable_mask = MAX77686_OPMODE_MASK \
< < MAX77686_OPMODE_SHIFT , \
}
2012-10-16 17:24:19 +05:30
# define regulator_desc_lpm_ldo(num) { \
. name = " LDO " # num , \
2014-11-05 10:47:50 +01:00
. of_match = of_match_ptr ( " LDO " # num ) , \
. regulators_node = of_match_ptr ( " voltage-regulators " ) , \
2012-10-16 17:24:19 +05:30
. id = MAX77686_LDO # # num , \
. ops = & max77686_ldo_ops , \
. type = REGULATOR_VOLTAGE , \
. owner = THIS_MODULE , \
. min_uV = MAX77686_LDO_MINUV , \
. uV_step = MAX77686_LDO_UVSTEP , \
. ramp_delay = MAX77686_RAMP_DELAY , \
. n_voltages = MAX77686_VSEL_MASK + 1 , \
. vsel_reg = MAX77686_REG_LDO1CTRL1 + num - 1 , \
. vsel_mask = MAX77686_VSEL_MASK , \
. enable_reg = MAX77686_REG_LDO1CTRL1 + num - 1 , \
. enable_mask = MAX77686_OPMODE_MASK \
< < MAX77686_OPMODE_SHIFT , \
}
2012-06-01 13:17:14 +09:00
# define regulator_desc_ldo_low(num) { \
2012-10-16 17:24:19 +05:30
. name = " LDO " # num , \
2014-11-05 10:47:50 +01:00
. of_match = of_match_ptr ( " LDO " # num ) , \
. regulators_node = of_match_ptr ( " voltage-regulators " ) , \
2012-10-16 17:24:19 +05:30
. id = MAX77686_LDO # # num , \
. ops = & max77686_ldo_ops , \
. type = REGULATOR_VOLTAGE , \
. owner = THIS_MODULE , \
. min_uV = MAX77686_LDO_LOW_MINUV , \
. uV_step = MAX77686_LDO_LOW_UVSTEP , \
. ramp_delay = MAX77686_RAMP_DELAY , \
. n_voltages = MAX77686_VSEL_MASK + 1 , \
. vsel_reg = MAX77686_REG_LDO1CTRL1 + num - 1 , \
. vsel_mask = MAX77686_VSEL_MASK , \
. enable_reg = MAX77686_REG_LDO1CTRL1 + num - 1 , \
. enable_mask = MAX77686_OPMODE_MASK \
< < MAX77686_OPMODE_SHIFT , \
}
# define regulator_desc_ldo1_low(num) { \
2012-06-01 13:17:14 +09:00
. name = " LDO " # num , \
2014-11-05 10:47:50 +01:00
. of_match = of_match_ptr ( " LDO " # num ) , \
. regulators_node = of_match_ptr ( " voltage-regulators " ) , \
2012-06-01 13:17:14 +09:00
. id = MAX77686_LDO # # num , \
. ops = & max77686_ops , \
. type = REGULATOR_VOLTAGE , \
. owner = THIS_MODULE , \
. min_uV = MAX77686_LDO_LOW_MINUV , \
. uV_step = MAX77686_LDO_LOW_UVSTEP , \
2012-06-19 13:23:42 +05:30
. ramp_delay = MAX77686_RAMP_DELAY , \
2012-06-01 13:17:14 +09:00
. n_voltages = MAX77686_VSEL_MASK + 1 , \
. vsel_reg = MAX77686_REG_LDO1CTRL1 + num - 1 , \
. vsel_mask = MAX77686_VSEL_MASK , \
. enable_reg = MAX77686_REG_LDO1CTRL1 + num - 1 , \
. enable_mask = MAX77686_OPMODE_MASK \
< < MAX77686_OPMODE_SHIFT , \
}
# define regulator_desc_buck(num) { \
. name = " BUCK " # num , \
2014-11-05 10:47:50 +01:00
. of_match = of_match_ptr ( " BUCK " # num ) , \
. regulators_node = of_match_ptr ( " voltage-regulators " ) , \
2015-01-05 12:48:43 +01:00
. of_parse_cb = max77686_of_parse_cb , \
2012-06-01 13:17:14 +09:00
. id = MAX77686_BUCK # # num , \
. ops = & max77686_ops , \
. type = REGULATOR_VOLTAGE , \
. owner = THIS_MODULE , \
. min_uV = MAX77686_BUCK_MINUV , \
. uV_step = MAX77686_BUCK_UVSTEP , \
2012-06-19 13:23:42 +05:30
. ramp_delay = MAX77686_RAMP_DELAY , \
2016-04-29 12:59:51 +02:00
. enable_time = MAX77686_BUCK_ENABLE_TIME , \
2012-06-01 13:17:14 +09:00
. n_voltages = MAX77686_VSEL_MASK + 1 , \
. vsel_reg = MAX77686_REG_BUCK5OUT + ( num - 5 ) * 2 , \
. vsel_mask = MAX77686_VSEL_MASK , \
. enable_reg = MAX77686_REG_BUCK5CTRL + ( num - 5 ) * 2 , \
. enable_mask = MAX77686_OPMODE_MASK , \
}
# define regulator_desc_buck1(num) { \
. name = " BUCK " # num , \
2014-11-05 10:47:50 +01:00
. of_match = of_match_ptr ( " BUCK " # num ) , \
. regulators_node = of_match_ptr ( " voltage-regulators " ) , \
2012-06-01 13:17:14 +09:00
. id = MAX77686_BUCK # # num , \
2012-10-16 17:24:19 +05:30
. ops = & max77686_buck1_ops , \
2012-06-01 13:17:14 +09:00
. type = REGULATOR_VOLTAGE , \
. owner = THIS_MODULE , \
. min_uV = MAX77686_BUCK_MINUV , \
. uV_step = MAX77686_BUCK_UVSTEP , \
2012-06-19 13:23:42 +05:30
. ramp_delay = MAX77686_RAMP_DELAY , \
2016-04-29 12:59:51 +02:00
. enable_time = MAX77686_BUCK_ENABLE_TIME , \
2012-06-01 13:17:14 +09:00
. n_voltages = MAX77686_VSEL_MASK + 1 , \
. vsel_reg = MAX77686_REG_BUCK1OUT , \
. vsel_mask = MAX77686_VSEL_MASK , \
. enable_reg = MAX77686_REG_BUCK1CTRL , \
. enable_mask = MAX77686_OPMODE_MASK , \
}
# define regulator_desc_buck_dvs(num) { \
. name = " BUCK " # num , \
2014-11-05 10:47:50 +01:00
. of_match = of_match_ptr ( " BUCK " # num ) , \
. regulators_node = of_match_ptr ( " voltage-regulators " ) , \
2012-06-01 13:17:14 +09:00
. id = MAX77686_BUCK # # num , \
2012-06-04 10:19:18 +08:00
. ops = & max77686_buck_dvs_ops , \
2012-06-01 13:17:14 +09:00
. type = REGULATOR_VOLTAGE , \
. owner = THIS_MODULE , \
. min_uV = MAX77686_DVS_MINUV , \
. uV_step = MAX77686_DVS_UVSTEP , \
2012-06-19 13:23:42 +05:30
. ramp_delay = MAX77686_DVS_RAMP_DELAY , \
2016-04-29 12:59:51 +02:00
. enable_time = MAX77686_DVS_ENABLE_TIME , \
2012-06-01 13:17:14 +09:00
. n_voltages = MAX77686_DVS_VSEL_MASK + 1 , \
. vsel_reg = MAX77686_REG_BUCK2DVS1 + ( num - 2 ) * 10 , \
. vsel_mask = MAX77686_DVS_VSEL_MASK , \
. enable_reg = MAX77686_REG_BUCK2CTRL1 + ( num - 2 ) * 10 , \
. enable_mask = MAX77686_OPMODE_MASK \
< < MAX77686_OPMODE_BUCK234_SHIFT , \
}
2014-10-27 16:03:42 +01:00
static const struct regulator_desc regulators [ ] = {
2012-10-16 17:24:19 +05:30
regulator_desc_ldo1_low ( 1 ) ,
2012-06-01 13:17:14 +09:00
regulator_desc_ldo_low ( 2 ) ,
regulator_desc_ldo ( 3 ) ,
regulator_desc_ldo ( 4 ) ,
regulator_desc_ldo ( 5 ) ,
regulator_desc_ldo_low ( 6 ) ,
regulator_desc_ldo_low ( 7 ) ,
regulator_desc_ldo_low ( 8 ) ,
regulator_desc_ldo ( 9 ) ,
2012-10-16 17:24:19 +05:30
regulator_desc_lpm_ldo ( 10 ) ,
regulator_desc_lpm_ldo ( 11 ) ,
regulator_desc_lpm_ldo ( 12 ) ,
2012-06-01 13:17:14 +09:00
regulator_desc_ldo ( 13 ) ,
2012-10-16 17:24:19 +05:30
regulator_desc_lpm_ldo ( 14 ) ,
2012-06-01 13:17:14 +09:00
regulator_desc_ldo_low ( 15 ) ,
2012-10-16 17:24:19 +05:30
regulator_desc_lpm_ldo ( 16 ) ,
2012-06-01 13:17:14 +09:00
regulator_desc_ldo ( 17 ) ,
regulator_desc_ldo ( 18 ) ,
regulator_desc_ldo ( 19 ) ,
regulator_desc_ldo ( 20 ) ,
regulator_desc_ldo ( 21 ) ,
regulator_desc_ldo ( 22 ) ,
regulator_desc_ldo ( 23 ) ,
regulator_desc_ldo ( 24 ) ,
regulator_desc_ldo ( 25 ) ,
regulator_desc_ldo ( 26 ) ,
regulator_desc_buck1 ( 1 ) ,
regulator_desc_buck_dvs ( 2 ) ,
regulator_desc_buck_dvs ( 3 ) ,
regulator_desc_buck_dvs ( 4 ) ,
regulator_desc_buck ( 5 ) ,
regulator_desc_buck ( 6 ) ,
regulator_desc_buck ( 7 ) ,
regulator_desc_buck ( 8 ) ,
regulator_desc_buck ( 9 ) ,
} ;
2012-11-19 13:22:22 -05:00
static int max77686_pmic_probe ( struct platform_device * pdev )
2012-06-01 13:17:14 +09:00
{
struct max77686_dev * iodev = dev_get_drvdata ( pdev - > dev . parent ) ;
struct max77686_data * max77686 ;
2014-11-05 10:47:50 +01:00
int i ;
2012-06-20 15:01:25 +08:00
struct regulator_config config = { } ;
2012-06-01 13:17:14 +09:00
dev_dbg ( & pdev - > dev , " %s \n " , __func__ ) ;
max77686 = devm_kzalloc ( & pdev - > dev , sizeof ( struct max77686_data ) ,
GFP_KERNEL ) ;
if ( ! max77686 )
return - ENOMEM ;
2018-11-15 09:01:19 +01:00
max77686 - > dev = & pdev - > dev ;
2014-11-05 10:47:50 +01:00
config . dev = iodev - > dev ;
2012-06-20 10:50:51 +05:30
config . regmap = iodev - > regmap ;
2012-10-16 17:24:18 +05:30
config . driver_data = max77686 ;
2012-06-01 13:17:14 +09:00
platform_set_drvdata ( pdev , max77686 ) ;
2012-06-08 12:03:04 +08:00
for ( i = 0 ; i < MAX77686_REGULATORS ; i + + ) {
2014-03-10 09:32:45 +01:00
struct regulator_dev * rdev ;
2014-11-04 09:49:41 +01:00
int id = regulators [ i ] . id ;
2014-03-10 09:32:45 +01:00
2014-11-04 09:49:42 +01:00
max77686 - > opmode [ id ] = MAX77686_NORMAL ;
2014-03-10 09:32:45 +01:00
rdev = devm_regulator_register ( & pdev - > dev ,
2013-09-04 11:07:54 +05:30
& regulators [ i ] , & config ) ;
2014-03-10 09:32:45 +01:00
if ( IS_ERR ( rdev ) ) {
2014-11-05 10:47:50 +01:00
int ret = PTR_ERR ( rdev ) ;
2012-06-20 10:50:51 +05:30
dev_err ( & pdev - > dev ,
2014-11-05 10:47:50 +01:00
" regulator init failed for %d: %d \n " , i , ret ) ;
return ret ;
2012-06-01 13:17:14 +09:00
}
}
2012-06-08 12:03:04 +08:00
2012-06-01 13:17:14 +09:00
return 0 ;
}
static const struct platform_device_id max77686_pmic_id [ ] = {
{ " max77686-pmic " , 0 } ,
{ } ,
} ;
MODULE_DEVICE_TABLE ( platform , max77686_pmic_id ) ;
static struct platform_driver max77686_pmic_driver = {
. driver = {
. name = " max77686-pmic " ,
} ,
. probe = max77686_pmic_probe ,
. id_table = max77686_pmic_id ,
} ;
2016-04-06 09:49:47 -04:00
module_platform_driver ( max77686_pmic_driver ) ;
2012-06-01 13:17:14 +09:00
MODULE_DESCRIPTION ( " MAXIM 77686 Regulator Driver " ) ;
MODULE_AUTHOR ( " Chiwoong Byun <woong.byun@samsung.com> " ) ;
MODULE_LICENSE ( " GPL " ) ;