diff mbox series

[v3,4/5] iio/adc: ingenic: add JZ4760B support to the sadc driver

Message ID 20210724190449.221894-5-cbranchereau@gmail.com
State New
Headers show
Series iio/adc: ingenic: add support for the JZ4760(B) Socs to the ingenic sadc driver | expand

Commit Message

Christophe Branchereau July 24, 2021, 7:04 p.m. UTC
The JZ4760B variant differs slightly from the JZ4760: it has a bit called VBAT_SEL in the CFG register.

In order to correctly sample the battery voltage on existing handhelds using this SOC, the bit must be cleared.

We leave the possibility to set the bit, by using the "ingenic,use-internal-divider" in the devicetree.

Signed-off-by: Christophe Branchereau <cbranchereau@gmail.com>
---
 drivers/iio/adc/ingenic-adc.c | 9 +++++++++
 1 file changed, 9 insertions(+)

Comments

Paul Cercueil July 25, 2021, 9:22 a.m. UTC | #1
Hi Christophe,

Where did the
+ { .compatible = "ingenic,jz4760b-adc", .data = &jz4760_adc_soc_data },

go?

Cheers,
-Paul


Le sam., juil. 24 2021 at 21:04:48 +0200, Christophe Branchereau 
<cbranchereau@gmail.com> a écrit :
> The JZ4760B variant differs slightly from the JZ4760: it has a bit 

> called VBAT_SEL in the CFG register.

> 

> In order to correctly sample the battery voltage on existing 

> handhelds using this SOC, the bit must be cleared.

> 

> We leave the possibility to set the bit, by using the 

> "ingenic,use-internal-divider" in the devicetree.

> 

> Signed-off-by: Christophe Branchereau <cbranchereau@gmail.com>

> ---

>  drivers/iio/adc/ingenic-adc.c | 9 +++++++++

>  1 file changed, 9 insertions(+)

> 

> diff --git a/drivers/iio/adc/ingenic-adc.c 

> b/drivers/iio/adc/ingenic-adc.c

> index 6b9af0530590..eaa8ab36183c 100644

> --- a/drivers/iio/adc/ingenic-adc.c

> +++ b/drivers/iio/adc/ingenic-adc.c

> @@ -37,6 +37,7 @@

>  #define JZ_ADC_REG_CFG_SAMPLE_NUM(n)	((n) << 10)

>  #define JZ_ADC_REG_CFG_PULL_UP(n)	((n) << 16)

>  #define JZ_ADC_REG_CFG_CMD_SEL		BIT(22)

> +#define JZ_ADC_REG_CFG_VBAT_SEL		BIT(30)

>  #define JZ_ADC_REG_CFG_TOUCH_OPS_MASK	(BIT(31) | GENMASK(23, 10))

>  #define JZ_ADC_REG_ADCLK_CLKDIV_LSB	0

>  #define JZ4725B_ADC_REG_ADCLK_CLKDIV10US_LSB	16

> @@ -879,6 +880,14 @@ static int ingenic_adc_probe(struct 

> platform_device *pdev)

>  	/* Put hardware in a known passive state. */

>  	writeb(0x00, adc->base + JZ_ADC_REG_ENABLE);

>  	writeb(0xff, adc->base + JZ_ADC_REG_CTRL);

> +

> +	/* JZ4760B specific */

> +	if (device_property_present(dev, "ingenic,use-internal-divider"))

> +		ingenic_adc_set_config(adc, JZ_ADC_REG_CFG_VBAT_SEL,

> +					    JZ_ADC_REG_CFG_VBAT_SEL);

> +	else

> +		ingenic_adc_set_config(adc, JZ_ADC_REG_CFG_VBAT_SEL, 0);

> +

>  	usleep_range(2000, 3000); /* Must wait at least 2ms. */

>  	clk_disable(adc->clk);

> 

> --

> 2.30.2

>
diff mbox series

Patch

diff --git a/drivers/iio/adc/ingenic-adc.c b/drivers/iio/adc/ingenic-adc.c
index 6b9af0530590..eaa8ab36183c 100644
--- a/drivers/iio/adc/ingenic-adc.c
+++ b/drivers/iio/adc/ingenic-adc.c
@@ -37,6 +37,7 @@ 
 #define JZ_ADC_REG_CFG_SAMPLE_NUM(n)	((n) << 10)
 #define JZ_ADC_REG_CFG_PULL_UP(n)	((n) << 16)
 #define JZ_ADC_REG_CFG_CMD_SEL		BIT(22)
+#define JZ_ADC_REG_CFG_VBAT_SEL		BIT(30)
 #define JZ_ADC_REG_CFG_TOUCH_OPS_MASK	(BIT(31) | GENMASK(23, 10))
 #define JZ_ADC_REG_ADCLK_CLKDIV_LSB	0
 #define JZ4725B_ADC_REG_ADCLK_CLKDIV10US_LSB	16
@@ -879,6 +880,14 @@  static int ingenic_adc_probe(struct platform_device *pdev)
 	/* Put hardware in a known passive state. */
 	writeb(0x00, adc->base + JZ_ADC_REG_ENABLE);
 	writeb(0xff, adc->base + JZ_ADC_REG_CTRL);
+
+	/* JZ4760B specific */
+	if (device_property_present(dev, "ingenic,use-internal-divider"))
+		ingenic_adc_set_config(adc, JZ_ADC_REG_CFG_VBAT_SEL,
+					    JZ_ADC_REG_CFG_VBAT_SEL);
+	else
+		ingenic_adc_set_config(adc, JZ_ADC_REG_CFG_VBAT_SEL, 0);
+
 	usleep_range(2000, 3000); /* Must wait at least 2ms. */
 	clk_disable(adc->clk);