[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20210831054207.13236-2-hui.liu@mediatek.com>
Date: Tue, 31 Aug 2021 13:42:07 +0800
From: Hui Liu <hui.liu@...iatek.com>
To: <robh+dt@...nel.org>, <jic23@...nel.org>, <lars@...afoo.de>,
<pmeerw@...erw.net>
CC: <srv_heupstream@...iatek.com>, <hui.liu@...iatek.com>,
<zhiyong.tao@...iatek.com>, <chun-hung.wu@...iatek.com>,
<yingjoe.chen@...iatek.com>, <seiya.wang@...iatek.com>,
<ben.tseng@...iatek.com>, <matthias.bgg@...il.com>,
<s.hauer@...gutronix.de>, <devicetree@...r.kernel.org>,
<linux-kernel@...r.kernel.org>,
<linux-arm-kernel@...ts.infradead.org>,
<linux-iio@...r.kernel.org>, <linux-mediatek@...ts.infradead.org>
Subject: [PATCH v2 1/1] iio: mtk-auxadc: update case IIO_CHAN_INFO_PROCESSED
Convert raw data to processed data, the processed data is input voltage.
Signed-off-by: Hui Liu <hui.liu@...iatek.com>
---
drivers/iio/adc/mt6577_auxadc.c | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/drivers/iio/adc/mt6577_auxadc.c b/drivers/iio/adc/mt6577_auxadc.c
index 79c1dd68b909..d4fccd52ef08 100644
--- a/drivers/iio/adc/mt6577_auxadc.c
+++ b/drivers/iio/adc/mt6577_auxadc.c
@@ -82,6 +82,10 @@ static const struct iio_chan_spec mt6577_auxadc_iio_channels[] = {
MT6577_AUXADC_CHANNEL(15),
};
+/* For Voltage calculation */
+#define VOLTAGE_FULL_RANGE 1500 /* VA voltage */
+#define AUXADC_PRECISE 4096 /* 12 bits */
+
static int mt_auxadc_get_cali_data(int rawdata, bool enable_cali)
{
return rawdata;
@@ -191,6 +195,10 @@ static int mt6577_auxadc_read_raw(struct iio_dev *indio_dev,
}
if (adc_dev->dev_comp->sample_data_cali)
*val = mt_auxadc_get_cali_data(*val, true);
+
+ /* Convert adc raw data to voltage: 0 - 1500 mV */
+ *val = *val * VOLTAGE_FULL_RANGE / AUXADC_PRECISE;
+
return IIO_VAL_INT;
default:
--
2.18.0
Powered by blists - more mailing lists