Lines Matching +full:regulator +full:- +full:v4
1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (c) 2011-2014, The Linux Foundation. All rights reserved.
22 #include <linux/regulator/driver.h>
259 if (drv->reg_data->reg_offset[reg]) in spm_register_write()
260 writel_relaxed(val, drv->reg_base + in spm_register_write()
261 drv->reg_data->reg_offset[reg]); in spm_register_write()
270 if (!drv->reg_data->reg_offset[reg]) in spm_register_write_sync()
274 writel_relaxed(val, drv->reg_base + in spm_register_write_sync()
275 drv->reg_data->reg_offset[reg]); in spm_register_write_sync()
276 ret = readl_relaxed(drv->reg_base + in spm_register_write_sync()
277 drv->reg_data->reg_offset[reg]); in spm_register_write_sync()
287 return readl_relaxed(drv->reg_base + drv->reg_data->reg_offset[reg]); in spm_register_read()
296 start_index = drv->reg_data->start_index[mode]; in spm_set_low_power_mode()
309 drv->volt_sel = selector; in spm_set_voltage_sel()
312 return smp_call_function_single(drv->reg_cpu, drv->reg_data->set_vdd, drv, true); in spm_set_voltage_sel()
319 return drv->volt_sel; in spm_get_voltage_sel()
336 volt_sel = drv->volt_sel; in smp_set_vdd_v1_1()
368 dev_err_ratelimited(drv->dev, "timeout setting the voltage (%x %x)!\n", sts, vlevel); in smp_set_vdd_v1_1()
374 unsigned int min_avs = max(max_avs, 4U) - 4; in smp_set_vdd_v1_1()
401 found = (saw_node == dev->of_node); in spm_get_cpu()
411 return -EOPNOTSUPP; in spm_get_cpu()
425 if (!drv->reg_data->set_vdd) in spm_register_regulator()
430 return -ENOMEM; in spm_register_regulator()
432 rdesc->name = "spm"; in spm_register_regulator()
433 rdesc->of_match = of_match_ptr("regulator"); in spm_register_regulator()
434 rdesc->type = REGULATOR_VOLTAGE; in spm_register_regulator()
435 rdesc->owner = THIS_MODULE; in spm_register_regulator()
436 rdesc->ops = &spm_reg_ops; in spm_register_regulator()
438 rdesc->linear_ranges = drv->reg_data->range; in spm_register_regulator()
439 rdesc->n_linear_ranges = 1; in spm_register_regulator()
440 rdesc->n_voltages = rdesc->linear_ranges[rdesc->n_linear_ranges - 1].max_sel + 1; in spm_register_regulator()
441 rdesc->ramp_delay = drv->reg_data->ramp_delay; in spm_register_regulator()
447 drv->reg_cpu = ret; in spm_register_regulator()
448 dev_dbg(dev, "SAW2 bound to CPU %d\n", drv->reg_cpu); in spm_register_regulator()
454 drv->volt_sel = DIV_ROUND_UP(drv->reg_data->init_uV - rdesc->min_uV, in spm_register_regulator()
455 rdesc->uV_step); in spm_register_regulator()
456 ret = linear_range_get_selector_high(drv->reg_data->range, in spm_register_regulator()
457 drv->reg_data->init_uV, in spm_register_regulator()
458 &drv->volt_sel, in spm_register_regulator()
466 smp_call_function_single(drv->reg_cpu, drv->reg_data->set_vdd, drv, true); in spm_register_regulator()
470 dev_err(dev, "failed to register regulator\n"); in spm_register_regulator()
478 { .compatible = "qcom,sdm660-gold-saw2-v4.1-l2",
480 { .compatible = "qcom,sdm660-silver-saw2-v4.1-l2",
482 { .compatible = "qcom,msm8226-saw2-v2.1-cpu",
484 { .compatible = "qcom,msm8909-saw2-v3.0-cpu",
486 { .compatible = "qcom,msm8916-saw2-v3.0-cpu",
488 { .compatible = "qcom,msm8939-saw2-v3.0-cpu",
490 { .compatible = "qcom,msm8974-saw2-v2.1-cpu",
492 { .compatible = "qcom,msm8976-gold-saw2-v2.3-l2",
494 { .compatible = "qcom,msm8976-silver-saw2-v2.3-l2",
496 { .compatible = "qcom,msm8998-gold-saw2-v4.1-l2",
498 { .compatible = "qcom,msm8998-silver-saw2-v4.1-l2",
500 { .compatible = "qcom,apq8084-saw2-v2.1-cpu",
502 { .compatible = "qcom,apq8064-saw2-v1.1-cpu",
514 drv = devm_kzalloc(&pdev->dev, sizeof(*drv), GFP_KERNEL); in spm_dev_probe()
516 return -ENOMEM; in spm_dev_probe()
518 drv->reg_base = devm_platform_ioremap_resource(pdev, 0); in spm_dev_probe()
519 if (IS_ERR(drv->reg_base)) in spm_dev_probe()
520 return PTR_ERR(drv->reg_base); in spm_dev_probe()
522 match_id = of_match_node(spm_match_table, pdev->dev.of_node); in spm_dev_probe()
524 return -ENODEV; in spm_dev_probe()
526 drv->reg_data = match_id->data; in spm_dev_probe()
527 drv->dev = &pdev->dev; in spm_dev_probe()
531 addr = drv->reg_base + drv->reg_data->reg_offset[SPM_REG_SEQ_ENTRY]; in spm_dev_probe()
532 __iowrite32_copy(addr, drv->reg_data->seq, in spm_dev_probe()
533 ARRAY_SIZE(drv->reg_data->seq) / 4); in spm_dev_probe()
541 spm_register_write(drv, SPM_REG_AVS_CTL, drv->reg_data->avs_ctl); in spm_dev_probe()
542 spm_register_write(drv, SPM_REG_AVS_LIMIT, drv->reg_data->avs_limit); in spm_dev_probe()
543 spm_register_write(drv, SPM_REG_CFG, drv->reg_data->spm_cfg); in spm_dev_probe()
544 spm_register_write(drv, SPM_REG_DLY, drv->reg_data->spm_dly); in spm_dev_probe()
545 spm_register_write(drv, SPM_REG_PMIC_DLY, drv->reg_data->pmic_dly); in spm_dev_probe()
547 drv->reg_data->pmic_data[0]); in spm_dev_probe()
549 drv->reg_data->pmic_data[1]); in spm_dev_probe()
552 if (drv->reg_data->reg_offset[SPM_REG_SPM_CTL]) in spm_dev_probe()
556 return spm_register_regulator(&pdev->dev, drv); in spm_dev_probe()