提交 a3193edc 编写于 作者: D Daniel Lezcano 提交者: Daniel Lezcano

thermal/of: Replace device node match with device node search

The thermal_of code builds a trip array associated with the node
pointer in order to compare the trip point phandle with the list.

The thermal trip is a thermal zone property and should be moved
there. If some sensors have hardcoded trip points, they should use the
exported structure instead of redefining again and again their own
structure and data to describe exactly the same things.

In order to move this to the thermal.h header and allow more cleanup,
we need to remove the node pointer from the structure.

Instead of building storing the device node, we search directly in the
device tree the corresponding node. That results in a simplification
of the code and allows to move the structure to thermal.h

Cc: Alexandre Bailon <abailon@baylibre.com>
Cc: Kevin Hilman <khilman@baylibre.com>
Signed-off-by: NDaniel Lezcano <daniel.lezcano@linexp.org>
Link: https://lore.kernel.org/r/20220722200007.1839356-3-daniel.lezcano@linexp.orgSigned-off-by: NDaniel Lezcano <daniel.lezcano@linaro.org>
上级 3f95ac32
...@@ -671,6 +671,35 @@ EXPORT_SYMBOL_GPL(devm_thermal_zone_of_sensor_unregister); ...@@ -671,6 +671,35 @@ EXPORT_SYMBOL_GPL(devm_thermal_zone_of_sensor_unregister);
/*** functions parsing device tree nodes ***/ /*** functions parsing device tree nodes ***/
static int of_find_trip_id(struct device_node *np, struct device_node *trip)
{
struct device_node *trips;
struct device_node *t;
int i = 0;
trips = of_get_child_by_name(np, "trips");
if (!trips) {
pr_err("Failed to find 'trips' node\n");
return -EINVAL;
}
/*
* Find the trip id point associated with the cooling device map
*/
for_each_child_of_node(trips, t) {
if (t == trip)
goto out;
i++;
}
i = -ENXIO;
out:
of_node_put(trips);
return i;
}
/** /**
* thermal_of_populate_bind_params - parse and fill cooling map data * thermal_of_populate_bind_params - parse and fill cooling map data
* @np: DT node containing a cooling-map node * @np: DT node containing a cooling-map node
...@@ -686,14 +715,13 @@ EXPORT_SYMBOL_GPL(devm_thermal_zone_of_sensor_unregister); ...@@ -686,14 +715,13 @@ EXPORT_SYMBOL_GPL(devm_thermal_zone_of_sensor_unregister);
* Return: 0 on success, proper error code otherwise * Return: 0 on success, proper error code otherwise
*/ */
static int thermal_of_populate_bind_params(struct device_node *np, static int thermal_of_populate_bind_params(struct device_node *np,
struct __thermal_bind_params *__tbp, struct __thermal_bind_params *__tbp)
struct thermal_trip *trips,
int ntrips)
{ {
struct of_phandle_args cooling_spec; struct of_phandle_args cooling_spec;
struct __thermal_cooling_bind_param *__tcbp; struct __thermal_cooling_bind_param *__tcbp;
struct device_node *trip; struct device_node *trip;
int ret, i, count; int ret, i, count;
int trip_id;
u32 prop; u32 prop;
/* Default weight. Usage is optional */ /* Default weight. Usage is optional */
...@@ -708,18 +736,14 @@ static int thermal_of_populate_bind_params(struct device_node *np, ...@@ -708,18 +736,14 @@ static int thermal_of_populate_bind_params(struct device_node *np,
return -ENODEV; return -ENODEV;
} }
/* match using device_node */ trip_id = of_find_trip_id(np, trip);
for (i = 0; i < ntrips; i++) if (trip_id < 0) {
if (trip == trips[i].np) { ret = trip_id;
__tbp->trip_id = i;
break;
}
if (i == ntrips) {
ret = -ENODEV;
goto end; goto end;
} }
__tbp->trip_id = trip_id;
count = of_count_phandle_with_args(np, "cooling-device", count = of_count_phandle_with_args(np, "cooling-device",
"#cooling-cells"); "#cooling-cells");
if (count <= 0) { if (count <= 0) {
...@@ -868,6 +892,7 @@ static struct __thermal_zone ...@@ -868,6 +892,7 @@ static struct __thermal_zone
__init *thermal_of_build_thermal_zone(struct device_node *np) __init *thermal_of_build_thermal_zone(struct device_node *np)
{ {
struct device_node *child = NULL, *gchild; struct device_node *child = NULL, *gchild;
struct device_node *trips;
struct __thermal_zone *tz; struct __thermal_zone *tz;
int ret, i; int ret, i;
u32 prop, coef[2]; u32 prop, coef[2];
...@@ -910,13 +935,13 @@ __init *thermal_of_build_thermal_zone(struct device_node *np) ...@@ -910,13 +935,13 @@ __init *thermal_of_build_thermal_zone(struct device_node *np)
} }
/* trips */ /* trips */
child = of_get_child_by_name(np, "trips"); trips = of_get_child_by_name(np, "trips");
/* No trips provided */ /* No trips provided */
if (!child) if (!trips)
goto finish; goto finish;
tz->ntrips = of_get_child_count(child); tz->ntrips = of_get_child_count(trips);
if (tz->ntrips == 0) /* must have at least one child */ if (tz->ntrips == 0) /* must have at least one child */
goto finish; goto finish;
...@@ -927,14 +952,12 @@ __init *thermal_of_build_thermal_zone(struct device_node *np) ...@@ -927,14 +952,12 @@ __init *thermal_of_build_thermal_zone(struct device_node *np)
} }
i = 0; i = 0;
for_each_child_of_node(child, gchild) { for_each_child_of_node(trips, gchild) {
ret = thermal_of_populate_trip(gchild, &tz->trips[i++]); ret = thermal_of_populate_trip(gchild, &tz->trips[i++]);
if (ret) if (ret)
goto free_trips; goto free_trips;
} }
of_node_put(child);
/* cooling-maps */ /* cooling-maps */
child = of_get_child_by_name(np, "cooling-maps"); child = of_get_child_by_name(np, "cooling-maps");
...@@ -954,13 +977,13 @@ __init *thermal_of_build_thermal_zone(struct device_node *np) ...@@ -954,13 +977,13 @@ __init *thermal_of_build_thermal_zone(struct device_node *np)
i = 0; i = 0;
for_each_child_of_node(child, gchild) { for_each_child_of_node(child, gchild) {
ret = thermal_of_populate_bind_params(gchild, &tz->tbps[i++], ret = thermal_of_populate_bind_params(gchild, &tz->tbps[i++]);
tz->trips, tz->ntrips);
if (ret) if (ret)
goto free_tbps; goto free_tbps;
} }
finish: finish:
of_node_put(trips);
of_node_put(child); of_node_put(child);
return tz; return tz;
...@@ -981,6 +1004,7 @@ __init *thermal_of_build_thermal_zone(struct device_node *np) ...@@ -981,6 +1004,7 @@ __init *thermal_of_build_thermal_zone(struct device_node *np)
for (i = 0; i < tz->ntrips; i++) for (i = 0; i < tz->ntrips; i++)
of_node_put(tz->trips[i].np); of_node_put(tz->trips[i].np);
kfree(tz->trips); kfree(tz->trips);
of_node_put(trips);
of_node_put(gchild); of_node_put(gchild);
free_tz: free_tz:
kfree(tz); kfree(tz);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册