Commit 4a62d588 authored by Rafael J. Wysocki's avatar Rafael J. Wysocki

thermal: core: Eliminate writable trip points masks

All of the thermal_zone_device_register_with_trips() callers pass zero
writable trip points masks to it, so drop the mask argument from that
function and update all of its callers accordingly.

This also removes the artificial trip points per zone limit of 32,
related to using writable trip points masks.

No intentional functional impact.
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
Reviewed-by: default avatarDaniel Lezcano <daniel.lezcano@linaro.org>
parent 83c2d444
...@@ -665,7 +665,7 @@ static int acpi_thermal_register_thermal_zone(struct acpi_thermal *tz, ...@@ -665,7 +665,7 @@ static int acpi_thermal_register_thermal_zone(struct acpi_thermal *tz,
tz->thermal_zone = thermal_zone_device_register_with_trips("acpitz", tz->thermal_zone = thermal_zone_device_register_with_trips("acpitz",
trip_table, trip_table,
trip_count, trip_count,
0, tz, tz,
&acpi_thermal_zone_ops, &acpi_thermal_zone_ops,
NULL, NULL,
passive_delay, passive_delay,
......
...@@ -60,7 +60,7 @@ int cxgb4_thermal_init(struct adapter *adap) ...@@ -60,7 +60,7 @@ int cxgb4_thermal_init(struct adapter *adap)
snprintf(ch_tz_name, sizeof(ch_tz_name), "cxgb4_%s", adap->name); snprintf(ch_tz_name, sizeof(ch_tz_name), "cxgb4_%s", adap->name);
ch_thermal->tzdev = thermal_zone_device_register_with_trips(ch_tz_name, &trip, num_trip, ch_thermal->tzdev = thermal_zone_device_register_with_trips(ch_tz_name, &trip, num_trip,
0, adap, adap,
&cxgb4_thermal_ops, &cxgb4_thermal_ops,
NULL, 0, 0); NULL, 0, 0);
if (IS_ERR(ch_thermal->tzdev)) { if (IS_ERR(ch_thermal->tzdev)) {
......
...@@ -423,7 +423,6 @@ mlxsw_thermal_module_tz_init(struct mlxsw_thermal_module *module_tz) ...@@ -423,7 +423,6 @@ mlxsw_thermal_module_tz_init(struct mlxsw_thermal_module *module_tz)
module_tz->tzdev = thermal_zone_device_register_with_trips(tz_name, module_tz->tzdev = thermal_zone_device_register_with_trips(tz_name,
module_tz->trips, module_tz->trips,
MLXSW_THERMAL_NUM_TRIPS, MLXSW_THERMAL_NUM_TRIPS,
0,
module_tz, module_tz,
&mlxsw_thermal_module_ops, &mlxsw_thermal_module_ops,
&mlxsw_thermal_params, &mlxsw_thermal_params,
...@@ -551,7 +550,6 @@ mlxsw_thermal_gearbox_tz_init(struct mlxsw_thermal_module *gearbox_tz) ...@@ -551,7 +550,6 @@ mlxsw_thermal_gearbox_tz_init(struct mlxsw_thermal_module *gearbox_tz)
gearbox_tz->tzdev = thermal_zone_device_register_with_trips(tz_name, gearbox_tz->tzdev = thermal_zone_device_register_with_trips(tz_name,
gearbox_tz->trips, gearbox_tz->trips,
MLXSW_THERMAL_NUM_TRIPS, MLXSW_THERMAL_NUM_TRIPS,
0,
gearbox_tz, gearbox_tz,
&mlxsw_thermal_gearbox_ops, &mlxsw_thermal_gearbox_ops,
&mlxsw_thermal_params, 0, &mlxsw_thermal_params, 0,
...@@ -776,7 +774,6 @@ int mlxsw_thermal_init(struct mlxsw_core *core, ...@@ -776,7 +774,6 @@ int mlxsw_thermal_init(struct mlxsw_core *core,
thermal->tzdev = thermal_zone_device_register_with_trips("mlxsw", thermal->tzdev = thermal_zone_device_register_with_trips("mlxsw",
thermal->trips, thermal->trips,
MLXSW_THERMAL_NUM_TRIPS, MLXSW_THERMAL_NUM_TRIPS,
0,
thermal, thermal,
&mlxsw_thermal_ops, &mlxsw_thermal_ops,
&mlxsw_thermal_params, 0, &mlxsw_thermal_params, 0,
......
...@@ -694,7 +694,6 @@ static void iwl_mvm_thermal_zone_register(struct iwl_mvm *mvm) ...@@ -694,7 +694,6 @@ static void iwl_mvm_thermal_zone_register(struct iwl_mvm *mvm)
mvm->tz_device.tzone = thermal_zone_device_register_with_trips(name, mvm->tz_device.tzone = thermal_zone_device_register_with_trips(name,
mvm->tz_device.trips, mvm->tz_device.trips,
IWL_MAX_DTS_TRIPS, IWL_MAX_DTS_TRIPS,
0,
mvm, &tzone_ops, mvm, &tzone_ops,
NULL, 0, 0); NULL, 0, 0);
if (IS_ERR(mvm->tz_device.tzone)) { if (IS_ERR(mvm->tz_device.tzone)) {
......
...@@ -678,7 +678,7 @@ static int __init acerhdf_register_thermal(void) ...@@ -678,7 +678,7 @@ static int __init acerhdf_register_thermal(void)
return -EINVAL; return -EINVAL;
thz_dev = thermal_zone_device_register_with_trips("acerhdf", trips, ARRAY_SIZE(trips), thz_dev = thermal_zone_device_register_with_trips("acerhdf", trips, ARRAY_SIZE(trips),
0, NULL, &acerhdf_dev_ops, NULL, &acerhdf_dev_ops,
&acerhdf_zone_params, 0, &acerhdf_zone_params, 0,
(kernelmode) ? interval*1000 : 0); (kernelmode) ? interval*1000 : 0);
if (IS_ERR(thz_dev)) if (IS_ERR(thz_dev))
......
...@@ -197,7 +197,7 @@ static int da9062_thermal_probe(struct platform_device *pdev) ...@@ -197,7 +197,7 @@ static int da9062_thermal_probe(struct platform_device *pdev)
mutex_init(&thermal->lock); mutex_init(&thermal->lock);
thermal->zone = thermal_zone_device_register_with_trips(thermal->config->name, thermal->zone = thermal_zone_device_register_with_trips(thermal->config->name,
trips, ARRAY_SIZE(trips), 0, thermal, trips, ARRAY_SIZE(trips), thermal,
&da9062_thermal_ops, NULL, pp_tmp, &da9062_thermal_ops, NULL, pp_tmp,
0); 0);
if (IS_ERR(thermal->zone)) { if (IS_ERR(thermal->zone)) {
......
...@@ -701,7 +701,7 @@ static int imx_thermal_probe(struct platform_device *pdev) ...@@ -701,7 +701,7 @@ static int imx_thermal_probe(struct platform_device *pdev)
data->tz = thermal_zone_device_register_with_trips("imx_thermal_zone", data->tz = thermal_zone_device_register_with_trips("imx_thermal_zone",
trips, trips,
ARRAY_SIZE(trips), ARRAY_SIZE(trips),
0, data, data,
&imx_tz_ops, NULL, &imx_tz_ops, NULL,
IMX_PASSIVE_DELAY, IMX_PASSIVE_DELAY,
IMX_POLLING_DELAY); IMX_POLLING_DELAY);
......
...@@ -171,7 +171,7 @@ struct int34x_thermal_zone *int340x_thermal_zone_add(struct acpi_device *adev, ...@@ -171,7 +171,7 @@ struct int34x_thermal_zone *int340x_thermal_zone_add(struct acpi_device *adev,
int34x_zone->zone = thermal_zone_device_register_with_trips( int34x_zone->zone = thermal_zone_device_register_with_trips(
acpi_device_bid(adev), acpi_device_bid(adev),
zone_trips, trip_cnt, zone_trips, trip_cnt,
0, int34x_zone, int34x_zone,
&zone_ops, &zone_ops,
&int340x_thermal_params, &int340x_thermal_params,
0, 0); 0, 0);
......
...@@ -290,7 +290,7 @@ static int proc_thermal_pci_probe(struct pci_dev *pdev, const struct pci_device_ ...@@ -290,7 +290,7 @@ static int proc_thermal_pci_probe(struct pci_dev *pdev, const struct pci_device_
psv_trip.temperature = get_trip_temp(pci_info); psv_trip.temperature = get_trip_temp(pci_info);
pci_info->tzone = thermal_zone_device_register_with_trips("TCPU_PCI", &psv_trip, pci_info->tzone = thermal_zone_device_register_with_trips("TCPU_PCI", &psv_trip,
1, 0, pci_info, 1, pci_info,
&tzone_ops, &tzone_ops,
&tzone_params, 0, 0); &tzone_params, 0, 0);
if (IS_ERR(pci_info->tzone)) { if (IS_ERR(pci_info->tzone)) {
......
...@@ -237,7 +237,7 @@ static int intel_pch_thermal_probe(struct pci_dev *pdev, ...@@ -237,7 +237,7 @@ static int intel_pch_thermal_probe(struct pci_dev *pdev,
ptd->tzd = thermal_zone_device_register_with_trips(board_names[board_id], ptd->tzd = thermal_zone_device_register_with_trips(board_names[board_id],
ptd_trips, nr_trips, ptd_trips, nr_trips,
0, ptd, &tzd_ops, ptd, &tzd_ops,
NULL, 0, 0); NULL, 0, 0);
if (IS_ERR(ptd->tzd)) { if (IS_ERR(ptd->tzd)) {
dev_err(&pdev->dev, "Failed to register thermal zone %s\n", dev_err(&pdev->dev, "Failed to register thermal zone %s\n",
......
...@@ -363,7 +363,7 @@ static struct soc_sensor_entry *alloc_soc_dts(void) ...@@ -363,7 +363,7 @@ static struct soc_sensor_entry *alloc_soc_dts(void)
aux_entry->tzone = thermal_zone_device_register_with_trips("quark_dts", aux_entry->tzone = thermal_zone_device_register_with_trips("quark_dts",
trips, trips,
QRK_MAX_DTS_TRIPS, QRK_MAX_DTS_TRIPS,
0, aux_entry, aux_entry,
&tzone_ops, &tzone_ops,
NULL, 0, polling_delay); NULL, 0, polling_delay);
if (IS_ERR(aux_entry->tzone)) { if (IS_ERR(aux_entry->tzone)) {
......
...@@ -230,7 +230,7 @@ static int add_dts_thermal_zone(int id, struct intel_soc_dts_sensor_entry *dts, ...@@ -230,7 +230,7 @@ static int add_dts_thermal_zone(int id, struct intel_soc_dts_sensor_entry *dts,
snprintf(name, sizeof(name), "soc_dts%d", id); snprintf(name, sizeof(name), "soc_dts%d", id);
dts->tzone = thermal_zone_device_register_with_trips(name, trips, dts->tzone = thermal_zone_device_register_with_trips(name, trips,
SOC_MAX_DTS_TRIPS, SOC_MAX_DTS_TRIPS,
0, dts, &tzone_ops, dts, &tzone_ops,
NULL, 0, 0); NULL, 0, 0);
if (IS_ERR(dts->tzone)) { if (IS_ERR(dts->tzone)) {
ret = PTR_ERR(dts->tzone); ret = PTR_ERR(dts->tzone);
......
...@@ -338,7 +338,7 @@ static int pkg_temp_thermal_device_add(unsigned int cpu) ...@@ -338,7 +338,7 @@ static int pkg_temp_thermal_device_add(unsigned int cpu)
INIT_DELAYED_WORK(&zonedev->work, pkg_temp_thermal_threshold_work_fn); INIT_DELAYED_WORK(&zonedev->work, pkg_temp_thermal_threshold_work_fn);
zonedev->cpu = cpu; zonedev->cpu = cpu;
zonedev->tzone = thermal_zone_device_register_with_trips("x86_pkg_temp", zonedev->tzone = thermal_zone_device_register_with_trips("x86_pkg_temp",
trips, thres_count, 0, trips, thres_count,
zonedev, &tzone_ops, &pkg_temp_tz_params, 0, 0); zonedev, &tzone_ops, &pkg_temp_tz_params, 0, 0);
if (IS_ERR(zonedev->tzone)) { if (IS_ERR(zonedev->tzone)) {
err = PTR_ERR(zonedev->tzone); err = PTR_ERR(zonedev->tzone);
......
...@@ -489,7 +489,7 @@ static int rcar_thermal_probe(struct platform_device *pdev) ...@@ -489,7 +489,7 @@ static int rcar_thermal_probe(struct platform_device *pdev)
&rcar_thermal_zone_ops); &rcar_thermal_zone_ops);
} else { } else {
priv->zone = thermal_zone_device_register_with_trips( priv->zone = thermal_zone_device_register_with_trips(
"rcar_thermal", trips, ARRAY_SIZE(trips), 0, priv, "rcar_thermal", trips, ARRAY_SIZE(trips), priv,
&rcar_thermal_zone_ops, NULL, 0, &rcar_thermal_zone_ops, NULL, 0,
idle); idle);
......
...@@ -203,7 +203,7 @@ int st_thermal_register(struct platform_device *pdev, ...@@ -203,7 +203,7 @@ int st_thermal_register(struct platform_device *pdev,
trip.type = THERMAL_TRIP_CRITICAL; trip.type = THERMAL_TRIP_CRITICAL;
sensor->thermal_dev = sensor->thermal_dev =
thermal_zone_device_register_with_trips(dev_name(dev), &trip, 1, 0, sensor, thermal_zone_device_register_with_trips(dev_name(dev), &trip, 1, sensor,
&st_tz_ops, NULL, 0, polling_delay); &st_tz_ops, NULL, 0, polling_delay);
if (IS_ERR(sensor->thermal_dev)) { if (IS_ERR(sensor->thermal_dev)) {
dev_err(dev, "failed to register thermal zone device\n"); dev_err(dev, "failed to register thermal zone device\n");
......
...@@ -1248,7 +1248,6 @@ EXPORT_SYMBOL_GPL(thermal_zone_get_crit_temp); ...@@ -1248,7 +1248,6 @@ EXPORT_SYMBOL_GPL(thermal_zone_get_crit_temp);
* @type: the thermal zone device type * @type: the thermal zone device type
* @trips: a pointer to an array of thermal trips * @trips: a pointer to an array of thermal trips
* @num_trips: the number of trip points the thermal zone support * @num_trips: the number of trip points the thermal zone support
* @mask: a bit string indicating the writeablility of trip points
* @devdata: private device data * @devdata: private device data
* @ops: standard thermal zone device callbacks * @ops: standard thermal zone device callbacks
* @tzp: thermal zone platform parameters * @tzp: thermal zone platform parameters
...@@ -1271,14 +1270,12 @@ EXPORT_SYMBOL_GPL(thermal_zone_get_crit_temp); ...@@ -1271,14 +1270,12 @@ EXPORT_SYMBOL_GPL(thermal_zone_get_crit_temp);
struct thermal_zone_device * struct thermal_zone_device *
thermal_zone_device_register_with_trips(const char *type, thermal_zone_device_register_with_trips(const char *type,
const struct thermal_trip *trips, const struct thermal_trip *trips,
int num_trips, int mask, int num_trips, void *devdata,
void *devdata,
const struct thermal_zone_device_ops *ops, const struct thermal_zone_device_ops *ops,
const struct thermal_zone_params *tzp, const struct thermal_zone_params *tzp,
int passive_delay, int polling_delay) int passive_delay, int polling_delay)
{ {
struct thermal_zone_device *tz; struct thermal_zone_device *tz;
struct thermal_trip *trip;
int id; int id;
int result; int result;
struct thermal_governor *governor; struct thermal_governor *governor;
...@@ -1294,20 +1291,7 @@ thermal_zone_device_register_with_trips(const char *type, ...@@ -1294,20 +1291,7 @@ thermal_zone_device_register_with_trips(const char *type,
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
/* if (num_trips < 0) {
* Max trip count can't exceed 31 as the "mask >> num_trips" condition.
* For example, shifting by 32 will result in compiler warning:
* warning: right shift count >= width of type [-Wshift-count- overflow]
*
* Also "mask >> num_trips" will always be true with 32 bit shift.
* E.g. mask = 0x80000000 for trip id 31 to be RW. Then
* mask >> 32 = 0x80000000
* This will result in failure for the below condition.
*
* Check will be true when the bit 31 of the mask is set.
* 32 bit shift will cause overflow of 4 byte integer.
*/
if (num_trips > (BITS_PER_TYPE(int) - 1) || num_trips < 0 || mask >> num_trips) {
pr_err("Incorrect number of thermal trips\n"); pr_err("Incorrect number of thermal trips\n");
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
...@@ -1357,12 +1341,6 @@ thermal_zone_device_register_with_trips(const char *type, ...@@ -1357,12 +1341,6 @@ thermal_zone_device_register_with_trips(const char *type,
tz->devdata = devdata; tz->devdata = devdata;
tz->num_trips = num_trips; tz->num_trips = num_trips;
memcpy(tz->trips, trips, num_trips * sizeof(*trips)); memcpy(tz->trips, trips, num_trips * sizeof(*trips));
for_each_trip(tz, trip) {
if (mask & 1)
trip->flags |= THERMAL_TRIP_FLAG_RW_TEMP;
mask >>= 1;
}
thermal_set_delay_jiffies(&tz->passive_delay_jiffies, passive_delay); thermal_set_delay_jiffies(&tz->passive_delay_jiffies, passive_delay);
thermal_set_delay_jiffies(&tz->polling_delay_jiffies, polling_delay); thermal_set_delay_jiffies(&tz->polling_delay_jiffies, polling_delay);
...@@ -1447,7 +1425,7 @@ struct thermal_zone_device *thermal_tripless_zone_device_register( ...@@ -1447,7 +1425,7 @@ struct thermal_zone_device *thermal_tripless_zone_device_register(
const struct thermal_zone_device_ops *ops, const struct thermal_zone_device_ops *ops,
const struct thermal_zone_params *tzp) const struct thermal_zone_params *tzp)
{ {
return thermal_zone_device_register_with_trips(type, NULL, 0, 0, devdata, return thermal_zone_device_register_with_trips(type, NULL, 0, devdata,
ops, tzp, 0, 0); ops, tzp, 0, 0);
} }
EXPORT_SYMBOL_GPL(thermal_tripless_zone_device_register); EXPORT_SYMBOL_GPL(thermal_tripless_zone_device_register);
......
...@@ -507,7 +507,7 @@ static struct thermal_zone_device *thermal_of_zone_register(struct device_node * ...@@ -507,7 +507,7 @@ static struct thermal_zone_device *thermal_of_zone_register(struct device_node *
of_ops.critical = thermal_zone_device_critical_reboot; of_ops.critical = thermal_zone_device_critical_reboot;
tz = thermal_zone_device_register_with_trips(np->name, trips, ntrips, tz = thermal_zone_device_register_with_trips(np->name, trips, ntrips,
0, data, &of_ops, &tzp, data, &of_ops, &tzp,
pdelay, delay); pdelay, delay);
if (IS_ERR(tz)) { if (IS_ERR(tz)) {
ret = PTR_ERR(tz); ret = PTR_ERR(tz);
......
...@@ -323,8 +323,7 @@ int thermal_zone_get_crit_temp(struct thermal_zone_device *tz, int *temp); ...@@ -323,8 +323,7 @@ int thermal_zone_get_crit_temp(struct thermal_zone_device *tz, int *temp);
struct thermal_zone_device *thermal_zone_device_register_with_trips( struct thermal_zone_device *thermal_zone_device_register_with_trips(
const char *type, const char *type,
const struct thermal_trip *trips, const struct thermal_trip *trips,
int num_trips, int mask, int num_trips, void *devdata,
void *devdata,
const struct thermal_zone_device_ops *ops, const struct thermal_zone_device_ops *ops,
const struct thermal_zone_params *tzp, const struct thermal_zone_params *tzp,
int passive_delay, int polling_delay); int passive_delay, int polling_delay);
...@@ -383,8 +382,7 @@ void thermal_zone_device_critical(struct thermal_zone_device *tz); ...@@ -383,8 +382,7 @@ void thermal_zone_device_critical(struct thermal_zone_device *tz);
static inline struct thermal_zone_device *thermal_zone_device_register_with_trips( static inline struct thermal_zone_device *thermal_zone_device_register_with_trips(
const char *type, const char *type,
const struct thermal_trip *trips, const struct thermal_trip *trips,
int num_trips, int mask, int num_trips, void *devdata,
void *devdata,
const struct thermal_zone_device_ops *ops, const struct thermal_zone_device_ops *ops,
const struct thermal_zone_params *tzp, const struct thermal_zone_params *tzp,
int passive_delay, int polling_delay) int passive_delay, int polling_delay)
......
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