mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-05 20:54:31 +00:00
ee30068fa5
The RK809 is a Power Management IC (PMIC) for multimedia and handheld devices. They contains the following components: - Regulators(5*BUCKs, 9*LDOs, 2*SWITCHes) - RTC - Clocking Signed-off-by: Joseph Chen <chenjh@rock-chips.com> Signed-off-by: Elaine Zhang <zhangqing@rock-chips.com> Reviewed-by: Kever Yang <kever.yang@rock-chips.com>
236 lines
4 KiB
C
236 lines
4 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* Copyright (C) 2015 Google, Inc
|
|
* Written by Simon Glass <sjg@chromium.org>
|
|
*/
|
|
|
|
#ifndef _PMIC_RK8XX_H_
|
|
#define _PMIC_RK8XX_H_
|
|
|
|
enum {
|
|
REG_SECONDS = 0x00,
|
|
REG_MINUTES,
|
|
REG_HOURS,
|
|
REG_DAYS,
|
|
REG_MONTHS,
|
|
REG_YEARS,
|
|
REG_WEEKS,
|
|
REG_ALARM_SECONDS,
|
|
REG_ALARM_MINUTES,
|
|
REG_ALARM_HOURS,
|
|
REG_ALARM_DAYS,
|
|
REG_ALARM_MONTHS,
|
|
REG_ALARM_YEARS,
|
|
|
|
REG_RTC_CTRL = 0x10,
|
|
REG_RTC_STATUS,
|
|
REG_RTC_INT,
|
|
REG_RTC_COMP_LSB,
|
|
REG_RTC_COMP_MSB,
|
|
|
|
ID_MSB = 0x17,
|
|
ID_LSB,
|
|
|
|
REG_CLK32OUT = 0x20,
|
|
REG_VB_MON,
|
|
REG_THERMAL,
|
|
REG_DCDC_EN,
|
|
REG_LDO_EN,
|
|
REG_SLEEP_SET_OFF1,
|
|
REG_SLEEP_SET_OFF2,
|
|
REG_DCDC_UV_STS,
|
|
REG_DCDC_UV_ACT,
|
|
REG_LDO_UV_STS,
|
|
REG_LDO_UV_ACT,
|
|
REG_DCDC_PG,
|
|
REG_LDO_PG,
|
|
REG_VOUT_MON_TDB,
|
|
REG_BUCK1_CONFIG,
|
|
REG_BUCK1_ON_VSEL,
|
|
REG_BUCK1_SLP_VSEL,
|
|
REG_BUCK1_DVS_VSEL,
|
|
REG_BUCK2_CONFIG,
|
|
REG_BUCK2_ON_VSEL,
|
|
REG_BUCK2_SLP_VSEL,
|
|
REG_BUCK2_DVS_VSEL,
|
|
REG_BUCK3_CONFIG,
|
|
REG_BUCK4_CONFIG,
|
|
REG_BUCK4_ON_VSEL,
|
|
REG_BUCK4_SLP_VSEL,
|
|
REG_BOOST_CONFIG_REG,
|
|
REG_LDO1_ON_VSEL,
|
|
REG_LDO1_SLP_VSEL,
|
|
REG_LDO2_ON_VSEL,
|
|
REG_LDO2_SLP_VSEL,
|
|
REG_LDO3_ON_VSEL,
|
|
REG_LDO3_SLP_VSEL,
|
|
REG_LDO4_ON_VSEL,
|
|
REG_LDO4_SLP_VSEL,
|
|
REG_LDO5_ON_VSEL,
|
|
REG_LDO5_SLP_VSEL,
|
|
REG_LDO6_ON_VSEL,
|
|
REG_LDO6_SLP_VSEL,
|
|
REG_LDO7_ON_VSEL,
|
|
REG_LDO7_SLP_VSEL,
|
|
REG_LDO8_ON_VSEL,
|
|
REG_LDO8_SLP_VSEL,
|
|
REG_DEVCTRL,
|
|
REG_INT_STS1,
|
|
REG_INT_STS_MSK1,
|
|
REG_INT_STS2,
|
|
REG_INT_STS_MSK2,
|
|
REG_IO_POL,
|
|
REG_OTP_VDD_EN,
|
|
REG_H5V_EN,
|
|
REG_SLEEP_SET_OFF,
|
|
REG_BOOST_LDO9_ON_VSEL,
|
|
REG_BOOST_LDO9_SLP_VSEL,
|
|
REG_BOOST_CTRL,
|
|
|
|
/* Not sure what this does */
|
|
REG_DCDC_ILMAX = 0x90,
|
|
REG_CHRG_COMP = 0x9a,
|
|
REG_SUP_STS = 0xa0,
|
|
REG_USB_CTRL,
|
|
REG1_CHRG_CTRL,
|
|
REG2_CHRG_CTRL,
|
|
REG3_CHRG_CTRL,
|
|
REG_BAT_CTRL,
|
|
REG_BAT_HTS_TS1,
|
|
REG_BAT_LTS_TS1,
|
|
REG_BAT_HTS_TS2,
|
|
REG_BAT_LTS_TS2,
|
|
REG_TS_CTRL,
|
|
REG_ADC_CTRL,
|
|
REG_ON_SOURCE,
|
|
REG_OFF_SOURCE,
|
|
REG_GGCON,
|
|
REG_GGSTS,
|
|
REG_FRAME_SMP_INTERV,
|
|
REG_AUTO_SLP_CUR_THR,
|
|
REG3_GASCNT_CAL,
|
|
REG2_GASCNT_CAL,
|
|
REG1_GASCNT_CAL,
|
|
REG0_GASCNT_CAL,
|
|
REG3_GASCNT,
|
|
REG2_GASCNT,
|
|
REG1_GASCNT,
|
|
REG0_GASCNT,
|
|
REGH_BAT_CUR_AVG,
|
|
REGL_BAT_CUR_AVG,
|
|
REGH_TS1_ADC,
|
|
REGL_TS1_ADC,
|
|
REGH_TS2_ADC,
|
|
REGL_TS2_ADC,
|
|
REGH_BAT_OCV,
|
|
REGL_BAT_OCV,
|
|
REGH_BAT_VOL,
|
|
REGL_BAT_VOL,
|
|
REGH_RELAX_ENTRY_THRES,
|
|
REGL_RELAX_ENTRY_THRES,
|
|
REGH_RELAX_EXIT_THRES,
|
|
REGL_RELAX_EXIT_THRES,
|
|
REGH_RELAX_VOL1,
|
|
REGL_RELAX_VOL1,
|
|
REGH_RELAX_VOL2,
|
|
REGL_RELAX_VOL2,
|
|
REGH_BAT_CUR_R_CALC,
|
|
REGL_BAT_CUR_R_CALC,
|
|
REGH_BAT_VOL_R_CALC,
|
|
REGL_BAT_VOL_R_CALC,
|
|
REGH_CAL_OFFSET,
|
|
REGL_CAL_OFFSET,
|
|
REG_NON_ACT_TIMER_CNT,
|
|
REGH_VCALIB0,
|
|
REGL_VCALIB0,
|
|
REGH_VCALIB1,
|
|
REGL_VCALIB1,
|
|
REGH_IOFFSET,
|
|
REGL_IOFFSET,
|
|
REG_SOC,
|
|
REG3_REMAIN_CAP,
|
|
REG2_REMAIN_CAP,
|
|
REG1_REMAIN_CAP,
|
|
REG0_REMAIN_CAP,
|
|
REG_UPDAT_LEVE,
|
|
REG3_NEW_FCC,
|
|
REG2_NEW_FCC,
|
|
REG1_NEW_FCC,
|
|
REG0_NEW_FCC,
|
|
REG_NON_ACT_TIMER_CNT_SAVE,
|
|
REG_OCV_VOL_VALID,
|
|
REG_REBOOT_CNT,
|
|
REG_POFFSET,
|
|
REG_MISC_MARK,
|
|
REG_HALT_CNT,
|
|
REGH_CALC_REST,
|
|
REGL_CALC_REST,
|
|
SAVE_DATA19,
|
|
RK808_NUM_OF_REGS,
|
|
};
|
|
|
|
enum {
|
|
RK817_REG_SYS_CFG3 = 0xf4,
|
|
};
|
|
|
|
enum {
|
|
RK816_REG_DCDC_EN1 = 0x23,
|
|
RK816_REG_DCDC_EN2,
|
|
RK816_REG_DCDC_SLP_EN,
|
|
RK816_REG_LDO_SLP_EN,
|
|
RK816_REG_LDO_EN1 = 0x27,
|
|
RK816_REG_LDO_EN2,
|
|
};
|
|
|
|
enum {
|
|
RK805_ID = 0x8050,
|
|
RK808_ID = 0x0000,
|
|
RK809_ID = 0x8090,
|
|
RK816_ID = 0x8160,
|
|
RK817_ID = 0x8170,
|
|
RK818_ID = 0x8180,
|
|
};
|
|
|
|
enum {
|
|
RK817_POWER_EN0 = 0xb1,
|
|
RK817_POWER_EN1,
|
|
RK817_POWER_EN2,
|
|
RK817_POWER_EN3,
|
|
};
|
|
|
|
#define RK817_POWER_EN_SAVE0 0x99
|
|
#define RK817_POWER_EN_SAVE1 0xa4
|
|
|
|
#define RK817_ID_MSB 0xed
|
|
#define RK817_ID_LSB 0xee
|
|
#define RK8XX_ID_MSK 0xfff0
|
|
|
|
#define RK817_PMIC_SYS_CFG3 0xf4
|
|
#define RK817_GPIO_INT_CFG 0xfe
|
|
|
|
#define RK8XX_ON_SOURCE 0xae
|
|
#define RK8XX_OFF_SOURCE 0xaf
|
|
#define RK817_BUCK4_CMIN 0xc6
|
|
#define RK817_ON_SOURCE 0xf5
|
|
#define RK817_OFF_SOURCE 0xf6
|
|
|
|
struct reg_data {
|
|
u8 reg;
|
|
u8 val;
|
|
u8 mask;
|
|
};
|
|
struct rk8xx_reg_table {
|
|
char *name;
|
|
u8 reg_ctl;
|
|
u8 reg_vol;
|
|
};
|
|
|
|
struct rk8xx_priv {
|
|
int variant;
|
|
};
|
|
|
|
int rk8xx_spl_configure_buck(struct udevice *pmic, int buck, int uvolt);
|
|
int rk818_spl_configure_usb_input_current(struct udevice *pmic, int current_ma);
|
|
int rk818_spl_configure_usb_chrg_shutdown(struct udevice *pmic, int uvolt);
|
|
|
|
#endif
|