sensor: adltc2990: separate function return values
This commit reworks the adltc2990_fetch_property_value function to pass its result through a variable pointer instead of direct return. This is done in part to separate the errno value being return in the default case of the switch from the result of the function, but also to make it easier the fix a Coverity issue regarding the unhandled return values of i2c reads. Signed-off-by: Benjamin Björnsson <benjamin.bjornsson@gmail.com>
This commit is contained in:
parent
ef871058aa
commit
773257dda4
|
@ -141,9 +141,10 @@ static int adltc2990_trigger_measurement(const struct device *dev)
|
|||
return i2c_reg_write_byte_dt(&cfg->bus, ADLTC2990_REG_TRIGGER, 0x1);
|
||||
}
|
||||
|
||||
static int32_t adltc2990_fetch_property_value(const struct device *dev,
|
||||
static int adltc2990_fetch_property_value(const struct device *dev,
|
||||
enum adltc2990_monitoring_type type,
|
||||
enum adltc2990_monitor_pins pin)
|
||||
enum adltc2990_monitor_pins pin,
|
||||
int32_t *output)
|
||||
{
|
||||
const struct adltc2990_config *cfg = dev->config;
|
||||
|
||||
|
@ -211,7 +212,9 @@ static int32_t adltc2990_fetch_property_value(const struct device *dev,
|
|||
|
||||
int32_t voltage_value = (value << (31 - negative_bit_index)) >> (31 - negative_bit_index);
|
||||
|
||||
return (voltage_value * conversion_factor) / sensor_val_divisor;
|
||||
*output = (voltage_value * conversion_factor) / sensor_val_divisor;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int adltc2990_init(const struct device *dev)
|
||||
|
@ -248,11 +251,16 @@ static int adltc2990_sample_fetch(const struct device *dev, enum sensor_channel
|
|||
|
||||
float voltage_divider_ratio;
|
||||
int ret;
|
||||
int32_t value;
|
||||
|
||||
switch (chan) {
|
||||
case SENSOR_CHAN_DIE_TEMP: {
|
||||
data->internal_temperature =
|
||||
adltc2990_fetch_property_value(dev, TEMPERATURE, INTERNAL_TEMPERATURE);
|
||||
ret = adltc2990_fetch_property_value(dev, TEMPERATURE, INTERNAL_TEMPERATURE,
|
||||
&value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->internal_temperature = value;
|
||||
break;
|
||||
}
|
||||
case SENSOR_CHAN_CURRENT: {
|
||||
|
@ -261,68 +269,91 @@ static int adltc2990_sample_fetch(const struct device *dev, enum sensor_channel
|
|||
return -EINVAL;
|
||||
}
|
||||
if (mode_v1_v2 == VOLTAGE_DIFFERENTIAL) {
|
||||
ret = adltc2990_fetch_property_value(dev, VOLTAGE_DIFFERENTIAL, V1, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v1_v2_values[0] =
|
||||
adltc2990_fetch_property_value(dev, VOLTAGE_DIFFERENTIAL, V1) *
|
||||
(ADLTC2990_MICROOHM_CONVERSION_FACTOR /
|
||||
value * (ADLTC2990_MICROOHM_CONVERSION_FACTOR /
|
||||
(float)cfg->pins_v1_v2.pins_current_resistor);
|
||||
}
|
||||
if (mode_v3_v4 == VOLTAGE_DIFFERENTIAL) {
|
||||
data->pins_v3_v4_values[0] =
|
||||
adltc2990_fetch_property_value(dev, VOLTAGE_DIFFERENTIAL, V3) *
|
||||
(ADLTC2990_MICROOHM_CONVERSION_FACTOR /
|
||||
ret = adltc2990_fetch_property_value(dev, VOLTAGE_DIFFERENTIAL, V3, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v3_v4_values[0] = value * (ADLTC2990_MICROOHM_CONVERSION_FACTOR /
|
||||
(float)cfg->pins_v3_v4.pins_current_resistor);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case SENSOR_CHAN_VOLTAGE: {
|
||||
data->supply_voltage =
|
||||
adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, SUPPLY_VOLTAGE) +
|
||||
2500000;
|
||||
ret = adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, SUPPLY_VOLTAGE,
|
||||
&value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->supply_voltage = value + 2500000;
|
||||
|
||||
if (mode_v1_v2 == VOLTAGE_DIFFERENTIAL) {
|
||||
data->pins_v1_v2_values[0] =
|
||||
adltc2990_fetch_property_value(dev, VOLTAGE_DIFFERENTIAL, V1);
|
||||
ret = adltc2990_fetch_property_value(dev, VOLTAGE_DIFFERENTIAL, V1, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v1_v2_values[0] = value;
|
||||
} else if (mode_v1_v2 == VOLTAGE_SINGLEENDED) {
|
||||
uint32_t v1_r1 = cfg->pins_v1_v2.voltage_divider_resistors.v1_r1_r2[0];
|
||||
|
||||
uint32_t v1_r2 = cfg->pins_v1_v2.voltage_divider_resistors.v1_r1_r2[1];
|
||||
|
||||
voltage_divider_ratio = (v1_r1 + v1_r2) / (float)v1_r2;
|
||||
data->pins_v1_v2_values[0] =
|
||||
adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, V1) *
|
||||
voltage_divider_ratio;
|
||||
ret = adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, V1, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v1_v2_values[0] = value * voltage_divider_ratio;
|
||||
|
||||
uint32_t v2_r1 = cfg->pins_v1_v2.voltage_divider_resistors.v2_r1_r2[0];
|
||||
|
||||
uint32_t v2_r2 = cfg->pins_v1_v2.voltage_divider_resistors.v2_r1_r2[1];
|
||||
|
||||
voltage_divider_ratio = (v2_r1 + v2_r2) / (float)v2_r2;
|
||||
data->pins_v1_v2_values[1] =
|
||||
adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, V2) *
|
||||
voltage_divider_ratio;
|
||||
ret = adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, V2, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v1_v2_values[1] = value * voltage_divider_ratio;
|
||||
}
|
||||
|
||||
if (mode_v3_v4 == VOLTAGE_DIFFERENTIAL) {
|
||||
data->pins_v3_v4_values[0] =
|
||||
adltc2990_fetch_property_value(dev, VOLTAGE_DIFFERENTIAL, V3);
|
||||
ret = adltc2990_fetch_property_value(dev, VOLTAGE_DIFFERENTIAL, V3, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v3_v4_values[0] = value;
|
||||
} else if (mode_v3_v4 == VOLTAGE_SINGLEENDED) {
|
||||
uint32_t v3_r1 = cfg->pins_v3_v4.voltage_divider_resistors.v3_r1_r2[0];
|
||||
|
||||
uint32_t v3_r2 = cfg->pins_v3_v4.voltage_divider_resistors.v3_r1_r2[1];
|
||||
|
||||
voltage_divider_ratio = (v3_r1 + v3_r2) / (float)v3_r2;
|
||||
data->pins_v3_v4_values[0] =
|
||||
adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, V3) *
|
||||
voltage_divider_ratio;
|
||||
ret = adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, V3, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v3_v4_values[0] = value * voltage_divider_ratio;
|
||||
|
||||
uint32_t v4_r1 = cfg->pins_v3_v4.voltage_divider_resistors.v4_r1_r2[0];
|
||||
|
||||
uint32_t v4_r2 = cfg->pins_v3_v4.voltage_divider_resistors.v4_r1_r2[1];
|
||||
|
||||
voltage_divider_ratio = (v4_r1 + v4_r2) / (float)v4_r2;
|
||||
data->pins_v3_v4_values[1] =
|
||||
adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, V4) *
|
||||
voltage_divider_ratio;
|
||||
|
||||
ret = adltc2990_fetch_property_value(dev, VOLTAGE_SINGLEENDED, V4, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v3_v4_values[1] = value * voltage_divider_ratio;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
@ -332,12 +363,18 @@ static int adltc2990_sample_fetch(const struct device *dev, enum sensor_channel
|
|||
return -EINVAL;
|
||||
}
|
||||
if (mode_v1_v2 == TEMPERATURE) {
|
||||
data->pins_v1_v2_values[0] =
|
||||
adltc2990_fetch_property_value(dev, TEMPERATURE, V1);
|
||||
ret = adltc2990_fetch_property_value(dev, TEMPERATURE, V1, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v1_v2_values[0] = value;
|
||||
}
|
||||
if (mode_v3_v4 == TEMPERATURE) {
|
||||
data->pins_v3_v4_values[0] =
|
||||
adltc2990_fetch_property_value(dev, TEMPERATURE, V3);
|
||||
ret = adltc2990_fetch_property_value(dev, TEMPERATURE, V3, &value);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
data->pins_v3_v4_values[0] = value;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue