Skip to content

Commit 4e89a53

Browse files
committed
Merge tag 'opp-updates-6.11' of ssh://gitolite.kernel.org/pub/scm/linux/kernel/git/vireshk/pm into pm-opp
Merge OPP Updates for 6.11 from Viresh Kumar: "- Introduce an OF helper function to inform if required-opps is used (Ulf Hansson). - Generic cleanups (Ulf Hansson and Viresh Kumar)." * tag 'opp-updates-6.11' of ssh://gitolite.kernel.org/pub/scm/linux/kernel/git/vireshk/pm: OPP: Introduce an OF helper function to inform if required-opps is used OPP: Drop a redundant in-parameter to _set_opp_level() OPP: Fix missing cleanup on error in _opp_attach_genpd()
2 parents 256abd8 + e3943f0 commit 4e89a53

File tree

3 files changed

+46
-7
lines changed

3 files changed

+46
-7
lines changed

drivers/opp/core.c

Lines changed: 8 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1102,8 +1102,7 @@ static int _set_required_opps(struct device *dev, struct opp_table *opp_table,
11021102
return 0;
11031103
}
11041104

1105-
static int _set_opp_level(struct device *dev, struct opp_table *opp_table,
1106-
struct dev_pm_opp *opp)
1105+
static int _set_opp_level(struct device *dev, struct dev_pm_opp *opp)
11071106
{
11081107
unsigned int level = 0;
11091108
int ret = 0;
@@ -1171,7 +1170,7 @@ static int _disable_opp_table(struct device *dev, struct opp_table *opp_table)
11711170
if (opp_table->regulators)
11721171
regulator_disable(opp_table->regulators[0]);
11731172

1174-
ret = _set_opp_level(dev, opp_table, NULL);
1173+
ret = _set_opp_level(dev, NULL);
11751174
if (ret)
11761175
goto out;
11771176

@@ -1220,7 +1219,7 @@ static int _set_opp(struct device *dev, struct opp_table *opp_table,
12201219
return ret;
12211220
}
12221221

1223-
ret = _set_opp_level(dev, opp_table, opp);
1222+
ret = _set_opp_level(dev, opp);
12241223
if (ret)
12251224
return ret;
12261225

@@ -1267,7 +1266,7 @@ static int _set_opp(struct device *dev, struct opp_table *opp_table,
12671266
return ret;
12681267
}
12691268

1270-
ret = _set_opp_level(dev, opp_table, opp);
1269+
ret = _set_opp_level(dev, opp);
12711270
if (ret)
12721271
return ret;
12731272

@@ -2443,8 +2442,10 @@ static int _opp_attach_genpd(struct opp_table *opp_table, struct device *dev,
24432442
* Cross check it again and fix if required.
24442443
*/
24452444
gdev = dev_to_genpd_dev(virt_dev);
2446-
if (IS_ERR(gdev))
2447-
return PTR_ERR(gdev);
2445+
if (IS_ERR(gdev)) {
2446+
ret = PTR_ERR(gdev);
2447+
goto err;
2448+
}
24482449

24492450
genpd_table = _find_opp_table(gdev);
24502451
if (!IS_ERR(genpd_table)) {

drivers/opp/of.c

Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1443,6 +1443,38 @@ int of_get_required_opp_performance_state(struct device_node *np, int index)
14431443
}
14441444
EXPORT_SYMBOL_GPL(of_get_required_opp_performance_state);
14451445

1446+
/**
1447+
* dev_pm_opp_of_has_required_opp - Find out if a required-opps exists.
1448+
* @dev: The device to investigate.
1449+
*
1450+
* Returns true if the device's node has a "operating-points-v2" property and if
1451+
* the corresponding node for the opp-table describes opp nodes that uses the
1452+
* "required-opps" property.
1453+
*
1454+
* Return: True if a required-opps is present, else false.
1455+
*/
1456+
bool dev_pm_opp_of_has_required_opp(struct device *dev)
1457+
{
1458+
struct device_node *opp_np, *np;
1459+
int count;
1460+
1461+
opp_np = _opp_of_get_opp_desc_node(dev->of_node, 0);
1462+
if (!opp_np)
1463+
return false;
1464+
1465+
np = of_get_next_available_child(opp_np, NULL);
1466+
of_node_put(opp_np);
1467+
if (!np) {
1468+
dev_warn(dev, "Empty OPP table\n");
1469+
return false;
1470+
}
1471+
1472+
count = of_count_phandle_with_args(np, "required-opps", NULL);
1473+
of_node_put(np);
1474+
1475+
return count > 0;
1476+
}
1477+
14461478
/**
14471479
* dev_pm_opp_get_of_node() - Gets the DT node corresponding to an opp
14481480
* @opp: opp for which DT node has to be returned for

include/linux/pm_opp.h

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -474,6 +474,7 @@ int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, struct cpumask *cpuma
474474
struct device_node *dev_pm_opp_of_get_opp_desc_node(struct device *dev);
475475
struct device_node *dev_pm_opp_get_of_node(struct dev_pm_opp *opp);
476476
int of_get_required_opp_performance_state(struct device_node *np, int index);
477+
bool dev_pm_opp_of_has_required_opp(struct device *dev);
477478
int dev_pm_opp_of_find_icc_paths(struct device *dev, struct opp_table *opp_table);
478479
int dev_pm_opp_of_register_em(struct device *dev, struct cpumask *cpus);
479480
int dev_pm_opp_calc_power(struct device *dev, unsigned long *uW,
@@ -552,6 +553,11 @@ static inline int of_get_required_opp_performance_state(struct device_node *np,
552553
return -EOPNOTSUPP;
553554
}
554555

556+
static inline bool dev_pm_opp_of_has_required_opp(struct device *dev)
557+
{
558+
return false;
559+
}
560+
555561
static inline int dev_pm_opp_of_find_icc_paths(struct device *dev, struct opp_table *opp_table)
556562
{
557563
return -EOPNOTSUPP;

0 commit comments

Comments
 (0)