svn commit: r356148 - head/sys/arm64/rockchip
Emmanuel Vadot
manu at FreeBSD.org
Sat Dec 28 15:28:40 UTC 2019
Author: manu
Date: Sat Dec 28 15:28:39 2019
New Revision: 356148
URL: https://svnweb.freebsd.org/changeset/base/356148
Log:
arm64: rockchip: rk808: Add remaining regulators
The RK808 driver was missing the LDO and switch regulators.
Add support for them.
Reviewed by: mmel
MFC after: 1 month
Differential Revision: https://reviews.freebsd.org/D22852
Modified:
head/sys/arm64/rockchip/rk805.c
head/sys/arm64/rockchip/rk805reg.h
Modified: head/sys/arm64/rockchip/rk805.c
==============================================================================
--- head/sys/arm64/rockchip/rk805.c Sat Dec 28 13:35:54 2019 (r356147)
+++ head/sys/arm64/rockchip/rk805.c Sat Dec 28 15:28:39 2019 (r356148)
@@ -221,6 +221,114 @@ static struct rk805_regdef rk808_regdefs[] = {
.voltage_step = 100000,
.voltage_nstep = 16,
},
+ {
+ .id = RK808_LDO1,
+ .name = "LDO_REG1",
+ .enable_reg = RK808_LDO_EN,
+ .enable_mask = 0x1,
+ .voltage_reg = RK805_LDO1_ON_VSEL,
+ .voltage_mask = 0x1F,
+ .voltage_min = 1800000,
+ .voltage_max = 3400000,
+ .voltage_step = 100000,
+ .voltage_nstep = 17,
+ },
+ {
+ .id = RK808_LDO2,
+ .name = "LDO_REG2",
+ .enable_reg = RK808_LDO_EN,
+ .enable_mask = 0x2,
+ .voltage_reg = RK805_LDO2_ON_VSEL,
+ .voltage_mask = 0x1F,
+ .voltage_min = 1800000,
+ .voltage_max = 3400000,
+ .voltage_step = 100000,
+ .voltage_nstep = 17,
+ },
+ {
+ .id = RK808_LDO3,
+ .name = "LDO_REG3",
+ .enable_reg = RK808_LDO_EN,
+ .enable_mask = 0x4,
+ .voltage_reg = RK805_LDO3_ON_VSEL,
+ .voltage_mask = 0xF,
+ .voltage_min = 800000,
+ .voltage_max = 2500000,
+ .voltage_step = 100000,
+ .voltage_nstep = 18,
+ },
+ {
+ .id = RK808_LDO4,
+ .name = "LDO_REG4",
+ .enable_reg = RK808_LDO_EN,
+ .enable_mask = 0x8,
+ .voltage_reg = RK808_LDO4_ON_VSEL,
+ .voltage_mask = 0x1F,
+ .voltage_min = 1800000,
+ .voltage_max = 3400000,
+ .voltage_step = 100000,
+ .voltage_nstep = 17,
+ },
+ {
+ .id = RK808_LDO5,
+ .name = "LDO_REG5",
+ .enable_reg = RK808_LDO_EN,
+ .enable_mask = 0x10,
+ .voltage_reg = RK808_LDO5_ON_VSEL,
+ .voltage_mask = 0x1F,
+ .voltage_min = 1800000,
+ .voltage_max = 3400000,
+ .voltage_step = 100000,
+ .voltage_nstep = 17,
+ },
+ {
+ .id = RK808_LDO6,
+ .name = "LDO_REG6",
+ .enable_reg = RK808_LDO_EN,
+ .enable_mask = 0x20,
+ .voltage_reg = RK808_LDO6_ON_VSEL,
+ .voltage_mask = 0x1F,
+ .voltage_min = 800000,
+ .voltage_max = 2500000,
+ .voltage_step = 100000,
+ .voltage_nstep = 18,
+ },
+ {
+ .id = RK808_LDO7,
+ .name = "LDO_REG7",
+ .enable_reg = RK808_LDO_EN,
+ .enable_mask = 0x40,
+ .voltage_reg = RK808_LDO7_ON_VSEL,
+ .voltage_mask = 0x1F,
+ .voltage_min = 800000,
+ .voltage_max = 2500000,
+ .voltage_step = 100000,
+ .voltage_nstep = 18,
+ },
+ {
+ .id = RK808_LDO8,
+ .name = "LDO_REG8",
+ .enable_reg = RK808_LDO_EN,
+ .enable_mask = 0x80,
+ .voltage_reg = RK808_LDO8_ON_VSEL,
+ .voltage_mask = 0x1F,
+ .voltage_min = 1800000,
+ .voltage_max = 3400000,
+ .voltage_step = 100000,
+ .voltage_nstep = 17,
+ },
+ {
+ .id = RK808_SWITCH1,
+ .name = "SWITCH_REG1",
+ .enable_reg = RK805_DCDC_EN,
+ .enable_mask = 0x20,
+ },
+ {
+ .id = RK808_SWITCH2,
+ .name = "SWITCH_REG2",
+ .enable_reg = RK805_DCDC_EN,
+ .enable_mask = 0x40,
+ },
};
static int
Modified: head/sys/arm64/rockchip/rk805reg.h
==============================================================================
--- head/sys/arm64/rockchip/rk805reg.h Sat Dec 28 13:35:54 2019 (r356147)
+++ head/sys/arm64/rockchip/rk805reg.h Sat Dec 28 15:28:39 2019 (r356148)
@@ -58,6 +58,16 @@
#define RK805_LDO2_SLEEP_VSEL 0x3E
#define RK805_LDO3_ON_VSEL 0x3F
#define RK805_LDO3_SLEEP_VSEL 0x40
+#define RK808_LDO4_ON_VSEL 0x41
+#define RK808_LDO4_SLEEP_VSEL 0x42
+#define RK808_LDO5_ON_VSEL 0x43
+#define RK808_LDO5_SLEEP_VSEL 0x44
+#define RK808_LDO6_ON_VSEL 0x45
+#define RK808_LDO6_SLEEP_VSEL 0x46
+#define RK808_LDO7_ON_VSEL 0x47
+#define RK808_LDO7_SLEEP_VSEL 0x48
+#define RK808_LDO8_ON_VSEL 0x49
+#define RK808_LDO8_SLEEP_VSEL 0x4A
enum rk805_regulator {
RK805_DCDC1 = 0,
More information about the svn-src-all
mailing list