mirror of https://gitee.com/openkylin/linux.git
regulator: Fixes for v5.5
A small set of fixes for mostly minor issues here, the only real code ones are Wen Yang's fixes for error handling in the core and Christian Marussi's list_voltage() change which is a fix for disruptively bad performance for regulators with continuous voltage control (which are rare). -----BEGIN PGP SIGNATURE----- iQFHBAABCgAxFiEEreZoqmdXGLWf4p/qJNaLcl1Uh9AFAl34yr4THGJyb29uaWVA a2VybmVsLm9yZwAKCRAk1otyXVSH0KJyB/97dTSIk+gJxwFSc9tTPbMvSGvGqoEL AUE8JSHVNqav9IdFKwtzxa6dnjVy1U23ySemeOAvabmLmyJjoIRMJAeA10+OwcMl 2dq3j/3z6Vl305QSVNu3yMcxp2XtQ8nhKOpNz+rDGwRAvr08YBjdrCPv4dbiv/ei G7z7sOwcNNACE7CNGat3kOh9cOJm3wVzls1bF5Ix+kDlWH6v591GSY1MMXdhx6Tj RS9HCjj8Gp4O+vnJH4r/AVkOyZp8SOSOje/+81pF68wc2g+S7XV8hE4kDipRlHS3 4aKpBbfyA4twjZ4AOCVGTwJrGXh6W7GhDlrbWCYyQ3y2hOfwgbh8sKzo =Lx6m -----END PGP SIGNATURE----- Merge tag 'regulator-fix-v5.5-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator Pull regulator fixes from Mark Brown: "A small set of fixes for mostly minor issues here, the only real code ones are Wen Yang's fixes for error handling in the core and Christian Marussi's list_voltage() change which is a fix for disruptively bad performance for regulators with continuous voltage control (which are rare)" * tag 'regulator-fix-v5.5-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator: regulator: rn5t618: fix module aliases regulator: max77650: add of_match table regulator: core: avoid unneeded .list_voltage calls regulator: s5m8767: Fix a warning message regulator: core: fix regulator_register() error paths to properly release rdev regulator: fix use after free issue
This commit is contained in:
commit
58d90a04bd
|
@ -1198,6 +1198,10 @@ static int machine_constraints_voltage(struct regulator_dev *rdev,
|
|||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* no need to loop voltages if range is continuous */
|
||||
if (rdev->desc->continuous_voltage_range)
|
||||
return 0;
|
||||
|
||||
/* initial: [cmin..cmax] valid, [min_uV..max_uV] not */
|
||||
for (i = 0; i < count; i++) {
|
||||
int value;
|
||||
|
@ -1938,8 +1942,8 @@ struct regulator *_regulator_get(struct device *dev, const char *id,
|
|||
regulator = create_regulator(rdev, dev, id);
|
||||
if (regulator == NULL) {
|
||||
regulator = ERR_PTR(-ENOMEM);
|
||||
put_device(&rdev->dev);
|
||||
module_put(rdev->owner);
|
||||
put_device(&rdev->dev);
|
||||
return regulator;
|
||||
}
|
||||
|
||||
|
@ -2063,13 +2067,13 @@ static void _regulator_put(struct regulator *regulator)
|
|||
|
||||
rdev->open_count--;
|
||||
rdev->exclusive = 0;
|
||||
put_device(&rdev->dev);
|
||||
regulator_unlock(rdev);
|
||||
|
||||
kfree_const(regulator->supply_name);
|
||||
kfree(regulator);
|
||||
|
||||
module_put(rdev->owner);
|
||||
put_device(&rdev->dev);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -5002,6 +5006,7 @@ regulator_register(const struct regulator_desc *regulator_desc,
|
|||
struct regulator_dev *rdev;
|
||||
bool dangling_cfg_gpiod = false;
|
||||
bool dangling_of_gpiod = false;
|
||||
bool reg_device_fail = false;
|
||||
struct device *dev;
|
||||
int ret, i;
|
||||
|
||||
|
@ -5187,7 +5192,7 @@ regulator_register(const struct regulator_desc *regulator_desc,
|
|||
dev_set_drvdata(&rdev->dev, rdev);
|
||||
ret = device_register(&rdev->dev);
|
||||
if (ret != 0) {
|
||||
put_device(&rdev->dev);
|
||||
reg_device_fail = true;
|
||||
goto unset_supplies;
|
||||
}
|
||||
|
||||
|
@ -5218,6 +5223,9 @@ regulator_register(const struct regulator_desc *regulator_desc,
|
|||
clean:
|
||||
if (dangling_of_gpiod)
|
||||
gpiod_put(config->ena_gpiod);
|
||||
if (reg_device_fail)
|
||||
put_device(&rdev->dev);
|
||||
else
|
||||
kfree(rdev);
|
||||
kfree(config);
|
||||
rinse:
|
||||
|
|
|
@ -386,9 +386,16 @@ static int max77650_regulator_probe(struct platform_device *pdev)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id max77650_regulator_of_match[] = {
|
||||
{ .compatible = "maxim,max77650-regulator" },
|
||||
{ }
|
||||
};
|
||||
MODULE_DEVICE_TABLE(of, max77650_regulator_of_match);
|
||||
|
||||
static struct platform_driver max77650_regulator_driver = {
|
||||
.driver = {
|
||||
.name = "max77650-regulator",
|
||||
.of_match_table = max77650_regulator_of_match,
|
||||
},
|
||||
.probe = max77650_regulator_probe,
|
||||
};
|
||||
|
|
|
@ -148,6 +148,7 @@ static struct platform_driver rn5t618_regulator_driver = {
|
|||
|
||||
module_platform_driver(rn5t618_regulator_driver);
|
||||
|
||||
MODULE_ALIAS("platform:rn5t618-regulator");
|
||||
MODULE_AUTHOR("Beniamino Galvani <b.galvani@gmail.com>");
|
||||
MODULE_DESCRIPTION("RN5T618 regulator driver");
|
||||
MODULE_LICENSE("GPL v2");
|
||||
|
|
|
@ -588,7 +588,7 @@ static int s5m8767_pmic_dt_parse_pdata(struct platform_device *pdev,
|
|||
if (of_property_read_u32(reg_np, "op_mode",
|
||||
&rmode->mode)) {
|
||||
dev_warn(iodev->dev,
|
||||
"no op_mode property property at %pOF\n",
|
||||
"no op_mode property at %pOF\n",
|
||||
reg_np);
|
||||
|
||||
rmode->mode = S5M8767_OPMODE_NORMAL_MODE;
|
||||
|
|
Loading…
Reference in New Issue