[PATCH 6/8] regulator: qcom-rpmh-regulator: add support for pm6150l regulators
Neil Armstrong
neil.armstrong at linaro.org
Fri Jun 20 10:56:24 CEST 2025
On 18/06/2025 16:25, Luca Weiss wrote:
> Add the pm6150l regulator data found on the Qualcomm SM6350 platform.
> The tables are imported from the Linux driver. The SMPS regulators were
> not added now.
>
> Signed-off-by: Luca Weiss <luca.weiss at fairphone.com>
> ---
> drivers/power/regulator/qcom-rpmh-regulator.c | 31 +++++++++++++++++++++++++++
> 1 file changed, 31 insertions(+)
>
> diff --git a/drivers/power/regulator/qcom-rpmh-regulator.c b/drivers/power/regulator/qcom-rpmh-regulator.c
> index 954deca5ed75ca4f58898ee401bd06c9da82e56e..0646614256049e49846aa257bd02466fb9cf59d7 100644
> --- a/drivers/power/regulator/qcom-rpmh-regulator.c
> +++ b/drivers/power/regulator/qcom-rpmh-regulator.c
> @@ -456,6 +456,16 @@ static const struct rpmh_vreg_hw_data pmic5_pldo_lv = {
> .n_modes = ARRAY_SIZE(pmic_mode_map_pmic5_ldo),
> };
>
> +static const struct rpmh_vreg_hw_data pmic5_nldo = {
> + .regulator_type = VRM,
> + .ops = &rpmh_regulator_vrm_drms_ops,
> + .voltage_range = REGULATOR_LINEAR_RANGE(320000, 0, 123, 8000),
> + .n_voltages = 124,
> + .hpm_min_load_uA = 30000,
> + .pmic_mode_map = pmic_mode_map_pmic5_ldo,
> + .n_modes = ARRAY_SIZE(pmic_mode_map_pmic5_ldo),
> +};
> +
> static const struct rpmh_vreg_hw_data pmic5_nldo515 = {
> .regulator_type = VRM,
> .ops = &rpmh_regulator_vrm_drms_ops,
> @@ -493,6 +503,23 @@ static const struct rpmh_vreg_hw_data pmic5_pldo515_mv = {
> .supply_name = _supply_name, \
> }
>
> +static const struct rpmh_vreg_init_data pm6150l_vreg_data[] = {
> + /* smps1 - smps8 are not added to u-boot yet */
> + RPMH_VREG("ldo1", "ldo%s1", &pmic5_pldo_lv, "vdd-l1-l8"),
> + RPMH_VREG("ldo2", "ldo%s2", &pmic5_nldo, "vdd-l2-l3"),
> + RPMH_VREG("ldo3", "ldo%s3", &pmic5_nldo, "vdd-l2-l3"),
> + RPMH_VREG("ldo4", "ldo%s4", &pmic5_pldo, "vdd-l4-l5-l6"),
> + RPMH_VREG("ldo5", "ldo%s5", &pmic5_pldo, "vdd-l4-l5-l6"),
> + RPMH_VREG("ldo6", "ldo%s6", &pmic5_pldo, "vdd-l4-l5-l6"),
> + RPMH_VREG("ldo7", "ldo%s7", &pmic5_pldo, "vdd-l7-l11"),
> + RPMH_VREG("ldo8", "ldo%s8", &pmic5_pldo, "vdd-l1-l8"),
> + RPMH_VREG("ldo9", "ldo%s9", &pmic5_pldo, "vdd-l9-l10"),
> + RPMH_VREG("ldo10", "ldo%s10", &pmic5_pldo, "vdd-l9-l10"),
> + RPMH_VREG("ldo11", "ldo%s11", &pmic5_pldo, "vdd-l7-l11"),
> + RPMH_VREG("bob", "bob%s1", &pmic5_bob, "vdd-bob"),
> + {}
> +};
> +
> static const struct rpmh_vreg_init_data pm8150_vreg_data[] = {
> RPMH_VREG("ldo13", "ldo%s13", &pmic5_pldo, "vdd-l13-l16-l17"),
> {}
> @@ -705,6 +732,10 @@ static int rpmh_regulators_bind(struct udevice *dev)
> }
>
> static const struct udevice_id rpmh_regulator_ids[] = {
> + {
> + .compatible = "qcom,pm6150l-rpmh-regulators",
> + .data = (ulong)pm6150l_vreg_data,
> + },
> {
> .compatible = "qcom,pm8150-rpmh-regulators",
> .data = (ulong)pm8150_vreg_data,
>
Reviewed-by: Neil Armstrong <neil.armstrong at linaro.org>
More information about the U-Boot
mailing list