Commit 1b75f5e9 authored by Peter Colberg's avatar Peter Colberg Committed by Xu Yilun

fpga: dfl: fme: use SI unit prefix macros

Substitute SI prefixes MILLI for temperature and MICRO for power, which
are exported via the hwmon sysfs interface in m°C and ųW, respectively.
Suggested-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: default avatarPeter Colberg <peter.colberg@intel.com>
Reviewed-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Acked-by: default avatarXu Yilun <yilun.xu@intel.com>
Link: https://lore.kernel.org/r/20230705033548.10737-1-peter.colberg@intel.comSigned-off-by: default avatarXu Yilun <yilun.xu@intel.com>
parent 06c2afb8
...@@ -19,6 +19,7 @@ ...@@ -19,6 +19,7 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/uaccess.h> #include <linux/uaccess.h>
#include <linux/units.h>
#include <linux/fpga-dfl.h> #include <linux/fpga-dfl.h>
#include "dfl.h" #include "dfl.h"
...@@ -231,19 +232,19 @@ static int thermal_hwmon_read(struct device *dev, enum hwmon_sensor_types type, ...@@ -231,19 +232,19 @@ static int thermal_hwmon_read(struct device *dev, enum hwmon_sensor_types type,
switch (attr) { switch (attr) {
case hwmon_temp_input: case hwmon_temp_input:
v = readq(feature->ioaddr + FME_THERM_RDSENSOR_FMT1); v = readq(feature->ioaddr + FME_THERM_RDSENSOR_FMT1);
*val = (long)(FIELD_GET(FPGA_TEMPERATURE, v) * 1000); *val = (long)(FIELD_GET(FPGA_TEMPERATURE, v) * MILLI);
break; break;
case hwmon_temp_max: case hwmon_temp_max:
v = readq(feature->ioaddr + FME_THERM_THRESHOLD); v = readq(feature->ioaddr + FME_THERM_THRESHOLD);
*val = (long)(FIELD_GET(TEMP_THRESHOLD1, v) * 1000); *val = (long)(FIELD_GET(TEMP_THRESHOLD1, v) * MILLI);
break; break;
case hwmon_temp_crit: case hwmon_temp_crit:
v = readq(feature->ioaddr + FME_THERM_THRESHOLD); v = readq(feature->ioaddr + FME_THERM_THRESHOLD);
*val = (long)(FIELD_GET(TEMP_THRESHOLD2, v) * 1000); *val = (long)(FIELD_GET(TEMP_THRESHOLD2, v) * MILLI);
break; break;
case hwmon_temp_emergency: case hwmon_temp_emergency:
v = readq(feature->ioaddr + FME_THERM_THRESHOLD); v = readq(feature->ioaddr + FME_THERM_THRESHOLD);
*val = (long)(FIELD_GET(TRIP_THRESHOLD, v) * 1000); *val = (long)(FIELD_GET(TRIP_THRESHOLD, v) * MILLI);
break; break;
case hwmon_temp_max_alarm: case hwmon_temp_max_alarm:
v = readq(feature->ioaddr + FME_THERM_THRESHOLD); v = readq(feature->ioaddr + FME_THERM_THRESHOLD);
...@@ -382,15 +383,15 @@ static int power_hwmon_read(struct device *dev, enum hwmon_sensor_types type, ...@@ -382,15 +383,15 @@ static int power_hwmon_read(struct device *dev, enum hwmon_sensor_types type,
switch (attr) { switch (attr) {
case hwmon_power_input: case hwmon_power_input:
v = readq(feature->ioaddr + FME_PWR_STATUS); v = readq(feature->ioaddr + FME_PWR_STATUS);
*val = (long)(FIELD_GET(PWR_CONSUMED, v) * 1000000); *val = (long)(FIELD_GET(PWR_CONSUMED, v) * MICRO);
break; break;
case hwmon_power_max: case hwmon_power_max:
v = readq(feature->ioaddr + FME_PWR_THRESHOLD); v = readq(feature->ioaddr + FME_PWR_THRESHOLD);
*val = (long)(FIELD_GET(PWR_THRESHOLD1, v) * 1000000); *val = (long)(FIELD_GET(PWR_THRESHOLD1, v) * MICRO);
break; break;
case hwmon_power_crit: case hwmon_power_crit:
v = readq(feature->ioaddr + FME_PWR_THRESHOLD); v = readq(feature->ioaddr + FME_PWR_THRESHOLD);
*val = (long)(FIELD_GET(PWR_THRESHOLD2, v) * 1000000); *val = (long)(FIELD_GET(PWR_THRESHOLD2, v) * MICRO);
break; break;
case hwmon_power_max_alarm: case hwmon_power_max_alarm:
v = readq(feature->ioaddr + FME_PWR_THRESHOLD); v = readq(feature->ioaddr + FME_PWR_THRESHOLD);
...@@ -415,7 +416,7 @@ static int power_hwmon_write(struct device *dev, enum hwmon_sensor_types type, ...@@ -415,7 +416,7 @@ static int power_hwmon_write(struct device *dev, enum hwmon_sensor_types type,
int ret = 0; int ret = 0;
u64 v; u64 v;
val = clamp_val(val / 1000000, 0, PWR_THRESHOLD_MAX); val = clamp_val(val / MICRO, 0, PWR_THRESHOLD_MAX);
mutex_lock(&pdata->lock); mutex_lock(&pdata->lock);
......
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