Skip to content

Commit 5a32fe4

Browse files
committed
Merge tag 'pm-5.7-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm
Pull power management update from Rafael Wysocki: "Allow the operating performance points (OPP) core to be used in the case when the same driver is used on different platforms, some of which have an OPP table and some of which have a clock node (Rajendra Nayak)" * tag 'pm-5.7-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: opp: Manage empty OPP tables with clk handle
2 parents c8a6552 + 2c127c4 commit 5a32fe4

File tree

1 file changed

+14
-0
lines changed

1 file changed

+14
-0
lines changed

drivers/opp/core.c

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -819,6 +819,8 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq)
819819
if (unlikely(!target_freq)) {
820820
if (opp_table->required_opp_tables) {
821821
ret = _set_required_opps(dev, opp_table, NULL);
822+
} else if (!_get_opp_count(opp_table)) {
823+
return 0;
822824
} else {
823825
dev_err(dev, "target frequency can't be 0\n");
824826
ret = -EINVAL;
@@ -849,6 +851,18 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq)
849851
goto put_opp_table;
850852
}
851853

854+
/*
855+
* For IO devices which require an OPP on some platforms/SoCs
856+
* while just needing to scale the clock on some others
857+
* we look for empty OPP tables with just a clock handle and
858+
* scale only the clk. This makes dev_pm_opp_set_rate()
859+
* equivalent to a clk_set_rate()
860+
*/
861+
if (!_get_opp_count(opp_table)) {
862+
ret = _generic_set_opp_clk_only(dev, clk, freq);
863+
goto put_opp_table;
864+
}
865+
852866
temp_freq = old_freq;
853867
old_opp = _find_freq_ceil(opp_table, &temp_freq);
854868
if (IS_ERR(old_opp)) {

0 commit comments

Comments
 (0)