提交 40257b95 编写于 作者: G Guenter Roeck

hwmon: (pmbus) Fix low limit temperature alarms

Temperature alarms are detected by checking the alarm bit and comparing
temperature limits against the current temperature. For low limits, this
comparison needs to be reversed (temp < limit instead of temp > limit).
This was not taken into account, resulting in wrong alarms if a temperature
fell below a low limit.

Fix by adding a low limit flag in the limit data structure. When creating the
sensor entry, the order of registers to compare is now reversed for low limits.
Signed-off-by: NGuenter Roeck <guenter.roeck@ericsson.com>
Acked-by: NJean Delvare <khali@linux-fr.org>
Cc: stable@kernel.org # 3.0+
上级 b6fd41e2
...@@ -978,6 +978,8 @@ static void pmbus_find_max_attr(struct i2c_client *client, ...@@ -978,6 +978,8 @@ static void pmbus_find_max_attr(struct i2c_client *client,
struct pmbus_limit_attr { struct pmbus_limit_attr {
u16 reg; /* Limit register */ u16 reg; /* Limit register */
bool update; /* True if register needs updates */ bool update; /* True if register needs updates */
bool low; /* True if low limit; for limits with compare
functions only */
const char *attr; /* Attribute name */ const char *attr; /* Attribute name */
const char *alarm; /* Alarm attribute name */ const char *alarm; /* Alarm attribute name */
u32 sbit; /* Alarm attribute status bit */ u32 sbit; /* Alarm attribute status bit */
...@@ -1029,7 +1031,8 @@ static bool pmbus_add_limit_attrs(struct i2c_client *client, ...@@ -1029,7 +1031,8 @@ static bool pmbus_add_limit_attrs(struct i2c_client *client,
if (attr->compare) { if (attr->compare) {
pmbus_add_boolean_cmp(data, name, pmbus_add_boolean_cmp(data, name,
l->alarm, index, l->alarm, index,
cbase, cindex, l->low ? cindex : cbase,
l->low ? cbase : cindex,
attr->sbase + page, l->sbit); attr->sbase + page, l->sbit);
} else { } else {
pmbus_add_boolean_reg(data, name, pmbus_add_boolean_reg(data, name,
...@@ -1366,11 +1369,13 @@ static const struct pmbus_sensor_attr power_attributes[] = { ...@@ -1366,11 +1369,13 @@ static const struct pmbus_sensor_attr power_attributes[] = {
static const struct pmbus_limit_attr temp_limit_attrs[] = { static const struct pmbus_limit_attr temp_limit_attrs[] = {
{ {
.reg = PMBUS_UT_WARN_LIMIT, .reg = PMBUS_UT_WARN_LIMIT,
.low = true,
.attr = "min", .attr = "min",
.alarm = "min_alarm", .alarm = "min_alarm",
.sbit = PB_TEMP_UT_WARNING, .sbit = PB_TEMP_UT_WARNING,
}, { }, {
.reg = PMBUS_UT_FAULT_LIMIT, .reg = PMBUS_UT_FAULT_LIMIT,
.low = true,
.attr = "lcrit", .attr = "lcrit",
.alarm = "lcrit_alarm", .alarm = "lcrit_alarm",
.sbit = PB_TEMP_UT_FAULT, .sbit = PB_TEMP_UT_FAULT,
...@@ -1399,11 +1404,13 @@ static const struct pmbus_limit_attr temp_limit_attrs[] = { ...@@ -1399,11 +1404,13 @@ static const struct pmbus_limit_attr temp_limit_attrs[] = {
static const struct pmbus_limit_attr temp_limit_attrs23[] = { static const struct pmbus_limit_attr temp_limit_attrs23[] = {
{ {
.reg = PMBUS_UT_WARN_LIMIT, .reg = PMBUS_UT_WARN_LIMIT,
.low = true,
.attr = "min", .attr = "min",
.alarm = "min_alarm", .alarm = "min_alarm",
.sbit = PB_TEMP_UT_WARNING, .sbit = PB_TEMP_UT_WARNING,
}, { }, {
.reg = PMBUS_UT_FAULT_LIMIT, .reg = PMBUS_UT_FAULT_LIMIT,
.low = true,
.attr = "lcrit", .attr = "lcrit",
.alarm = "lcrit_alarm", .alarm = "lcrit_alarm",
.sbit = PB_TEMP_UT_FAULT, .sbit = PB_TEMP_UT_FAULT,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册