Commit 944441d8 authored by Daniel Lezcano's avatar Daniel Lezcano Committed by Daniel Lezcano

thermal/drivers/broadcom: Switch to new of API

The thermal OF code has a new API allowing to migrate the OF
initialization to a simpler approach. The ops are no longer device
tree specific and are the generic ones provided by the core code.

Convert the ops to the thermal_zone_device_ops format and use the new
API to register the thermal zone with these generic ops.
Signed-off-by: default avatarDaniel Lezcano <daniel.lezcano@linexp.org>
Tested-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Link: https://lore.kernel.org/r/20220804224349.1926752-11-daniel.lezcano@linexp.orgSigned-off-by: default avatarDaniel Lezcano <daniel.lezcano@linaro.org>
parent 7f689a2e
...@@ -31,11 +31,11 @@ struct bcm2711_thermal_priv { ...@@ -31,11 +31,11 @@ struct bcm2711_thermal_priv {
struct thermal_zone_device *thermal; struct thermal_zone_device *thermal;
}; };
static int bcm2711_get_temp(void *data, int *temp) static int bcm2711_get_temp(struct thermal_zone_device *tz, int *temp)
{ {
struct bcm2711_thermal_priv *priv = data; struct bcm2711_thermal_priv *priv = tz->devdata;
int slope = thermal_zone_get_slope(priv->thermal); int slope = thermal_zone_get_slope(tz);
int offset = thermal_zone_get_offset(priv->thermal); int offset = thermal_zone_get_offset(tz);
u32 val; u32 val;
int ret; int ret;
...@@ -54,7 +54,7 @@ static int bcm2711_get_temp(void *data, int *temp) ...@@ -54,7 +54,7 @@ static int bcm2711_get_temp(void *data, int *temp)
return 0; return 0;
} }
static const struct thermal_zone_of_device_ops bcm2711_thermal_of_ops = { static const struct thermal_zone_device_ops bcm2711_thermal_of_ops = {
.get_temp = bcm2711_get_temp, .get_temp = bcm2711_get_temp,
}; };
...@@ -88,7 +88,7 @@ static int bcm2711_thermal_probe(struct platform_device *pdev) ...@@ -88,7 +88,7 @@ static int bcm2711_thermal_probe(struct platform_device *pdev)
} }
priv->regmap = regmap; priv->regmap = regmap;
thermal = devm_thermal_zone_of_sensor_register(dev, 0, priv, thermal = devm_thermal_of_zone_register(dev, 0, priv,
&bcm2711_thermal_of_ops); &bcm2711_thermal_of_ops);
if (IS_ERR(thermal)) { if (IS_ERR(thermal)) {
ret = PTR_ERR(thermal); ret = PTR_ERR(thermal);
......
...@@ -88,9 +88,9 @@ static int bcm2835_thermal_temp2adc(int temp, int offset, int slope) ...@@ -88,9 +88,9 @@ static int bcm2835_thermal_temp2adc(int temp, int offset, int slope)
return temp; return temp;
} }
static int bcm2835_thermal_get_temp(void *d, int *temp) static int bcm2835_thermal_get_temp(struct thermal_zone_device *tz, int *temp)
{ {
struct bcm2835_thermal_data *data = d; struct bcm2835_thermal_data *data = tz->devdata;
u32 val = readl(data->regs + BCM2835_TS_TSENSSTAT); u32 val = readl(data->regs + BCM2835_TS_TSENSSTAT);
if (!(val & BCM2835_TS_TSENSSTAT_VALID)) if (!(val & BCM2835_TS_TSENSSTAT_VALID))
...@@ -135,7 +135,7 @@ static void bcm2835_thermal_debugfs(struct platform_device *pdev) ...@@ -135,7 +135,7 @@ static void bcm2835_thermal_debugfs(struct platform_device *pdev)
debugfs_create_regset32("regset", 0444, data->debugfsdir, regset); debugfs_create_regset32("regset", 0444, data->debugfsdir, regset);
} }
static const struct thermal_zone_of_device_ops bcm2835_thermal_ops = { static const struct thermal_zone_device_ops bcm2835_thermal_ops = {
.get_temp = bcm2835_thermal_get_temp, .get_temp = bcm2835_thermal_get_temp,
}; };
...@@ -206,7 +206,7 @@ static int bcm2835_thermal_probe(struct platform_device *pdev) ...@@ -206,7 +206,7 @@ static int bcm2835_thermal_probe(struct platform_device *pdev)
data->clk, rate); data->clk, rate);
/* register of thermal sensor and get info from DT */ /* register of thermal sensor and get info from DT */
tz = thermal_zone_of_sensor_register(&pdev->dev, 0, data, tz = devm_thermal_of_zone_register(&pdev->dev, 0, data,
&bcm2835_thermal_ops); &bcm2835_thermal_ops);
if (IS_ERR(tz)) { if (IS_ERR(tz)) {
err = PTR_ERR(tz); err = PTR_ERR(tz);
...@@ -277,7 +277,7 @@ static int bcm2835_thermal_probe(struct platform_device *pdev) ...@@ -277,7 +277,7 @@ static int bcm2835_thermal_probe(struct platform_device *pdev)
return 0; return 0;
err_tz: err_tz:
thermal_zone_of_sensor_unregister(&pdev->dev, tz); thermal_of_zone_unregister(tz);
err_clk: err_clk:
clk_disable_unprepare(data->clk); clk_disable_unprepare(data->clk);
...@@ -290,7 +290,7 @@ static int bcm2835_thermal_remove(struct platform_device *pdev) ...@@ -290,7 +290,7 @@ static int bcm2835_thermal_remove(struct platform_device *pdev)
struct thermal_zone_device *tz = data->tz; struct thermal_zone_device *tz = data->tz;
debugfs_remove_recursive(data->debugfsdir); debugfs_remove_recursive(data->debugfsdir);
thermal_zone_of_sensor_unregister(&pdev->dev, tz); thermal_of_zone_unregister(tz);
clk_disable_unprepare(data->clk); clk_disable_unprepare(data->clk);
return 0; return 0;
......
...@@ -105,7 +105,7 @@ static struct avs_tmon_trip avs_tmon_trips[] = { ...@@ -105,7 +105,7 @@ static struct avs_tmon_trip avs_tmon_trips[] = {
struct brcmstb_thermal_params { struct brcmstb_thermal_params {
unsigned int offset; unsigned int offset;
unsigned int mult; unsigned int mult;
const struct thermal_zone_of_device_ops *of_ops; const struct thermal_zone_device_ops *of_ops;
}; };
struct brcmstb_thermal_priv { struct brcmstb_thermal_priv {
...@@ -150,9 +150,9 @@ static inline u32 avs_tmon_temp_to_code(struct brcmstb_thermal_priv *priv, ...@@ -150,9 +150,9 @@ static inline u32 avs_tmon_temp_to_code(struct brcmstb_thermal_priv *priv,
return (u32)((offset - temp) / mult); return (u32)((offset - temp) / mult);
} }
static int brcmstb_get_temp(void *data, int *temp) static int brcmstb_get_temp(struct thermal_zone_device *tz, int *temp)
{ {
struct brcmstb_thermal_priv *priv = data; struct brcmstb_thermal_priv *priv = tz->devdata;
u32 val; u32 val;
long t; long t;
...@@ -260,9 +260,9 @@ static irqreturn_t brcmstb_tmon_irq_thread(int irq, void *data) ...@@ -260,9 +260,9 @@ static irqreturn_t brcmstb_tmon_irq_thread(int irq, void *data)
return IRQ_HANDLED; return IRQ_HANDLED;
} }
static int brcmstb_set_trips(void *data, int low, int high) static int brcmstb_set_trips(struct thermal_zone_device *tz, int low, int high)
{ {
struct brcmstb_thermal_priv *priv = data; struct brcmstb_thermal_priv *priv = tz->devdata;
dev_dbg(priv->dev, "set trips %d <--> %d\n", low, high); dev_dbg(priv->dev, "set trips %d <--> %d\n", low, high);
...@@ -288,7 +288,7 @@ static int brcmstb_set_trips(void *data, int low, int high) ...@@ -288,7 +288,7 @@ static int brcmstb_set_trips(void *data, int low, int high)
return 0; return 0;
} }
static const struct thermal_zone_of_device_ops brcmstb_16nm_of_ops = { static const struct thermal_zone_device_ops brcmstb_16nm_of_ops = {
.get_temp = brcmstb_get_temp, .get_temp = brcmstb_get_temp,
}; };
...@@ -298,7 +298,7 @@ static const struct brcmstb_thermal_params brcmstb_16nm_params = { ...@@ -298,7 +298,7 @@ static const struct brcmstb_thermal_params brcmstb_16nm_params = {
.of_ops = &brcmstb_16nm_of_ops, .of_ops = &brcmstb_16nm_of_ops,
}; };
static const struct thermal_zone_of_device_ops brcmstb_28nm_of_ops = { static const struct thermal_zone_device_ops brcmstb_28nm_of_ops = {
.get_temp = brcmstb_get_temp, .get_temp = brcmstb_get_temp,
.set_trips = brcmstb_set_trips, .set_trips = brcmstb_set_trips,
}; };
...@@ -318,7 +318,7 @@ MODULE_DEVICE_TABLE(of, brcmstb_thermal_id_table); ...@@ -318,7 +318,7 @@ MODULE_DEVICE_TABLE(of, brcmstb_thermal_id_table);
static int brcmstb_thermal_probe(struct platform_device *pdev) static int brcmstb_thermal_probe(struct platform_device *pdev)
{ {
const struct thermal_zone_of_device_ops *of_ops; const struct thermal_zone_device_ops *of_ops;
struct thermal_zone_device *thermal; struct thermal_zone_device *thermal;
struct brcmstb_thermal_priv *priv; struct brcmstb_thermal_priv *priv;
struct resource *res; struct resource *res;
...@@ -341,7 +341,7 @@ static int brcmstb_thermal_probe(struct platform_device *pdev) ...@@ -341,7 +341,7 @@ static int brcmstb_thermal_probe(struct platform_device *pdev)
platform_set_drvdata(pdev, priv); platform_set_drvdata(pdev, priv);
of_ops = priv->temp_params->of_ops; of_ops = priv->temp_params->of_ops;
thermal = devm_thermal_zone_of_sensor_register(&pdev->dev, 0, priv, thermal = devm_thermal_of_zone_register(&pdev->dev, 0, priv,
of_ops); of_ops);
if (IS_ERR(thermal)) { if (IS_ERR(thermal)) {
ret = PTR_ERR(thermal); ret = PTR_ERR(thermal);
......
...@@ -14,19 +14,14 @@ ...@@ -14,19 +14,14 @@
#define PVTMON_CONTROL0_SEL_TEST_MODE 0x0000000e #define PVTMON_CONTROL0_SEL_TEST_MODE 0x0000000e
#define PVTMON_STATUS 0x08 #define PVTMON_STATUS 0x08
struct ns_thermal { static int ns_thermal_get_temp(struct thermal_zone_device *tz, int *temp)
struct thermal_zone_device *tz;
void __iomem *pvtmon;
};
static int ns_thermal_get_temp(void *data, int *temp)
{ {
struct ns_thermal *ns_thermal = data; void __iomem *pvtmon = tz->devdata;
int offset = thermal_zone_get_offset(ns_thermal->tz); int offset = thermal_zone_get_offset(tz);
int slope = thermal_zone_get_slope(ns_thermal->tz); int slope = thermal_zone_get_slope(tz);
u32 val; u32 val;
val = readl(ns_thermal->pvtmon + PVTMON_CONTROL0); val = readl(pvtmon + PVTMON_CONTROL0);
if ((val & PVTMON_CONTROL0_SEL_MASK) != PVTMON_CONTROL0_SEL_TEMP_MONITOR) { if ((val & PVTMON_CONTROL0_SEL_MASK) != PVTMON_CONTROL0_SEL_TEMP_MONITOR) {
/* Clear current mode selection */ /* Clear current mode selection */
val &= ~PVTMON_CONTROL0_SEL_MASK; val &= ~PVTMON_CONTROL0_SEL_MASK;
...@@ -34,50 +29,47 @@ static int ns_thermal_get_temp(void *data, int *temp) ...@@ -34,50 +29,47 @@ static int ns_thermal_get_temp(void *data, int *temp)
/* Set temp monitor mode (it's the default actually) */ /* Set temp monitor mode (it's the default actually) */
val |= PVTMON_CONTROL0_SEL_TEMP_MONITOR; val |= PVTMON_CONTROL0_SEL_TEMP_MONITOR;
writel(val, ns_thermal->pvtmon + PVTMON_CONTROL0); writel(val, pvtmon + PVTMON_CONTROL0);
} }
val = readl(ns_thermal->pvtmon + PVTMON_STATUS); val = readl(pvtmon + PVTMON_STATUS);
*temp = slope * val + offset; *temp = slope * val + offset;
return 0; return 0;
} }
static const struct thermal_zone_of_device_ops ns_thermal_ops = { static const struct thermal_zone_device_ops ns_thermal_ops = {
.get_temp = ns_thermal_get_temp, .get_temp = ns_thermal_get_temp,
}; };
static int ns_thermal_probe(struct platform_device *pdev) static int ns_thermal_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct ns_thermal *ns_thermal; struct thermal_zone_device *tz;
void __iomem *pvtmon;
ns_thermal = devm_kzalloc(dev, sizeof(*ns_thermal), GFP_KERNEL);
if (!ns_thermal)
return -ENOMEM;
ns_thermal->pvtmon = of_iomap(dev_of_node(dev), 0); pvtmon = of_iomap(dev_of_node(dev), 0);
if (WARN_ON(!ns_thermal->pvtmon)) if (WARN_ON(!pvtmon))
return -ENOENT; return -ENOENT;
ns_thermal->tz = devm_thermal_zone_of_sensor_register(dev, 0, tz = devm_thermal_of_zone_register(dev, 0,
ns_thermal, pvtmon,
&ns_thermal_ops); &ns_thermal_ops);
if (IS_ERR(ns_thermal->tz)) { if (IS_ERR(tz)) {
iounmap(ns_thermal->pvtmon); iounmap(pvtmon);
return PTR_ERR(ns_thermal->tz); return PTR_ERR(tz);
} }
platform_set_drvdata(pdev, ns_thermal); platform_set_drvdata(pdev, pvtmon);
return 0; return 0;
} }
static int ns_thermal_remove(struct platform_device *pdev) static int ns_thermal_remove(struct platform_device *pdev)
{ {
struct ns_thermal *ns_thermal = platform_get_drvdata(pdev); void __iomem *pvtmon = platform_get_drvdata(pdev);
iounmap(ns_thermal->pvtmon); iounmap(pvtmon);
return 0; return 0;
} }
......
...@@ -19,7 +19,6 @@ ...@@ -19,7 +19,6 @@
#define SR_TMON_MAX_LIST 6 #define SR_TMON_MAX_LIST 6
struct sr_tmon { struct sr_tmon {
struct thermal_zone_device *tz;
unsigned int crit_temp; unsigned int crit_temp;
unsigned int tmon_id; unsigned int tmon_id;
struct sr_thermal *priv; struct sr_thermal *priv;
...@@ -31,9 +30,9 @@ struct sr_thermal { ...@@ -31,9 +30,9 @@ struct sr_thermal {
struct sr_tmon tmon[SR_TMON_MAX_LIST]; struct sr_tmon tmon[SR_TMON_MAX_LIST];
}; };
static int sr_get_temp(void *data, int *temp) static int sr_get_temp(struct thermal_zone_device *tz, int *temp)
{ {
struct sr_tmon *tmon = data; struct sr_tmon *tmon = tz->devdata;
struct sr_thermal *sr_thermal = tmon->priv; struct sr_thermal *sr_thermal = tmon->priv;
*temp = readl(sr_thermal->regs + SR_TMON_TEMP_BASE(tmon->tmon_id)); *temp = readl(sr_thermal->regs + SR_TMON_TEMP_BASE(tmon->tmon_id));
...@@ -41,13 +40,14 @@ static int sr_get_temp(void *data, int *temp) ...@@ -41,13 +40,14 @@ static int sr_get_temp(void *data, int *temp)
return 0; return 0;
} }
static const struct thermal_zone_of_device_ops sr_tz_ops = { static const struct thermal_zone_device_ops sr_tz_ops = {
.get_temp = sr_get_temp, .get_temp = sr_get_temp,
}; };
static int sr_thermal_probe(struct platform_device *pdev) static int sr_thermal_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct thermal_zone_device *tz;
struct sr_thermal *sr_thermal; struct sr_thermal *sr_thermal;
struct sr_tmon *tmon; struct sr_tmon *tmon;
struct resource *res; struct resource *res;
...@@ -84,10 +84,10 @@ static int sr_thermal_probe(struct platform_device *pdev) ...@@ -84,10 +84,10 @@ static int sr_thermal_probe(struct platform_device *pdev)
writel(0, sr_thermal->regs + SR_TMON_TEMP_BASE(i)); writel(0, sr_thermal->regs + SR_TMON_TEMP_BASE(i));
tmon->tmon_id = i; tmon->tmon_id = i;
tmon->priv = sr_thermal; tmon->priv = sr_thermal;
tmon->tz = devm_thermal_zone_of_sensor_register(dev, i, tmon, tz = devm_thermal_of_zone_register(dev, i, tmon,
&sr_tz_ops); &sr_tz_ops);
if (IS_ERR(tmon->tz)) if (IS_ERR(tz))
return PTR_ERR(tmon->tz); return PTR_ERR(tz);
dev_dbg(dev, "thermal sensor %d registered\n", i); dev_dbg(dev, "thermal sensor %d registered\n", i);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment