sunxi: power: Unify axp pmic function names
Stop prefixing the axp functions for setting voltages, etc. with the model number, there ever is only one pmic driver built into u-boot, this allows simplifying the callers. Signed-off-by: Hans de Goede <hdegoede@redhat.com> Acked-by: Ian Campbell <ijc@hellion.org.uk>
This commit is contained in:
parent
401175220d
commit
6944aff1ca
12 changed files with 106 additions and 148 deletions
|
@ -10,7 +10,7 @@
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
#include <asm/arch/cpu.h>
|
#include <asm/arch/cpu.h>
|
||||||
#include <asm/arch/clock.h>
|
#include <asm/arch/clock.h>
|
||||||
#include <axp221.h>
|
#include <axp_pmic.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
#ifdef CONFIG_MACH_SUN6I
|
#ifdef CONFIG_MACH_SUN6I
|
||||||
|
@ -82,7 +82,7 @@ int print_cpuinfo(void)
|
||||||
int sunxi_get_sid(unsigned int *sid)
|
int sunxi_get_sid(unsigned int *sid)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_AXP221_POWER
|
#ifdef CONFIG_AXP221_POWER
|
||||||
return axp221_get_sid(sid);
|
return axp_get_sid(sid);
|
||||||
#elif defined SUNXI_SID_BASE
|
#elif defined SUNXI_SID_BASE
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
|
|
@ -17,15 +17,6 @@
|
||||||
#include <asm/gpio.h>
|
#include <asm/gpio.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#ifdef CONFIG_AXP152_POWER
|
|
||||||
#include <axp152.h>
|
|
||||||
#endif
|
|
||||||
#ifdef CONFIG_AXP209_POWER
|
|
||||||
#include <axp209.h>
|
|
||||||
#endif
|
|
||||||
#ifdef CONFIG_AXP221_POWER
|
|
||||||
#include <axp221.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define SUNXI_USB_PMU_IRQ_ENABLE 0x800
|
#define SUNXI_USB_PMU_IRQ_ENABLE 0x800
|
||||||
#ifdef CONFIG_MACH_SUN8I_A33
|
#ifdef CONFIG_MACH_SUN8I_A33
|
||||||
|
|
|
@ -13,15 +13,7 @@
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <mmc.h>
|
#include <mmc.h>
|
||||||
#ifdef CONFIG_AXP152_POWER
|
#include <axp_pmic.h>
|
||||||
#include <axp152.h>
|
|
||||||
#endif
|
|
||||||
#ifdef CONFIG_AXP209_POWER
|
|
||||||
#include <axp209.h>
|
|
||||||
#endif
|
|
||||||
#ifdef CONFIG_AXP221_POWER
|
|
||||||
#include <axp221.h>
|
|
||||||
#endif
|
|
||||||
#include <asm/arch/clock.h>
|
#include <asm/arch/clock.h>
|
||||||
#include <asm/arch/cpu.h>
|
#include <asm/arch/cpu.h>
|
||||||
#include <asm/arch/display.h>
|
#include <asm/arch/display.h>
|
||||||
|
@ -438,40 +430,42 @@ void sunxi_board_init(void)
|
||||||
int power_failed = 0;
|
int power_failed = 0;
|
||||||
unsigned long ramsize;
|
unsigned long ramsize;
|
||||||
|
|
||||||
#ifdef CONFIG_AXP152_POWER
|
#if defined CONFIG_AXP152_POWER || defined CONFIG_AXP209_POWER || defined CONFIG_AXP221_POWER
|
||||||
power_failed = axp152_init();
|
power_failed = axp_init();
|
||||||
power_failed |= axp152_set_dcdc2(CONFIG_AXP_DCDC2_VOLT);
|
|
||||||
power_failed |= axp152_set_dcdc3(CONFIG_AXP_DCDC3_VOLT);
|
#ifdef CONFIG_AXP221_POWER
|
||||||
power_failed |= axp152_set_dcdc4(CONFIG_AXP_DCDC4_VOLT);
|
power_failed |= axp_set_dcdc1(CONFIG_AXP_DCDC1_VOLT);
|
||||||
power_failed |= axp152_set_ldo2(CONFIG_AXP_ALDO2_VOLT);
|
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_AXP209_POWER
|
power_failed |= axp_set_dcdc2(CONFIG_AXP_DCDC2_VOLT);
|
||||||
power_failed |= axp209_init();
|
power_failed |= axp_set_dcdc3(CONFIG_AXP_DCDC3_VOLT);
|
||||||
power_failed |= axp209_set_dcdc2(CONFIG_AXP_DCDC2_VOLT);
|
#ifndef CONFIG_AXP209_POWER
|
||||||
power_failed |= axp209_set_dcdc3(CONFIG_AXP_DCDC3_VOLT);
|
power_failed |= axp_set_dcdc4(CONFIG_AXP_DCDC4_VOLT);
|
||||||
power_failed |= axp209_set_ldo2(CONFIG_AXP_ALDO2_VOLT);
|
|
||||||
power_failed |= axp209_set_ldo3(CONFIG_AXP_ALDO3_VOLT);
|
|
||||||
power_failed |= axp209_set_ldo4(CONFIG_AXP_ALDO4_VOLT);
|
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_AXP221_POWER
|
#ifdef CONFIG_AXP221_POWER
|
||||||
power_failed = axp221_init();
|
power_failed |= axp_set_dcdc5(CONFIG_AXP_DCDC5_VOLT);
|
||||||
power_failed |= axp221_set_dcdc1(CONFIG_AXP_DCDC1_VOLT);
|
|
||||||
power_failed |= axp221_set_dcdc2(CONFIG_AXP_DCDC2_VOLT);
|
|
||||||
power_failed |= axp221_set_dcdc3(CONFIG_AXP_DCDC3_VOLT);
|
|
||||||
power_failed |= axp221_set_dcdc4(CONFIG_AXP_DCDC4_VOLT);
|
|
||||||
power_failed |= axp221_set_dcdc5(CONFIG_AXP_DCDC5_VOLT);
|
|
||||||
power_failed |= axp221_set_aldo1(CONFIG_AXP_ALDO1_VOLT);
|
|
||||||
power_failed |= axp221_set_aldo2(CONFIG_AXP_ALDO2_VOLT);
|
|
||||||
power_failed |= axp221_set_aldo3(CONFIG_AXP_ALDO3_VOLT);
|
|
||||||
power_failed |= axp221_set_dldo1(CONFIG_AXP_DLDO1_VOLT);
|
|
||||||
power_failed |= axp221_set_dldo2(CONFIG_AXP_DLDO2_VOLT);
|
|
||||||
power_failed |= axp221_set_dldo3(CONFIG_AXP_DLDO3_VOLT);
|
|
||||||
power_failed |= axp221_set_dldo4(CONFIG_AXP_DLDO4_VOLT);
|
|
||||||
power_failed |= axp221_set_eldo(1, CONFIG_AXP_ELDO1_VOLT);
|
|
||||||
power_failed |= axp221_set_eldo(2, CONFIG_AXP_ELDO2_VOLT);
|
|
||||||
power_failed |= axp221_set_eldo(3, CONFIG_AXP_ELDO3_VOLT);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_AXP221_POWER
|
||||||
|
power_failed |= axp_set_aldo1(CONFIG_AXP_ALDO1_VOLT);
|
||||||
|
#endif
|
||||||
|
power_failed |= axp_set_aldo2(CONFIG_AXP_ALDO2_VOLT);
|
||||||
|
#ifndef CONFIG_AXP152_POWER
|
||||||
|
power_failed |= axp_set_aldo3(CONFIG_AXP_ALDO3_VOLT);
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_AXP209_POWER
|
||||||
|
power_failed |= axp_set_aldo4(CONFIG_AXP_ALDO4_VOLT);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_AXP221_POWER
|
||||||
|
power_failed |= axp_set_dldo1(CONFIG_AXP_DLDO1_VOLT);
|
||||||
|
power_failed |= axp_set_dldo2(CONFIG_AXP_DLDO2_VOLT);
|
||||||
|
power_failed |= axp_set_dldo3(CONFIG_AXP_DLDO3_VOLT);
|
||||||
|
power_failed |= axp_set_dldo4(CONFIG_AXP_DLDO4_VOLT);
|
||||||
|
power_failed |= axp_set_eldo(1, CONFIG_AXP_ELDO1_VOLT);
|
||||||
|
power_failed |= axp_set_eldo(2, CONFIG_AXP_ELDO2_VOLT);
|
||||||
|
power_failed |= axp_set_eldo(3, CONFIG_AXP_ELDO3_VOLT);
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
printf("DRAM:");
|
printf("DRAM:");
|
||||||
ramsize = sunxi_dram_init();
|
ramsize = sunxi_dram_init();
|
||||||
printf(" %lu MiB\n", ramsize >> 20);
|
printf(" %lu MiB\n", ramsize >> 20);
|
||||||
|
|
|
@ -10,22 +10,13 @@
|
||||||
#include <asm/arch/gpio.h>
|
#include <asm/arch/gpio.h>
|
||||||
#include <asm/arch/pmic_bus.h>
|
#include <asm/arch/pmic_bus.h>
|
||||||
#include <asm/gpio.h>
|
#include <asm/gpio.h>
|
||||||
|
#include <axp_pmic.h>
|
||||||
#include <dm.h>
|
#include <dm.h>
|
||||||
#include <dm/device-internal.h>
|
#include <dm/device-internal.h>
|
||||||
#include <dm/lists.h>
|
#include <dm/lists.h>
|
||||||
#include <dm/root.h>
|
#include <dm/root.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
#ifdef CONFIG_AXP152_POWER
|
|
||||||
#include <axp152.h>
|
|
||||||
#elif defined CONFIG_AXP209_POWER
|
|
||||||
#include <axp209.h>
|
|
||||||
#elif defined CONFIG_AXP221_POWER
|
|
||||||
#include <axp221.h>
|
|
||||||
#else
|
|
||||||
#error Unknown AXP model
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static int axp_gpio_set_value(struct udevice *dev, unsigned pin, int val);
|
static int axp_gpio_set_value(struct udevice *dev, unsigned pin, int val);
|
||||||
|
|
||||||
static u8 axp_get_gpio_ctrl_reg(unsigned pin)
|
static u8 axp_get_gpio_ctrl_reg(unsigned pin)
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
*/
|
*/
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <i2c.h>
|
#include <i2c.h>
|
||||||
#include <axp152.h>
|
#include <axp_pmic.h>
|
||||||
|
|
||||||
static int axp152_write(enum axp152_reg reg, u8 val)
|
static int axp152_write(enum axp152_reg reg, u8 val)
|
||||||
{
|
{
|
||||||
|
@ -28,7 +28,7 @@ static u8 axp152_mvolt_to_target(int mvolt, int min, int max, int div)
|
||||||
return (mvolt - min) / div;
|
return (mvolt - min) / div;
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp152_set_dcdc2(int mvolt)
|
int axp_set_dcdc2(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
u8 current, target;
|
u8 current, target;
|
||||||
|
@ -49,28 +49,28 @@ int axp152_set_dcdc2(int mvolt)
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp152_set_dcdc3(int mvolt)
|
int axp_set_dcdc3(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
u8 target = axp152_mvolt_to_target(mvolt, 700, 3500, 50);
|
u8 target = axp152_mvolt_to_target(mvolt, 700, 3500, 50);
|
||||||
|
|
||||||
return axp152_write(AXP152_DCDC3_VOLTAGE, target);
|
return axp152_write(AXP152_DCDC3_VOLTAGE, target);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp152_set_dcdc4(int mvolt)
|
int axp_set_dcdc4(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
u8 target = axp152_mvolt_to_target(mvolt, 700, 3500, 25);
|
u8 target = axp152_mvolt_to_target(mvolt, 700, 3500, 25);
|
||||||
|
|
||||||
return axp152_write(AXP152_DCDC4_VOLTAGE, target);
|
return axp152_write(AXP152_DCDC4_VOLTAGE, target);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp152_set_ldo2(int mvolt)
|
int axp_set_aldo2(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
u8 target = axp152_mvolt_to_target(mvolt, 700, 3500, 100);
|
u8 target = axp152_mvolt_to_target(mvolt, 700, 3500, 100);
|
||||||
|
|
||||||
return axp152_write(AXP152_LDO2_VOLTAGE, target);
|
return axp152_write(AXP152_LDO2_VOLTAGE, target);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp152_init(void)
|
int axp_init(void)
|
||||||
{
|
{
|
||||||
u8 ver;
|
u8 ver;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
|
@ -7,8 +7,7 @@
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <i2c.h>
|
#include <i2c.h>
|
||||||
#include <asm/arch/gpio.h>
|
#include <axp_pmic.h>
|
||||||
#include <axp209.h>
|
|
||||||
|
|
||||||
static int axp209_write(enum axp209_reg reg, u8 val)
|
static int axp209_write(enum axp209_reg reg, u8 val)
|
||||||
{
|
{
|
||||||
|
@ -30,7 +29,7 @@ static u8 axp209_mvolt_to_cfg(int mvolt, int min, int max, int div)
|
||||||
return (mvolt - min) / div;
|
return (mvolt - min) / div;
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp209_set_dcdc2(int mvolt)
|
int axp_set_dcdc2(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
u8 cfg, current;
|
u8 cfg, current;
|
||||||
|
@ -53,14 +52,14 @@ int axp209_set_dcdc2(int mvolt)
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp209_set_dcdc3(int mvolt)
|
int axp_set_dcdc3(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
u8 cfg = axp209_mvolt_to_cfg(mvolt, 700, 3500, 25);
|
u8 cfg = axp209_mvolt_to_cfg(mvolt, 700, 3500, 25);
|
||||||
|
|
||||||
return axp209_write(AXP209_DCDC3_VOLTAGE, cfg);
|
return axp209_write(AXP209_DCDC3_VOLTAGE, cfg);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp209_set_ldo2(int mvolt)
|
int axp_set_aldo2(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
u8 cfg, reg;
|
u8 cfg, reg;
|
||||||
|
@ -76,7 +75,7 @@ int axp209_set_ldo2(int mvolt)
|
||||||
return axp209_write(AXP209_LDO24_VOLTAGE, reg);
|
return axp209_write(AXP209_LDO24_VOLTAGE, reg);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp209_set_ldo3(int mvolt)
|
int axp_set_aldo3(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
u8 cfg;
|
u8 cfg;
|
||||||
|
|
||||||
|
@ -88,10 +87,10 @@ int axp209_set_ldo3(int mvolt)
|
||||||
return axp209_write(AXP209_LDO3_VOLTAGE, cfg);
|
return axp209_write(AXP209_LDO3_VOLTAGE, cfg);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp209_set_ldo4(int mvolt)
|
int axp_set_aldo4(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
static const int vindex[] = {
|
static const unsigned int vindex[] = {
|
||||||
1250, 1300, 1400, 1500, 1600, 1700, 1800, 1900, 2000, 2500,
|
1250, 1300, 1400, 1500, 1600, 1700, 1800, 1900, 2000, 2500,
|
||||||
2700, 2800, 3000, 3100, 3200, 3300
|
2700, 2800, 3000, 3100, 3200, 3300
|
||||||
};
|
};
|
||||||
|
@ -109,7 +108,7 @@ int axp209_set_ldo4(int mvolt)
|
||||||
return axp209_write(AXP209_LDO24_VOLTAGE, reg);
|
return axp209_write(AXP209_LDO24_VOLTAGE, reg);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp209_init(void)
|
int axp_init(void)
|
||||||
{
|
{
|
||||||
u8 ver;
|
u8 ver;
|
||||||
int i, rc;
|
int i, rc;
|
||||||
|
@ -133,25 +132,3 @@ int axp209_init(void)
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp209_poweron_by_dc(void)
|
|
||||||
{
|
|
||||||
u8 v;
|
|
||||||
|
|
||||||
if (axp209_read(AXP209_POWER_STATUS, &v))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
return (v & AXP209_POWER_STATUS_ON_BY_DC);
|
|
||||||
}
|
|
||||||
|
|
||||||
int axp209_power_button(void)
|
|
||||||
{
|
|
||||||
u8 v;
|
|
||||||
|
|
||||||
if (axp209_read(AXP209_IRQ_STATUS5, &v))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
axp209_write(AXP209_IRQ_STATUS5, AXP209_IRQ5_PEK_DOWN);
|
|
||||||
|
|
||||||
return v & AXP209_IRQ5_PEK_DOWN;
|
|
||||||
}
|
|
||||||
|
|
|
@ -12,9 +12,8 @@
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <asm/arch/gpio.h>
|
|
||||||
#include <asm/arch/pmic_bus.h>
|
#include <asm/arch/pmic_bus.h>
|
||||||
#include <axp221.h>
|
#include <axp_pmic.h>
|
||||||
|
|
||||||
static u8 axp221_mvolt_to_cfg(int mvolt, int min, int max, int div)
|
static u8 axp221_mvolt_to_cfg(int mvolt, int min, int max, int div)
|
||||||
{
|
{
|
||||||
|
@ -26,7 +25,7 @@ static u8 axp221_mvolt_to_cfg(int mvolt, int min, int max, int div)
|
||||||
return (mvolt - min) / div;
|
return (mvolt - min) / div;
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_dcdc1(unsigned int mvolt)
|
int axp_set_dcdc1(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 1600, 3400, 100);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 1600, 3400, 100);
|
||||||
|
@ -48,7 +47,7 @@ int axp221_set_dcdc1(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL1_DCDC1_EN);
|
AXP221_OUTPUT_CTRL1_DCDC1_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_dcdc2(unsigned int mvolt)
|
int axp_set_dcdc2(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 600, 1540, 20);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 600, 1540, 20);
|
||||||
|
@ -65,7 +64,7 @@ int axp221_set_dcdc2(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL1_DCDC2_EN);
|
AXP221_OUTPUT_CTRL1_DCDC2_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_dcdc3(unsigned int mvolt)
|
int axp_set_dcdc3(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 600, 1860, 20);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 600, 1860, 20);
|
||||||
|
@ -82,7 +81,7 @@ int axp221_set_dcdc3(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL1_DCDC3_EN);
|
AXP221_OUTPUT_CTRL1_DCDC3_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_dcdc4(unsigned int mvolt)
|
int axp_set_dcdc4(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 600, 1540, 20);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 600, 1540, 20);
|
||||||
|
@ -99,7 +98,7 @@ int axp221_set_dcdc4(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL1_DCDC4_EN);
|
AXP221_OUTPUT_CTRL1_DCDC4_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_dcdc5(unsigned int mvolt)
|
int axp_set_dcdc5(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 1000, 2550, 50);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 1000, 2550, 50);
|
||||||
|
@ -116,7 +115,7 @@ int axp221_set_dcdc5(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL1_DCDC5_EN);
|
AXP221_OUTPUT_CTRL1_DCDC5_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_dldo1(unsigned int mvolt)
|
int axp_set_dldo1(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
||||||
|
@ -133,7 +132,7 @@ int axp221_set_dldo1(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL2_DLDO1_EN);
|
AXP221_OUTPUT_CTRL2_DLDO1_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_dldo2(unsigned int mvolt)
|
int axp_set_dldo2(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
||||||
|
@ -150,7 +149,7 @@ int axp221_set_dldo2(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL2_DLDO2_EN);
|
AXP221_OUTPUT_CTRL2_DLDO2_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_dldo3(unsigned int mvolt)
|
int axp_set_dldo3(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
||||||
|
@ -167,7 +166,7 @@ int axp221_set_dldo3(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL2_DLDO3_EN);
|
AXP221_OUTPUT_CTRL2_DLDO3_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_dldo4(unsigned int mvolt)
|
int axp_set_dldo4(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
||||||
|
@ -184,7 +183,7 @@ int axp221_set_dldo4(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL2_DLDO4_EN);
|
AXP221_OUTPUT_CTRL2_DLDO4_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_aldo1(unsigned int mvolt)
|
int axp_set_aldo1(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
||||||
|
@ -201,7 +200,7 @@ int axp221_set_aldo1(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL1_ALDO1_EN);
|
AXP221_OUTPUT_CTRL1_ALDO1_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_aldo2(unsigned int mvolt)
|
int axp_set_aldo2(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
||||||
|
@ -218,7 +217,7 @@ int axp221_set_aldo2(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL1_ALDO2_EN);
|
AXP221_OUTPUT_CTRL1_ALDO2_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_aldo3(unsigned int mvolt)
|
int axp_set_aldo3(unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
||||||
|
@ -235,7 +234,7 @@ int axp221_set_aldo3(unsigned int mvolt)
|
||||||
AXP221_OUTPUT_CTRL3_ALDO3_EN);
|
AXP221_OUTPUT_CTRL3_ALDO3_EN);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_set_eldo(int eldo_num, unsigned int mvolt)
|
int axp_set_eldo(int eldo_num, unsigned int mvolt)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
u8 cfg = axp221_mvolt_to_cfg(mvolt, 700, 3300, 100);
|
||||||
|
@ -268,7 +267,7 @@ int axp221_set_eldo(int eldo_num, unsigned int mvolt)
|
||||||
return pmic_bus_setbits(AXP221_OUTPUT_CTRL2, bits);
|
return pmic_bus_setbits(AXP221_OUTPUT_CTRL2, bits);
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_init(void)
|
int axp_init(void)
|
||||||
{
|
{
|
||||||
/* This cannot be 0 because it is used in SPL before BSS is ready */
|
/* This cannot be 0 because it is used in SPL before BSS is ready */
|
||||||
static int needs_init = 1;
|
static int needs_init = 1;
|
||||||
|
@ -293,12 +292,12 @@ int axp221_init(void)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int axp221_get_sid(unsigned int *sid)
|
int axp_get_sid(unsigned int *sid)
|
||||||
{
|
{
|
||||||
u8 *dest = (u8 *)sid;
|
u8 *dest = (u8 *)sid;
|
||||||
int i, ret;
|
int i, ret;
|
||||||
|
|
||||||
ret = axp221_init();
|
ret = pmic_bus_init();
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
#include <asm/global_data.h>
|
#include <asm/global_data.h>
|
||||||
#include <asm/gpio.h>
|
#include <asm/gpio.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
#include <axp221.h>
|
#include <axp_pmic.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <fdtdec.h>
|
#include <fdtdec.h>
|
||||||
#include <fdt_support.h>
|
#include <fdt_support.h>
|
||||||
|
@ -1217,10 +1217,10 @@ static void sunxi_mode_set(const struct ctfb_res_modes *mode,
|
||||||
if (IS_ENABLED(CONFIG_VIDEO_LCD_PANEL_EDP_4_LANE_1620M_VIA_ANX9804)) {
|
if (IS_ENABLED(CONFIG_VIDEO_LCD_PANEL_EDP_4_LANE_1620M_VIA_ANX9804)) {
|
||||||
/*
|
/*
|
||||||
* The anx9804 needs 1.8V from eldo3, we do this here
|
* The anx9804 needs 1.8V from eldo3, we do this here
|
||||||
* and not via CONFIG_AXP221_ELDO3 from board_init()
|
* and not via CONFIG_AXP_ELDO3_VOLT from board_init()
|
||||||
* to avoid turning this on when using hdmi output.
|
* to avoid turning this on when using hdmi output.
|
||||||
*/
|
*/
|
||||||
axp221_set_eldo(3, 1800);
|
axp_set_eldo(3, 1800);
|
||||||
anx9804_init(CONFIG_VIDEO_LCD_I2C_BUS, 4,
|
anx9804_init(CONFIG_VIDEO_LCD_I2C_BUS, 4,
|
||||||
ANX9804_DATA_RATE_1620M,
|
ANX9804_DATA_RATE_1620M,
|
||||||
sunxi_display.depth);
|
sunxi_display.depth);
|
||||||
|
|
|
@ -25,9 +25,3 @@ enum axp152_reg {
|
||||||
#define AXP_GPIO_CTRL_INPUT 0x02 /* Input */
|
#define AXP_GPIO_CTRL_INPUT 0x02 /* Input */
|
||||||
#define AXP_GPIO_STATE 0x97
|
#define AXP_GPIO_STATE 0x97
|
||||||
#define AXP_GPIO_STATE_OFFSET 0
|
#define AXP_GPIO_STATE_OFFSET 0
|
||||||
|
|
||||||
int axp152_set_dcdc2(int mvolt);
|
|
||||||
int axp152_set_dcdc3(int mvolt);
|
|
||||||
int axp152_set_dcdc4(int mvolt);
|
|
||||||
int axp152_set_ldo2(int mvolt);
|
|
||||||
int axp152_init(void);
|
|
||||||
|
|
|
@ -39,12 +39,3 @@ enum axp209_reg {
|
||||||
#define AXP_GPIO_CTRL_INPUT 0x02 /* Input */
|
#define AXP_GPIO_CTRL_INPUT 0x02 /* Input */
|
||||||
#define AXP_GPIO_STATE 0x94
|
#define AXP_GPIO_STATE 0x94
|
||||||
#define AXP_GPIO_STATE_OFFSET 4
|
#define AXP_GPIO_STATE_OFFSET 4
|
||||||
|
|
||||||
extern int axp209_set_dcdc2(int mvolt);
|
|
||||||
extern int axp209_set_dcdc3(int mvolt);
|
|
||||||
extern int axp209_set_ldo2(int mvolt);
|
|
||||||
extern int axp209_set_ldo3(int mvolt);
|
|
||||||
extern int axp209_set_ldo4(int mvolt);
|
|
||||||
extern int axp209_init(void);
|
|
||||||
extern int axp209_poweron_by_dc(void);
|
|
||||||
extern int axp209_power_button(void);
|
|
||||||
|
|
|
@ -62,19 +62,3 @@
|
||||||
#define AXP_GPIO_CTRL_INPUT 0x02 /* Input */
|
#define AXP_GPIO_CTRL_INPUT 0x02 /* Input */
|
||||||
#define AXP_GPIO_STATE 0x94
|
#define AXP_GPIO_STATE 0x94
|
||||||
#define AXP_GPIO_STATE_OFFSET 0
|
#define AXP_GPIO_STATE_OFFSET 0
|
||||||
|
|
||||||
int axp221_set_dcdc1(unsigned int mvolt);
|
|
||||||
int axp221_set_dcdc2(unsigned int mvolt);
|
|
||||||
int axp221_set_dcdc3(unsigned int mvolt);
|
|
||||||
int axp221_set_dcdc4(unsigned int mvolt);
|
|
||||||
int axp221_set_dcdc5(unsigned int mvolt);
|
|
||||||
int axp221_set_dldo1(unsigned int mvolt);
|
|
||||||
int axp221_set_dldo2(unsigned int mvolt);
|
|
||||||
int axp221_set_dldo3(unsigned int mvolt);
|
|
||||||
int axp221_set_dldo4(unsigned int mvolt);
|
|
||||||
int axp221_set_aldo1(unsigned int mvolt);
|
|
||||||
int axp221_set_aldo2(unsigned int mvolt);
|
|
||||||
int axp221_set_aldo3(unsigned int mvolt);
|
|
||||||
int axp221_set_eldo(int eldo_num, unsigned int mvolt);
|
|
||||||
int axp221_init(void);
|
|
||||||
int axp221_get_sid(unsigned int *sid);
|
|
||||||
|
|
37
include/axp_pmic.h
Normal file
37
include/axp_pmic.h
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
/*
|
||||||
|
* (C) Copyright 2015 Hans de Goede <hdegoede@redhat.com>
|
||||||
|
*
|
||||||
|
* X-Powers AX Power Management IC support header
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0+
|
||||||
|
*/
|
||||||
|
#ifndef _AXP_PMIC_H_
|
||||||
|
|
||||||
|
#ifdef CONFIG_AXP152_POWER
|
||||||
|
#include <axp152.h>
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_AXP209_POWER
|
||||||
|
#include <axp209.h>
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_AXP221_POWER
|
||||||
|
#include <axp221.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int axp_set_dcdc1(unsigned int mvolt);
|
||||||
|
int axp_set_dcdc2(unsigned int mvolt);
|
||||||
|
int axp_set_dcdc3(unsigned int mvolt);
|
||||||
|
int axp_set_dcdc4(unsigned int mvolt);
|
||||||
|
int axp_set_dcdc5(unsigned int mvolt);
|
||||||
|
int axp_set_aldo1(unsigned int mvolt);
|
||||||
|
int axp_set_aldo2(unsigned int mvolt);
|
||||||
|
int axp_set_aldo3(unsigned int mvolt);
|
||||||
|
int axp_set_aldo4(unsigned int mvolt);
|
||||||
|
int axp_set_dldo1(unsigned int mvolt);
|
||||||
|
int axp_set_dldo2(unsigned int mvolt);
|
||||||
|
int axp_set_dldo3(unsigned int mvolt);
|
||||||
|
int axp_set_dldo4(unsigned int mvolt);
|
||||||
|
int axp_set_eldo(int eldo_num, unsigned int mvolt);
|
||||||
|
int axp_init(void);
|
||||||
|
int axp_get_sid(unsigned int *sid);
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in a new issue