Commit d0716b0e authored by Jacob Pan's avatar Jacob Pan Committed by Jonathan Cameron

iio/axp288_adc: add missing channel info mask

Commit 65de7654 ("iio: iio: Fix iio_channel_read return if
channel havn't info") added a check for valid info masks.

This patch adds missing channel info masks for all ADC channels.
Otherwise, iio_read_channel_raw() would return -EINVAL when called
by consumer drivers.

Note that the change of _processed to _raw actually fixes an ABI abuse
in the original driver where it was used to avoid some special handling
rather than because it was correct.
Signed-off-by: default avatarJacob Pan <jacob.jun.pan@linux.intel.com>
Cc: <Stable@vger.kernel.org>
Signed-off-by: default avatarJonathan Cameron <jic23@kernel.org>
parent abad3983
...@@ -53,39 +53,42 @@ static const struct iio_chan_spec const axp288_adc_channels[] = { ...@@ -53,39 +53,42 @@ static const struct iio_chan_spec const axp288_adc_channels[] = {
.channel = 0, .channel = 0,
.address = AXP288_TS_ADC_H, .address = AXP288_TS_ADC_H,
.datasheet_name = "TS_PIN", .datasheet_name = "TS_PIN",
.info_mask_separate = BIT(IIO_CHAN_INFO_RAW),
}, { }, {
.indexed = 1, .indexed = 1,
.type = IIO_TEMP, .type = IIO_TEMP,
.channel = 1, .channel = 1,
.address = AXP288_PMIC_ADC_H, .address = AXP288_PMIC_ADC_H,
.datasheet_name = "PMIC_TEMP", .datasheet_name = "PMIC_TEMP",
.info_mask_separate = BIT(IIO_CHAN_INFO_RAW),
}, { }, {
.indexed = 1, .indexed = 1,
.type = IIO_TEMP, .type = IIO_TEMP,
.channel = 2, .channel = 2,
.address = AXP288_GP_ADC_H, .address = AXP288_GP_ADC_H,
.datasheet_name = "GPADC", .datasheet_name = "GPADC",
.info_mask_separate = BIT(IIO_CHAN_INFO_RAW),
}, { }, {
.indexed = 1, .indexed = 1,
.type = IIO_CURRENT, .type = IIO_CURRENT,
.channel = 3, .channel = 3,
.address = AXP20X_BATT_CHRG_I_H, .address = AXP20X_BATT_CHRG_I_H,
.datasheet_name = "BATT_CHG_I", .datasheet_name = "BATT_CHG_I",
.info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED), .info_mask_separate = BIT(IIO_CHAN_INFO_RAW),
}, { }, {
.indexed = 1, .indexed = 1,
.type = IIO_CURRENT, .type = IIO_CURRENT,
.channel = 4, .channel = 4,
.address = AXP20X_BATT_DISCHRG_I_H, .address = AXP20X_BATT_DISCHRG_I_H,
.datasheet_name = "BATT_DISCHRG_I", .datasheet_name = "BATT_DISCHRG_I",
.info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED), .info_mask_separate = BIT(IIO_CHAN_INFO_RAW),
}, { }, {
.indexed = 1, .indexed = 1,
.type = IIO_VOLTAGE, .type = IIO_VOLTAGE,
.channel = 5, .channel = 5,
.address = AXP20X_BATT_V_H, .address = AXP20X_BATT_V_H,
.datasheet_name = "BATT_V", .datasheet_name = "BATT_V",
.info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED), .info_mask_separate = BIT(IIO_CHAN_INFO_RAW),
}, },
}; };
...@@ -151,9 +154,6 @@ static int axp288_adc_read_raw(struct iio_dev *indio_dev, ...@@ -151,9 +154,6 @@ static int axp288_adc_read_raw(struct iio_dev *indio_dev,
chan->address)) chan->address))
dev_err(&indio_dev->dev, "TS pin restore\n"); dev_err(&indio_dev->dev, "TS pin restore\n");
break; break;
case IIO_CHAN_INFO_PROCESSED:
ret = axp288_adc_read_channel(val, chan->address, info->regmap);
break;
default: default:
ret = -EINVAL; ret = -EINVAL;
} }
......
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