Lines Matching +full:rk3568 +full:- +full:vop

1 // SPDX-License-Identifier: GPL-2.0-only
26 * - If the voltage on a rail is above the "1.8" voltage (1.98V) we'll tell the
28 * - If the voltage on a rail is above the "3.3" voltage (3.6V) we'll consider
84 struct rockchip_iodomain *iod = supply->iod; in rk3568_iodomain_write()
89 switch (supply->idx) { in rk3568_iodomain_write()
93 b = supply->idx; in rk3568_iodomain_write()
95 b = supply->idx + 4; in rk3568_iodomain_write()
98 regmap_write(iod->grf, RK3568_PMU_GRF_IO_VSEL2, val0); in rk3568_iodomain_write()
99 regmap_write(iod->grf, RK3568_PMU_GRF_IO_VSEL2, val1); in rk3568_iodomain_write()
109 b = supply->idx - 1; in rk3568_iodomain_write()
113 regmap_write(iod->grf, RK3568_PMU_GRF_IO_VSEL0, val0); in rk3568_iodomain_write()
114 regmap_write(iod->grf, RK3568_PMU_GRF_IO_VSEL1, val1); in rk3568_iodomain_write()
117 return -EINVAL; in rk3568_iodomain_write()
126 struct rockchip_iodomain *iod = supply->iod; in rockchip_iodomain_write()
132 val <<= supply->idx; in rockchip_iodomain_write()
134 /* apply hiword-mask */ in rockchip_iodomain_write()
135 val |= (BIT(supply->idx) << 16); in rockchip_iodomain_write()
137 ret = regmap_write(iod->grf, iod->soc_data->grf_offset, val); in rockchip_iodomain_write()
139 dev_err(iod->dev, "Couldn't write to GRF\n"); in rockchip_iodomain_write()
169 uV = max_t(unsigned long, pvc_data->old_uV, pvc_data->max_uV); in rockchip_iodomain_notify()
177 dev_dbg(supply->iod->dev, "Setting to %d\n", uV); in rockchip_iodomain_notify()
180 dev_err(supply->iod->dev, "Voltage too high: %d\n", uV); in rockchip_iodomain_notify()
186 ret = supply->iod->write(supply, uV); in rockchip_iodomain_notify()
190 dev_dbg(supply->iod->dev, "Setting to %d done\n", uV); in rockchip_iodomain_notify()
200 if (!iod->supplies[PX30_IO_VSEL_VCCIO6_SUPPLY_NUM].reg) in px30_iodomain_init()
208 ret = regmap_write(iod->grf, PX30_IO_VSEL, val); in px30_iodomain_init()
210 dev_warn(iod->dev, "couldn't update vccio6 ctrl\n"); in px30_iodomain_init()
219 if (!iod->supplies[RK3288_SOC_FLASH_SUPPLY_NUM].reg) in rk3288_iodomain_init()
227 ret = regmap_write(iod->grf, RK3288_SOC_CON2, val); in rk3288_iodomain_init()
229 dev_warn(iod->dev, "couldn't update flash0 ctrl\n"); in rk3288_iodomain_init()
238 if (!iod->supplies[RK3328_SOC_VCCIO2_SUPPLY_NUM].reg) in rk3328_iodomain_init()
246 ret = regmap_write(iod->grf, RK3328_SOC_CON4, val); in rk3328_iodomain_init()
248 dev_warn(iod->dev, "couldn't update vccio2 vsel ctrl\n"); in rk3328_iodomain_init()
257 if (!iod->supplies[RK3368_SOC_FLASH_SUPPLY_NUM].reg) in rk3368_iodomain_init()
265 ret = regmap_write(iod->grf, RK3368_SOC_CON15, val); in rk3368_iodomain_init()
267 dev_warn(iod->dev, "couldn't update flash0 ctrl\n"); in rk3368_iodomain_init()
276 if (!iod->supplies[RK3399_PMUGRF_VSEL_SUPPLY_NUM].reg) in rk3399_pmu_iodomain_init()
284 ret = regmap_write(iod->grf, RK3399_PMUGRF_CON0, val); in rk3399_pmu_iodomain_init()
286 dev_warn(iod->dev, "couldn't update pmu io iodomain ctrl\n"); in rk3399_pmu_iodomain_init()
299 "vccio-oscgpi",
327 * On the rk3188 the io-domains are handled by a shared register with the
328 * lower 8 bits being still being continuing drive-strength settings.
417 "vop", /*LCDC IO domain*/
512 .compatible = "rockchip,px30-io-voltage-domain",
516 .compatible = "rockchip,px30-pmu-io-voltage-domain",
520 .compatible = "rockchip,rk3188-io-voltage-domain",
524 .compatible = "rockchip,rk3228-io-voltage-domain",
528 .compatible = "rockchip,rk3288-io-voltage-domain",
532 .compatible = "rockchip,rk3328-io-voltage-domain",
536 .compatible = "rockchip,rk3368-io-voltage-domain",
540 .compatible = "rockchip,rk3368-pmu-io-voltage-domain",
544 .compatible = "rockchip,rk3399-io-voltage-domain",
548 .compatible = "rockchip,rk3399-pmu-io-voltage-domain",
552 .compatible = "rockchip,rk3568-pmu-io-voltage-domain",
556 .compatible = "rockchip,rv1108-io-voltage-domain",
560 .compatible = "rockchip,rv1108-pmu-io-voltage-domain",
564 .compatible = "rockchip,rv1126-pmu-io-voltage-domain",
573 struct device_node *np = pdev->dev.of_node; in rockchip_iodomain_probe()
580 return -ENODEV; in rockchip_iodomain_probe()
582 iod = devm_kzalloc(&pdev->dev, sizeof(*iod), GFP_KERNEL); in rockchip_iodomain_probe()
584 return -ENOMEM; in rockchip_iodomain_probe()
586 iod->dev = &pdev->dev; in rockchip_iodomain_probe()
590 iod->soc_data = match->data; in rockchip_iodomain_probe()
592 if (iod->soc_data->write) in rockchip_iodomain_probe()
593 iod->write = iod->soc_data->write; in rockchip_iodomain_probe()
595 iod->write = rockchip_iodomain_write; in rockchip_iodomain_probe()
597 parent = pdev->dev.parent; in rockchip_iodomain_probe()
598 if (parent && parent->of_node) { in rockchip_iodomain_probe()
599 iod->grf = syscon_node_to_regmap(parent->of_node); in rockchip_iodomain_probe()
601 dev_dbg(&pdev->dev, "falling back to old binding\n"); in rockchip_iodomain_probe()
602 iod->grf = syscon_regmap_lookup_by_phandle(np, "rockchip,grf"); in rockchip_iodomain_probe()
605 if (IS_ERR(iod->grf)) { in rockchip_iodomain_probe()
606 dev_err(&pdev->dev, "couldn't find grf regmap\n"); in rockchip_iodomain_probe()
607 return PTR_ERR(iod->grf); in rockchip_iodomain_probe()
611 const char *supply_name = iod->soc_data->supply_names[i]; in rockchip_iodomain_probe()
612 struct rockchip_iodomain_supply *supply = &iod->supplies[i]; in rockchip_iodomain_probe()
619 reg = devm_regulator_get_optional(iod->dev, supply_name); in rockchip_iodomain_probe()
624 if (ret == -ENODEV) in rockchip_iodomain_probe()
626 else if (ret != -EPROBE_DEFER) in rockchip_iodomain_probe()
627 dev_err(iod->dev, "couldn't get regulator %s\n", in rockchip_iodomain_probe()
637 dev_err(iod->dev, "Can't determine voltage: %s\n", in rockchip_iodomain_probe()
644 dev_crit(iod->dev, in rockchip_iodomain_probe()
647 ret = -EINVAL; in rockchip_iodomain_probe()
652 supply->idx = i; in rockchip_iodomain_probe()
653 supply->iod = iod; in rockchip_iodomain_probe()
654 supply->reg = reg; in rockchip_iodomain_probe()
655 supply->nb.notifier_call = rockchip_iodomain_notify; in rockchip_iodomain_probe()
657 ret = iod->write(supply, uV); in rockchip_iodomain_probe()
659 supply->reg = NULL; in rockchip_iodomain_probe()
664 ret = regulator_register_notifier(reg, &supply->nb); in rockchip_iodomain_probe()
666 dev_err(&pdev->dev, in rockchip_iodomain_probe()
668 supply->reg = NULL; in rockchip_iodomain_probe()
673 if (iod->soc_data->init) in rockchip_iodomain_probe()
674 iod->soc_data->init(iod); in rockchip_iodomain_probe()
679 for (i = MAX_SUPPLIES - 1; i >= 0; i--) { in rockchip_iodomain_probe()
680 struct rockchip_iodomain_supply *io_supply = &iod->supplies[i]; in rockchip_iodomain_probe()
682 if (io_supply->reg) in rockchip_iodomain_probe()
683 regulator_unregister_notifier(io_supply->reg, in rockchip_iodomain_probe()
684 &io_supply->nb); in rockchip_iodomain_probe()
695 for (i = MAX_SUPPLIES - 1; i >= 0; i--) { in rockchip_iodomain_remove()
696 struct rockchip_iodomain_supply *io_supply = &iod->supplies[i]; in rockchip_iodomain_remove()
698 if (io_supply->reg) in rockchip_iodomain_remove()
699 regulator_unregister_notifier(io_supply->reg, in rockchip_iodomain_remove()
700 &io_supply->nb); in rockchip_iodomain_remove()
710 .name = "rockchip-iodomain",
717 MODULE_DESCRIPTION("Rockchip IO-domain driver");