提交 60a1f6e4 编写于 作者: R Ramakrishna Pallala 提交者: Anton Vorontsov

max17042_battery: Fix error handling

In max17042_get_property(...), the values returned by
max17042_read_reg are directly assigned to the variables,
even if the read results in an error.

This patch checks for the return code from max17042_read_reg and
exits the function if there is any error.
Signed-off-by: NRamakrishna Pallala <ramakrishna.pallala@intel.com>
Acked-by: NMyungJoo Ham <myungjoo.ham@samsung.com>
Signed-off-by: NAnton Vorontsov <cbouatmailru@gmail.com>
上级 86e6c6bd
...@@ -84,55 +84,79 @@ static int max17042_get_property(struct power_supply *psy, ...@@ -84,55 +84,79 @@ static int max17042_get_property(struct power_supply *psy,
{ {
struct max17042_chip *chip = container_of(psy, struct max17042_chip *chip = container_of(psy,
struct max17042_chip, battery); struct max17042_chip, battery);
int ret;
switch (psp) { switch (psp) {
case POWER_SUPPLY_PROP_PRESENT: case POWER_SUPPLY_PROP_PRESENT:
val->intval = max17042_read_reg(chip->client, ret = max17042_read_reg(chip->client, MAX17042_STATUS);
MAX17042_STATUS); if (ret < 0)
if (val->intval & MAX17042_STATUS_BattAbsent) return ret;
if (ret & MAX17042_STATUS_BattAbsent)
val->intval = 0; val->intval = 0;
else else
val->intval = 1; val->intval = 1;
break; break;
case POWER_SUPPLY_PROP_CYCLE_COUNT: case POWER_SUPPLY_PROP_CYCLE_COUNT:
val->intval = max17042_read_reg(chip->client, ret = max17042_read_reg(chip->client, MAX17042_Cycles);
MAX17042_Cycles); if (ret < 0)
return ret;
val->intval = ret;
break; break;
case POWER_SUPPLY_PROP_VOLTAGE_MAX: case POWER_SUPPLY_PROP_VOLTAGE_MAX:
val->intval = max17042_read_reg(chip->client, ret = max17042_read_reg(chip->client, MAX17042_MinMaxVolt);
MAX17042_MinMaxVolt); if (ret < 0)
val->intval >>= 8; return ret;
val->intval = ret >> 8;
val->intval *= 20000; /* Units of LSB = 20mV */ val->intval *= 20000; /* Units of LSB = 20mV */
break; break;
case POWER_SUPPLY_PROP_VOLTAGE_MIN_DESIGN: case POWER_SUPPLY_PROP_VOLTAGE_MIN_DESIGN:
val->intval = max17042_read_reg(chip->client, ret = max17042_read_reg(chip->client, MAX17042_V_empty);
MAX17042_V_empty); if (ret < 0)
val->intval >>= 7; return ret;
val->intval = ret >> 7;
val->intval *= 10000; /* Units of LSB = 10mV */ val->intval *= 10000; /* Units of LSB = 10mV */
break; break;
case POWER_SUPPLY_PROP_VOLTAGE_NOW: case POWER_SUPPLY_PROP_VOLTAGE_NOW:
val->intval = max17042_read_reg(chip->client, MAX17042_VCELL) ret = max17042_read_reg(chip->client, MAX17042_VCELL);
* 625 / 8; if (ret < 0)
return ret;
val->intval = ret * 625 / 8;
break; break;
case POWER_SUPPLY_PROP_VOLTAGE_AVG: case POWER_SUPPLY_PROP_VOLTAGE_AVG:
val->intval = max17042_read_reg(chip->client, MAX17042_AvgVCELL) ret = max17042_read_reg(chip->client, MAX17042_AvgVCELL);
* 625 / 8; if (ret < 0)
return ret;
val->intval = ret * 625 / 8;
break; break;
case POWER_SUPPLY_PROP_CAPACITY: case POWER_SUPPLY_PROP_CAPACITY:
val->intval = max17042_read_reg(chip->client, ret = max17042_read_reg(chip->client, MAX17042_SOC);
MAX17042_SOC) / 256; if (ret < 0)
return ret;
val->intval = ret >> 8;
break; break;
case POWER_SUPPLY_PROP_CHARGE_FULL: case POWER_SUPPLY_PROP_CHARGE_FULL:
val->intval = max17042_read_reg(chip->client, ret = max17042_read_reg(chip->client, MAX17042_RepSOC);
MAX17042_RepSOC); if (ret < 0)
if ((val->intval / 256) >= MAX17042_BATTERY_FULL) return ret;
if ((ret >> 8) >= MAX17042_BATTERY_FULL)
val->intval = 1; val->intval = 1;
else if (val->intval >= 0) else if (ret >= 0)
val->intval = 0; val->intval = 0;
break; break;
case POWER_SUPPLY_PROP_TEMP: case POWER_SUPPLY_PROP_TEMP:
val->intval = max17042_read_reg(chip->client, ret = max17042_read_reg(chip->client, MAX17042_TEMP);
MAX17042_TEMP); if (ret < 0)
return ret;
val->intval = ret;
/* The value is signed. */ /* The value is signed. */
if (val->intval & 0x8000) { if (val->intval & 0x8000) {
val->intval = (0x7fff & ~val->intval) + 1; val->intval = (0x7fff & ~val->intval) + 1;
...@@ -144,8 +168,11 @@ static int max17042_get_property(struct power_supply *psy, ...@@ -144,8 +168,11 @@ static int max17042_get_property(struct power_supply *psy,
break; break;
case POWER_SUPPLY_PROP_CURRENT_NOW: case POWER_SUPPLY_PROP_CURRENT_NOW:
if (chip->pdata->enable_current_sense) { if (chip->pdata->enable_current_sense) {
val->intval = max17042_read_reg(chip->client, ret = max17042_read_reg(chip->client, MAX17042_Current);
MAX17042_Current); if (ret < 0)
return ret;
val->intval = ret;
if (val->intval & 0x8000) { if (val->intval & 0x8000) {
/* Negative */ /* Negative */
val->intval = ~val->intval & 0x7fff; val->intval = ~val->intval & 0x7fff;
...@@ -159,8 +186,12 @@ static int max17042_get_property(struct power_supply *psy, ...@@ -159,8 +186,12 @@ static int max17042_get_property(struct power_supply *psy,
break; break;
case POWER_SUPPLY_PROP_CURRENT_AVG: case POWER_SUPPLY_PROP_CURRENT_AVG:
if (chip->pdata->enable_current_sense) { if (chip->pdata->enable_current_sense) {
val->intval = max17042_read_reg(chip->client, ret = max17042_read_reg(chip->client,
MAX17042_AvgCurrent); MAX17042_AvgCurrent);
if (ret < 0)
return ret;
val->intval = ret;
if (val->intval & 0x8000) { if (val->intval & 0x8000) {
/* Negative */ /* Negative */
val->intval = ~val->intval & 0x7fff; val->intval = ~val->intval & 0x7fff;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册