2021-07-21 11:03:03

by Christophe Branchereau

[permalink] [raw]
Subject: [PATCH 3/6] iio/adc: ingenic: add JZ4760 support to the sadc driver

Signed-off-by: citral23 <[email protected]>
---
drivers/iio/adc/ingenic-adc.c | 64 +++++++++++++++++++++++++++++++++++
1 file changed, 64 insertions(+)

diff --git a/drivers/iio/adc/ingenic-adc.c b/drivers/iio/adc/ingenic-adc.c
index 40f2d8c2cf72..285e7aa8e37a 100644
--- a/drivers/iio/adc/ingenic-adc.c
+++ b/drivers/iio/adc/ingenic-adc.c
@@ -71,6 +71,7 @@
#define JZ4725B_ADC_BATTERY_HIGH_VREF_BITS 10
#define JZ4740_ADC_BATTERY_HIGH_VREF (7500 * 0.986)
#define JZ4740_ADC_BATTERY_HIGH_VREF_BITS 12
+#define JZ4760_ADC_BATTERY_VREF 2500
#define JZ4770_ADC_BATTERY_VREF 1200
#define JZ4770_ADC_BATTERY_VREF_BITS 12

@@ -295,6 +296,10 @@ static const int jz4740_adc_battery_scale_avail[] = {
JZ_ADC_BATTERY_LOW_VREF, JZ_ADC_BATTERY_LOW_VREF_BITS,
};

+static const int jz4760_adc_battery_scale_avail[] = {
+ JZ4760_ADC_BATTERY_VREF, JZ4770_ADC_BATTERY_VREF_BITS,
+};
+
static const int jz4770_adc_battery_raw_avail[] = {
0, 1, (1 << JZ4770_ADC_BATTERY_VREF_BITS) - 1,
};
@@ -339,6 +344,8 @@ static int jz4725b_adc_init_clk_div(struct device *dev, struct ingenic_adc *adc)
return 0;
}

+
+
static int jz4770_adc_init_clk_div(struct device *dev, struct ingenic_adc *adc)
{
struct clk *parent_clk;
@@ -400,6 +407,47 @@ static const struct iio_chan_spec jz4740_channels[] = {
},
};

+static const struct iio_chan_spec jz4760_channels[] = {
+ {
+ .extend_name = "aux0",
+ .type = IIO_VOLTAGE,
+ .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .indexed = 1,
+ .channel = INGENIC_ADC_AUX0,
+ .scan_index = -1,
+ },
+ {
+ .extend_name = "aux",
+ .type = IIO_VOLTAGE,
+ .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .indexed = 1,
+ .channel = INGENIC_ADC_AUX,
+ .scan_index = -1,
+ },
+ {
+ .extend_name = "battery",
+ .type = IIO_VOLTAGE,
+ .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .info_mask_separate_available = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .indexed = 1,
+ .channel = INGENIC_ADC_BATTERY,
+ .scan_index = -1,
+ },
+ {
+ .extend_name = "aux2",
+ .type = IIO_VOLTAGE,
+ .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .indexed = 1,
+ .channel = INGENIC_ADC_AUX2,
+ .scan_index = -1,
+ },
+};
+
static const struct iio_chan_spec jz4770_channels[] = {
{
.type = IIO_VOLTAGE,
@@ -526,6 +574,20 @@ static const struct ingenic_adc_soc_data jz4740_adc_soc_data = {
.init_clk_div = NULL, /* no ADCLK register on JZ4740 */
};

+static const struct ingenic_adc_soc_data jz4760_adc_soc_data = {
+ .battery_high_vref = JZ4760_ADC_BATTERY_VREF,
+ .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
+ .battery_raw_avail = jz4770_adc_battery_raw_avail,
+ .battery_raw_avail_size = ARRAY_SIZE(jz4770_adc_battery_raw_avail),
+ .battery_scale_avail = jz4760_adc_battery_scale_avail,
+ .battery_scale_avail_size = ARRAY_SIZE(jz4760_adc_battery_scale_avail),
+ .battery_vref_mode = false,
+ .has_aux_md = true,
+ .channels = jz4760_channels,
+ .num_channels = ARRAY_SIZE(jz4760_channels),
+ .init_clk_div = jz4770_adc_init_clk_div,
+};
+
static const struct ingenic_adc_soc_data jz4770_adc_soc_data = {
.battery_high_vref = JZ4770_ADC_BATTERY_VREF,
.battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
@@ -621,6 +683,7 @@ static int ingenic_adc_read_raw(struct iio_dev *iio_dev,
return ingenic_adc_read_chan_info_raw(iio_dev, chan, val);
case IIO_CHAN_INFO_SCALE:
switch (chan->channel) {
+ case INGENIC_ADC_AUX0:
case INGENIC_ADC_AUX:
case INGENIC_ADC_AUX2:
*val = JZ_ADC_AUX_VREF;
@@ -832,6 +895,7 @@ static int ingenic_adc_probe(struct platform_device *pdev)
static const struct of_device_id ingenic_adc_of_match[] = {
{ .compatible = "ingenic,jz4725b-adc", .data = &jz4725b_adc_soc_data, },
{ .compatible = "ingenic,jz4740-adc", .data = &jz4740_adc_soc_data, },
+ { .compatible = "ingenic,jz4760-adc", .data = &jz4760_adc_soc_data, },
{ .compatible = "ingenic,jz4770-adc", .data = &jz4770_adc_soc_data, },
{ },
};
--
2.30.2


2021-07-21 21:08:00

by Paul Cercueil

[permalink] [raw]
Subject: Re: [PATCH 3/6] iio/adc: ingenic: add JZ4760 support to the sadc driver

Hi Christophe,

Le mer., juil. 21 2021 at 12:53:14 +0200, citral23
<[email protected]> a ?crit :
> Signed-off-by: citral23 <[email protected]>
> ---
> drivers/iio/adc/ingenic-adc.c | 64
> +++++++++++++++++++++++++++++++++++
> 1 file changed, 64 insertions(+)
>
> diff --git a/drivers/iio/adc/ingenic-adc.c
> b/drivers/iio/adc/ingenic-adc.c
> index 40f2d8c2cf72..285e7aa8e37a 100644
> --- a/drivers/iio/adc/ingenic-adc.c
> +++ b/drivers/iio/adc/ingenic-adc.c
> @@ -71,6 +71,7 @@
> #define JZ4725B_ADC_BATTERY_HIGH_VREF_BITS 10
> #define JZ4740_ADC_BATTERY_HIGH_VREF (7500 * 0.986)
> #define JZ4740_ADC_BATTERY_HIGH_VREF_BITS 12
> +#define JZ4760_ADC_BATTERY_VREF 2500
> #define JZ4770_ADC_BATTERY_VREF 1200
> #define JZ4770_ADC_BATTERY_VREF_BITS 12
>
> @@ -295,6 +296,10 @@ static const int
> jz4740_adc_battery_scale_avail[] = {
> JZ_ADC_BATTERY_LOW_VREF, JZ_ADC_BATTERY_LOW_VREF_BITS,
> };
>
> +static const int jz4760_adc_battery_scale_avail[] = {
> + JZ4760_ADC_BATTERY_VREF, JZ4770_ADC_BATTERY_VREF_BITS,
> +};
> +
> static const int jz4770_adc_battery_raw_avail[] = {
> 0, 1, (1 << JZ4770_ADC_BATTERY_VREF_BITS) - 1,
> };
> @@ -339,6 +344,8 @@ static int jz4725b_adc_init_clk_div(struct device
> *dev, struct ingenic_adc *adc)
> return 0;
> }
>
> +
> +

Unrelated cosmetic change - remove it.

> static int jz4770_adc_init_clk_div(struct device *dev, struct
> ingenic_adc *adc)
> {
> struct clk *parent_clk;
> @@ -400,6 +407,47 @@ static const struct iio_chan_spec
> jz4740_channels[] = {
> },
> };
>
> +static const struct iio_chan_spec jz4760_channels[] = {
> + {
> + .extend_name = "aux0",
> + .type = IIO_VOLTAGE,
> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> + BIT(IIO_CHAN_INFO_SCALE),
> + .indexed = 1,
> + .channel = INGENIC_ADC_AUX0,
> + .scan_index = -1,
> + },
> + {
> + .extend_name = "aux",
> + .type = IIO_VOLTAGE,
> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> + BIT(IIO_CHAN_INFO_SCALE),
> + .indexed = 1,
> + .channel = INGENIC_ADC_AUX,
> + .scan_index = -1,
> + },

A couple of things. First, ".extend_name" is deprecated now... But
since the driver used it before, I suppose it doesn't make sense to use
labels just for this SoC (as we can't remove .extend_name for other
SoCs because of ABI). So I suppose it works here, but maybe Jonathan
disagrees.

Also, you should probably use "aux1" as the channel's name instead of
"aux", independently of the macro name you used in the .channel field.

> + {
> + .extend_name = "battery",
> + .type = IIO_VOLTAGE,
> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> + BIT(IIO_CHAN_INFO_SCALE),
> + .info_mask_separate_available = BIT(IIO_CHAN_INFO_RAW) |
> + BIT(IIO_CHAN_INFO_SCALE),
> + .indexed = 1,
> + .channel = INGENIC_ADC_BATTERY,
> + .scan_index = -1,
> + },

Swap the battery channel at the end, no? First the three AUX then the
battery channel?

The rest looks pretty good to me.

Cheers,
-Paul

> + {
> + .extend_name = "aux2",
> + .type = IIO_VOLTAGE,
> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> + BIT(IIO_CHAN_INFO_SCALE),
> + .indexed = 1,
> + .channel = INGENIC_ADC_AUX2,
> + .scan_index = -1,
> + },
> +};
> +
> static const struct iio_chan_spec jz4770_channels[] = {
> {
> .type = IIO_VOLTAGE,
> @@ -526,6 +574,20 @@ static const struct ingenic_adc_soc_data
> jz4740_adc_soc_data = {
> .init_clk_div = NULL, /* no ADCLK register on JZ4740 */
> };
>
> +static const struct ingenic_adc_soc_data jz4760_adc_soc_data = {
> + .battery_high_vref = JZ4760_ADC_BATTERY_VREF,
> + .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
> + .battery_raw_avail = jz4770_adc_battery_raw_avail,
> + .battery_raw_avail_size = ARRAY_SIZE(jz4770_adc_battery_raw_avail),
> + .battery_scale_avail = jz4760_adc_battery_scale_avail,
> + .battery_scale_avail_size =
> ARRAY_SIZE(jz4760_adc_battery_scale_avail),
> + .battery_vref_mode = false,
> + .has_aux_md = true,
> + .channels = jz4760_channels,
> + .num_channels = ARRAY_SIZE(jz4760_channels),
> + .init_clk_div = jz4770_adc_init_clk_div,
> +};
> +
> static const struct ingenic_adc_soc_data jz4770_adc_soc_data = {
> .battery_high_vref = JZ4770_ADC_BATTERY_VREF,
> .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
> @@ -621,6 +683,7 @@ static int ingenic_adc_read_raw(struct iio_dev
> *iio_dev,
> return ingenic_adc_read_chan_info_raw(iio_dev, chan, val);
> case IIO_CHAN_INFO_SCALE:
> switch (chan->channel) {
> + case INGENIC_ADC_AUX0:
> case INGENIC_ADC_AUX:
> case INGENIC_ADC_AUX2:
> *val = JZ_ADC_AUX_VREF;
> @@ -832,6 +895,7 @@ static int ingenic_adc_probe(struct
> platform_device *pdev)
> static const struct of_device_id ingenic_adc_of_match[] = {
> { .compatible = "ingenic,jz4725b-adc", .data =
> &jz4725b_adc_soc_data, },
> { .compatible = "ingenic,jz4740-adc", .data = &jz4740_adc_soc_data,
> },
> + { .compatible = "ingenic,jz4760-adc", .data = &jz4760_adc_soc_data,
> },
> { .compatible = "ingenic,jz4770-adc", .data = &jz4770_adc_soc_data,
> },
> { },
> };
> --
> 2.30.2
>


2021-07-22 05:14:24

by Christophe Branchereau

[permalink] [raw]
Subject: Re: [PATCH 3/6] iio/adc: ingenic: add JZ4760 support to the sadc driver

Hello Paul, thank you for all the feedback, duly noted I will V2,
there is just one I disagree with:

On Wed, Jul 21, 2021 at 8:15 PM Paul Cercueil <[email protected]> wrote:
>
> Hi Christophe,
>
> Le mer., juil. 21 2021 at 12:53:14 +0200, citral23
> <[email protected]> a écrit :
> > Signed-off-by: citral23 <[email protected]>
> > ---
> > drivers/iio/adc/ingenic-adc.c | 64
> > +++++++++++++++++++++++++++++++++++
> > 1 file changed, 64 insertions(+)
> >
> > diff --git a/drivers/iio/adc/ingenic-adc.c
> > b/drivers/iio/adc/ingenic-adc.c
> > index 40f2d8c2cf72..285e7aa8e37a 100644
> > --- a/drivers/iio/adc/ingenic-adc.c
> > +++ b/drivers/iio/adc/ingenic-adc.c
> > @@ -71,6 +71,7 @@
> > #define JZ4725B_ADC_BATTERY_HIGH_VREF_BITS 10
> > #define JZ4740_ADC_BATTERY_HIGH_VREF (7500 * 0.986)
> > #define JZ4740_ADC_BATTERY_HIGH_VREF_BITS 12
> > +#define JZ4760_ADC_BATTERY_VREF 2500
> > #define JZ4770_ADC_BATTERY_VREF 1200
> > #define JZ4770_ADC_BATTERY_VREF_BITS 12
> >
> > @@ -295,6 +296,10 @@ static const int
> > jz4740_adc_battery_scale_avail[] = {
> > JZ_ADC_BATTERY_LOW_VREF, JZ_ADC_BATTERY_LOW_VREF_BITS,
> > };
> >
> > +static const int jz4760_adc_battery_scale_avail[] = {
> > + JZ4760_ADC_BATTERY_VREF, JZ4770_ADC_BATTERY_VREF_BITS,
> > +};
> > +
> > static const int jz4770_adc_battery_raw_avail[] = {
> > 0, 1, (1 << JZ4770_ADC_BATTERY_VREF_BITS) - 1,
> > };
> > @@ -339,6 +344,8 @@ static int jz4725b_adc_init_clk_div(struct device
> > *dev, struct ingenic_adc *adc)
> > return 0;
> > }
> >
> > +
> > +
>
> Unrelated cosmetic change - remove it.

This is not cosmetic, but to add a VREF of 2.5V for the jz4760, as per specs

>
> > static int jz4770_adc_init_clk_div(struct device *dev, struct
> > ingenic_adc *adc)
> > {
> > struct clk *parent_clk;
> > @@ -400,6 +407,47 @@ static const struct iio_chan_spec
> > jz4740_channels[] = {
> > },
> > };
> >
> > +static const struct iio_chan_spec jz4760_channels[] = {
> > + {
> > + .extend_name = "aux0",
> > + .type = IIO_VOLTAGE,
> > + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .indexed = 1,
> > + .channel = INGENIC_ADC_AUX0,
> > + .scan_index = -1,
> > + },
> > + {
> > + .extend_name = "aux",
> > + .type = IIO_VOLTAGE,
> > + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .indexed = 1,
> > + .channel = INGENIC_ADC_AUX,
> > + .scan_index = -1,
> > + },
>
> A couple of things. First, ".extend_name" is deprecated now... But
> since the driver used it before, I suppose it doesn't make sense to use
> labels just for this SoC (as we can't remove .extend_name for other
> SoCs because of ABI). So I suppose it works here, but maybe Jonathan
> disagrees.
>
> Also, you should probably use "aux1" as the channel's name instead of
> "aux", independently of the macro name you used in the .channel field.
>
> > + {
> > + .extend_name = "battery",
> > + .type = IIO_VOLTAGE,
> > + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .info_mask_separate_available = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .indexed = 1,
> > + .channel = INGENIC_ADC_BATTERY,
> > + .scan_index = -1,
> > + },
>
> Swap the battery channel at the end, no? First the three AUX then the
> battery channel?
>
> The rest looks pretty good to me.
>
> Cheers,
> -Paul
>
> > + {
> > + .extend_name = "aux2",
> > + .type = IIO_VOLTAGE,
> > + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .indexed = 1,
> > + .channel = INGENIC_ADC_AUX2,
> > + .scan_index = -1,
> > + },
> > +};
> > +
> > static const struct iio_chan_spec jz4770_channels[] = {
> > {
> > .type = IIO_VOLTAGE,
> > @@ -526,6 +574,20 @@ static const struct ingenic_adc_soc_data
> > jz4740_adc_soc_data = {
> > .init_clk_div = NULL, /* no ADCLK register on JZ4740 */
> > };
> >
> > +static const struct ingenic_adc_soc_data jz4760_adc_soc_data = {
> > + .battery_high_vref = JZ4760_ADC_BATTERY_VREF,
> > + .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
> > + .battery_raw_avail = jz4770_adc_battery_raw_avail,
> > + .battery_raw_avail_size = ARRAY_SIZE(jz4770_adc_battery_raw_avail),
> > + .battery_scale_avail = jz4760_adc_battery_scale_avail,
> > + .battery_scale_avail_size =
> > ARRAY_SIZE(jz4760_adc_battery_scale_avail),
> > + .battery_vref_mode = false,
> > + .has_aux_md = true,
> > + .channels = jz4760_channels,
> > + .num_channels = ARRAY_SIZE(jz4760_channels),
> > + .init_clk_div = jz4770_adc_init_clk_div,
> > +};
> > +
> > static const struct ingenic_adc_soc_data jz4770_adc_soc_data = {
> > .battery_high_vref = JZ4770_ADC_BATTERY_VREF,
> > .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
> > @@ -621,6 +683,7 @@ static int ingenic_adc_read_raw(struct iio_dev
> > *iio_dev,
> > return ingenic_adc_read_chan_info_raw(iio_dev, chan, val);
> > case IIO_CHAN_INFO_SCALE:
> > switch (chan->channel) {
> > + case INGENIC_ADC_AUX0:
> > case INGENIC_ADC_AUX:
> > case INGENIC_ADC_AUX2:
> > *val = JZ_ADC_AUX_VREF;
> > @@ -832,6 +895,7 @@ static int ingenic_adc_probe(struct
> > platform_device *pdev)
> > static const struct of_device_id ingenic_adc_of_match[] = {
> > { .compatible = "ingenic,jz4725b-adc", .data =
> > &jz4725b_adc_soc_data, },
> > { .compatible = "ingenic,jz4740-adc", .data = &jz4740_adc_soc_data,
> > },
> > + { .compatible = "ingenic,jz4760-adc", .data = &jz4760_adc_soc_data,
> > },
> > { .compatible = "ingenic,jz4770-adc", .data = &jz4770_adc_soc_data,
> > },
> > { },
> > };
> > --
> > 2.30.2
> >
>
>
KR
CB

2021-07-22 05:24:56

by Guenter Roeck

[permalink] [raw]
Subject: Re: [PATCH 3/6] iio/adc: ingenic: add JZ4760 support to the sadc driver

On 7/21/21 10:09 PM, Christophe Branchereau wrote:
> Hello Paul, thank you for all the feedback, duly noted I will V2,
> there is just one I disagree with:
>
> On Wed, Jul 21, 2021 at 8:15 PM Paul Cercueil <[email protected]> wrote:
>>
>> Hi Christophe,
>>
>> Le mer., juil. 21 2021 at 12:53:14 +0200, citral23
>> <[email protected]> a écrit :
>>> Signed-off-by: citral23 <[email protected]>
>>> ---
>>> drivers/iio/adc/ingenic-adc.c | 64
>>> +++++++++++++++++++++++++++++++++++
>>> 1 file changed, 64 insertions(+)
>>>
>>> diff --git a/drivers/iio/adc/ingenic-adc.c
>>> b/drivers/iio/adc/ingenic-adc.c
>>> index 40f2d8c2cf72..285e7aa8e37a 100644
>>> --- a/drivers/iio/adc/ingenic-adc.c
>>> +++ b/drivers/iio/adc/ingenic-adc.c
>>> @@ -71,6 +71,7 @@
>>> #define JZ4725B_ADC_BATTERY_HIGH_VREF_BITS 10
>>> #define JZ4740_ADC_BATTERY_HIGH_VREF (7500 * 0.986)
>>> #define JZ4740_ADC_BATTERY_HIGH_VREF_BITS 12
>>> +#define JZ4760_ADC_BATTERY_VREF 2500
>>> #define JZ4770_ADC_BATTERY_VREF 1200
>>> #define JZ4770_ADC_BATTERY_VREF_BITS 12
>>>
>>> @@ -295,6 +296,10 @@ static const int
>>> jz4740_adc_battery_scale_avail[] = {
>>> JZ_ADC_BATTERY_LOW_VREF, JZ_ADC_BATTERY_LOW_VREF_BITS,
>>> };
>>>
>>> +static const int jz4760_adc_battery_scale_avail[] = {
>>> + JZ4760_ADC_BATTERY_VREF, JZ4770_ADC_BATTERY_VREF_BITS,
>>> +};
>>> +
>>> static const int jz4770_adc_battery_raw_avail[] = {
>>> 0, 1, (1 << JZ4770_ADC_BATTERY_VREF_BITS) - 1,
>>> };
>>> @@ -339,6 +344,8 @@ static int jz4725b_adc_init_clk_div(struct device
>>> *dev, struct ingenic_adc *adc)
>>> return 0;
>>> }
>>>
>>> +
>>> +
>>
>> Unrelated cosmetic change - remove it.
>
> This is not cosmetic, but to add a VREF of 2.5V for the jz4760, as per specs
>

Two added empty lines are not cosmetic ?

Guenter

>>
>>> static int jz4770_adc_init_clk_div(struct device *dev, struct
>>> ingenic_adc *adc)
>>> {
>>> struct clk *parent_clk;
>>> @@ -400,6 +407,47 @@ static const struct iio_chan_spec
>>> jz4740_channels[] = {
>>> },
>>> };
>>>
>>> +static const struct iio_chan_spec jz4760_channels[] = {
>>> + {
>>> + .extend_name = "aux0",
>>> + .type = IIO_VOLTAGE,
>>> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
>>> + BIT(IIO_CHAN_INFO_SCALE),
>>> + .indexed = 1,
>>> + .channel = INGENIC_ADC_AUX0,
>>> + .scan_index = -1,
>>> + },
>>> + {
>>> + .extend_name = "aux",
>>> + .type = IIO_VOLTAGE,
>>> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
>>> + BIT(IIO_CHAN_INFO_SCALE),
>>> + .indexed = 1,
>>> + .channel = INGENIC_ADC_AUX,
>>> + .scan_index = -1,
>>> + },
>>
>> A couple of things. First, ".extend_name" is deprecated now... But
>> since the driver used it before, I suppose it doesn't make sense to use
>> labels just for this SoC (as we can't remove .extend_name for other
>> SoCs because of ABI). So I suppose it works here, but maybe Jonathan
>> disagrees.
>>
>> Also, you should probably use "aux1" as the channel's name instead of
>> "aux", independently of the macro name you used in the .channel field.
>>
>>> + {
>>> + .extend_name = "battery",
>>> + .type = IIO_VOLTAGE,
>>> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
>>> + BIT(IIO_CHAN_INFO_SCALE),
>>> + .info_mask_separate_available = BIT(IIO_CHAN_INFO_RAW) |
>>> + BIT(IIO_CHAN_INFO_SCALE),
>>> + .indexed = 1,
>>> + .channel = INGENIC_ADC_BATTERY,
>>> + .scan_index = -1,
>>> + },
>>
>> Swap the battery channel at the end, no? First the three AUX then the
>> battery channel?
>>
>> The rest looks pretty good to me.
>>
>> Cheers,
>> -Paul
>>
>>> + {
>>> + .extend_name = "aux2",
>>> + .type = IIO_VOLTAGE,
>>> + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
>>> + BIT(IIO_CHAN_INFO_SCALE),
>>> + .indexed = 1,
>>> + .channel = INGENIC_ADC_AUX2,
>>> + .scan_index = -1,
>>> + },
>>> +};
>>> +
>>> static const struct iio_chan_spec jz4770_channels[] = {
>>> {
>>> .type = IIO_VOLTAGE,
>>> @@ -526,6 +574,20 @@ static const struct ingenic_adc_soc_data
>>> jz4740_adc_soc_data = {
>>> .init_clk_div = NULL, /* no ADCLK register on JZ4740 */
>>> };
>>>
>>> +static const struct ingenic_adc_soc_data jz4760_adc_soc_data = {
>>> + .battery_high_vref = JZ4760_ADC_BATTERY_VREF,
>>> + .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
>>> + .battery_raw_avail = jz4770_adc_battery_raw_avail,
>>> + .battery_raw_avail_size = ARRAY_SIZE(jz4770_adc_battery_raw_avail),
>>> + .battery_scale_avail = jz4760_adc_battery_scale_avail,
>>> + .battery_scale_avail_size =
>>> ARRAY_SIZE(jz4760_adc_battery_scale_avail),
>>> + .battery_vref_mode = false,
>>> + .has_aux_md = true,
>>> + .channels = jz4760_channels,
>>> + .num_channels = ARRAY_SIZE(jz4760_channels),
>>> + .init_clk_div = jz4770_adc_init_clk_div,
>>> +};
>>> +
>>> static const struct ingenic_adc_soc_data jz4770_adc_soc_data = {
>>> .battery_high_vref = JZ4770_ADC_BATTERY_VREF,
>>> .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
>>> @@ -621,6 +683,7 @@ static int ingenic_adc_read_raw(struct iio_dev
>>> *iio_dev,
>>> return ingenic_adc_read_chan_info_raw(iio_dev, chan, val);
>>> case IIO_CHAN_INFO_SCALE:
>>> switch (chan->channel) {
>>> + case INGENIC_ADC_AUX0:
>>> case INGENIC_ADC_AUX:
>>> case INGENIC_ADC_AUX2:
>>> *val = JZ_ADC_AUX_VREF;
>>> @@ -832,6 +895,7 @@ static int ingenic_adc_probe(struct
>>> platform_device *pdev)
>>> static const struct of_device_id ingenic_adc_of_match[] = {
>>> { .compatible = "ingenic,jz4725b-adc", .data =
>>> &jz4725b_adc_soc_data, },
>>> { .compatible = "ingenic,jz4740-adc", .data = &jz4740_adc_soc_data,
>>> },
>>> + { .compatible = "ingenic,jz4760-adc", .data = &jz4760_adc_soc_data,
>>> },
>>> { .compatible = "ingenic,jz4770-adc", .data = &jz4770_adc_soc_data,
>>> },
>>> { },
>>> };
>>> --
>>> 2.30.2
>>>
>>
>>
> KR
> CB
>

2021-07-23 09:00:59

by Christophe Branchereau

[permalink] [raw]
Subject: [PATCH V2 0/5] iio/adc: ingenic: add support for the JZ4760(B) Socs to the ingenic sadc driver

This is a set of patches to add support to the JZ4760(B) socs found in numerous gaming handhelds and some
mp3 players.

Christophe Branchereau (5):
iio/adc: ingenic: rename has_aux2 to has_aux_md
dt-bindings: iio/adc: add an INGENIC_ADC_AUX0 entry
iio/adc: ingenic: add JZ4760 support to the sadc driver
iio/adc: ingenic: add JZ4760B support to the sadc driver
dt-bindings: iio/adc: ingenic: add the JZ4760(B) socs to the sadc
Documentation

2021-07-23 09:01:33

by Christophe Branchereau

[permalink] [raw]
Subject: [PATCH V2 5/5] dt-bindings: iio/adc: ingenic: add the JZ4760(B) socs to the sadc Documentation

The jz4760b variant differs slightly from the jz4760, add a property to
let users sample the internal divider if needed and document it.

Signed-off-by: Christophe Branchereau <[email protected]>
---
.../devicetree/bindings/iio/adc/ingenic,adc.yaml | 9 +++++++++
1 file changed, 9 insertions(+)

diff --git a/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml b/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
index 433a3fb55a2e..0dc42959a64f 100644
--- a/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
+++ b/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
@@ -23,6 +23,8 @@ properties:
enum:
- ingenic,jz4725b-adc
- ingenic,jz4740-adc
+ - ingenic,jz4760-adc
+ - ingenic,jz4760b-adc
- ingenic,jz4770-adc

'#io-channel-cells':
@@ -43,6 +45,13 @@ properties:
interrupts:
maxItems: 1

+ ingenic,use-internal-divider:
+ description:
+ This property can be used to set VBAT_SEL in the JZ4760B CFG register
+ to sample the battery voltage from the internal divider. If absent, it
+ will sample the external divider.
+ type: boolean
+
required:
- compatible
- '#io-channel-cells'
--
2.30.2

2021-07-23 09:01:35

by Christophe Branchereau

[permalink] [raw]
Subject: [PATCH V2 2/5] dt-bindings: iio/adc: add an INGENIC_ADC_AUX0 entry

The JZ4760(B) socs have 3 AUX inputs, add an entry to prepare including
the one named AUX in the sadc driver.

Leaving the rest untouched as it's ABI.

Signed-off-by: Christophe Branchereau <[email protected]>
---
include/dt-bindings/iio/adc/ingenic,adc.h | 1 +
1 file changed, 1 insertion(+)

diff --git a/include/dt-bindings/iio/adc/ingenic,adc.h b/include/dt-bindings/iio/adc/ingenic,adc.h
index 4627a00e369e..a6ccc031635b 100644
--- a/include/dt-bindings/iio/adc/ingenic,adc.h
+++ b/include/dt-bindings/iio/adc/ingenic,adc.h
@@ -13,5 +13,6 @@
#define INGENIC_ADC_TOUCH_YN 6
#define INGENIC_ADC_TOUCH_XD 7
#define INGENIC_ADC_TOUCH_YD 8
+#define INGENIC_ADC_AUX0 9

#endif
--
2.30.2

2021-07-23 09:01:52

by Christophe Branchereau

[permalink] [raw]
Subject: [PATCH V2 3/5] iio/adc: ingenic: add JZ4760 support to the sadc driver

The jz4760 sadc is very similar to the jz4770 one, but has a VREF of 2.5V
and 3 aux channels.

modify ingenic_adc_read_chan_info_raw() needs a change to account for it.

Signed-off-by: Christophe Branchereau <[email protected]>
---
drivers/iio/adc/ingenic-adc.c | 82 +++++++++++++++++++++++++++++++++--
1 file changed, 78 insertions(+), 4 deletions(-)

diff --git a/drivers/iio/adc/ingenic-adc.c b/drivers/iio/adc/ingenic-adc.c
index 40f2d8c2cf72..6b9af0530590 100644
--- a/drivers/iio/adc/ingenic-adc.c
+++ b/drivers/iio/adc/ingenic-adc.c
@@ -71,6 +71,7 @@
#define JZ4725B_ADC_BATTERY_HIGH_VREF_BITS 10
#define JZ4740_ADC_BATTERY_HIGH_VREF (7500 * 0.986)
#define JZ4740_ADC_BATTERY_HIGH_VREF_BITS 12
+#define JZ4760_ADC_BATTERY_VREF 2500
#define JZ4770_ADC_BATTERY_VREF 1200
#define JZ4770_ADC_BATTERY_VREF_BITS 12

@@ -295,6 +296,10 @@ static const int jz4740_adc_battery_scale_avail[] = {
JZ_ADC_BATTERY_LOW_VREF, JZ_ADC_BATTERY_LOW_VREF_BITS,
};

+static const int jz4760_adc_battery_scale_avail[] = {
+ JZ4760_ADC_BATTERY_VREF, JZ4770_ADC_BATTERY_VREF_BITS,
+};
+
static const int jz4770_adc_battery_raw_avail[] = {
0, 1, (1 << JZ4770_ADC_BATTERY_VREF_BITS) - 1,
};
@@ -400,6 +405,47 @@ static const struct iio_chan_spec jz4740_channels[] = {
},
};

+static const struct iio_chan_spec jz4760_channels[] = {
+ {
+ .extend_name = "aux",
+ .type = IIO_VOLTAGE,
+ .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .indexed = 1,
+ .channel = INGENIC_ADC_AUX0,
+ .scan_index = -1,
+ },
+ {
+ .extend_name = "aux1",
+ .type = IIO_VOLTAGE,
+ .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .indexed = 1,
+ .channel = INGENIC_ADC_AUX,
+ .scan_index = -1,
+ },
+ {
+ .extend_name = "aux2",
+ .type = IIO_VOLTAGE,
+ .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .indexed = 1,
+ .channel = INGENIC_ADC_AUX2,
+ .scan_index = -1,
+ },
+ {
+ .extend_name = "battery",
+ .type = IIO_VOLTAGE,
+ .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .info_mask_separate_available = BIT(IIO_CHAN_INFO_RAW) |
+ BIT(IIO_CHAN_INFO_SCALE),
+ .indexed = 1,
+ .channel = INGENIC_ADC_BATTERY,
+ .scan_index = -1,
+ },
+};
+
static const struct iio_chan_spec jz4770_channels[] = {
{
.type = IIO_VOLTAGE,
@@ -526,6 +572,20 @@ static const struct ingenic_adc_soc_data jz4740_adc_soc_data = {
.init_clk_div = NULL, /* no ADCLK register on JZ4740 */
};

+static const struct ingenic_adc_soc_data jz4760_adc_soc_data = {
+ .battery_high_vref = JZ4760_ADC_BATTERY_VREF,
+ .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
+ .battery_raw_avail = jz4770_adc_battery_raw_avail,
+ .battery_raw_avail_size = ARRAY_SIZE(jz4770_adc_battery_raw_avail),
+ .battery_scale_avail = jz4760_adc_battery_scale_avail,
+ .battery_scale_avail_size = ARRAY_SIZE(jz4760_adc_battery_scale_avail),
+ .battery_vref_mode = false,
+ .has_aux_md = true,
+ .channels = jz4760_channels,
+ .num_channels = ARRAY_SIZE(jz4760_channels),
+ .init_clk_div = jz4770_adc_init_clk_div,
+};
+
static const struct ingenic_adc_soc_data jz4770_adc_soc_data = {
.battery_high_vref = JZ4770_ADC_BATTERY_VREF,
.battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
@@ -569,7 +629,7 @@ static int ingenic_adc_read_chan_info_raw(struct iio_dev *iio_dev,
struct iio_chan_spec const *chan,
int *val)
{
- int bit, ret, engine = (chan->channel == INGENIC_ADC_BATTERY);
+ int cmd, ret, engine = (chan->channel == INGENIC_ADC_BATTERY);
struct ingenic_adc *adc = iio_priv(iio_dev);

ret = clk_enable(adc->clk);
@@ -579,11 +639,22 @@ static int ingenic_adc_read_chan_info_raw(struct iio_dev *iio_dev,
return ret;
}

- /* We cannot sample AUX/AUX2 in parallel. */
+ /* We cannot sample the aux channels in parallel. */
mutex_lock(&adc->aux_lock);
if (adc->soc_data->has_aux_md && engine == 0) {
- bit = BIT(chan->channel == INGENIC_ADC_AUX2);
- ingenic_adc_set_config(adc, JZ_ADC_REG_CFG_AUX_MD, bit);
+ switch (chan->channel) {
+ case INGENIC_ADC_AUX0:
+ cmd = 0;
+ break;
+ case INGENIC_ADC_AUX:
+ cmd = 1;
+ break;
+ case INGENIC_ADC_AUX2:
+ cmd = 2;
+ break;
+ }
+
+ ingenic_adc_set_config(adc, JZ_ADC_REG_CFG_AUX_MD, cmd);
}

ret = ingenic_adc_capture(adc, engine);
@@ -591,6 +662,7 @@ static int ingenic_adc_read_chan_info_raw(struct iio_dev *iio_dev,
goto out;

switch (chan->channel) {
+ case INGENIC_ADC_AUX0:
case INGENIC_ADC_AUX:
case INGENIC_ADC_AUX2:
*val = readw(adc->base + JZ_ADC_REG_ADSDAT);
@@ -621,6 +693,7 @@ static int ingenic_adc_read_raw(struct iio_dev *iio_dev,
return ingenic_adc_read_chan_info_raw(iio_dev, chan, val);
case IIO_CHAN_INFO_SCALE:
switch (chan->channel) {
+ case INGENIC_ADC_AUX0:
case INGENIC_ADC_AUX:
case INGENIC_ADC_AUX2:
*val = JZ_ADC_AUX_VREF;
@@ -832,6 +905,7 @@ static int ingenic_adc_probe(struct platform_device *pdev)
static const struct of_device_id ingenic_adc_of_match[] = {
{ .compatible = "ingenic,jz4725b-adc", .data = &jz4725b_adc_soc_data, },
{ .compatible = "ingenic,jz4740-adc", .data = &jz4740_adc_soc_data, },
+ { .compatible = "ingenic,jz4760-adc", .data = &jz4760_adc_soc_data, },
{ .compatible = "ingenic,jz4770-adc", .data = &jz4770_adc_soc_data, },
{ },
};
--
2.30.2

2021-07-23 09:02:03

by Christophe Branchereau

[permalink] [raw]
Subject: [PATCH V2 1/5] iio/adc: ingenic: rename has_aux2 to has_aux_md

The jz4760(b) socs have 3 aux channels.

The purpose of has_aux2 is to set the MD bits used to select
the AUX channel to be sampled, not to describe the hardware.

Rename it to a more appropriate name.

Signed-off-by: Christophe Branchereau <[email protected]>
---
drivers/iio/adc/ingenic-adc.c | 10 +++++-----
1 file changed, 5 insertions(+), 5 deletions(-)

diff --git a/drivers/iio/adc/ingenic-adc.c b/drivers/iio/adc/ingenic-adc.c
index 34c03a264f74..40f2d8c2cf72 100644
--- a/drivers/iio/adc/ingenic-adc.c
+++ b/drivers/iio/adc/ingenic-adc.c
@@ -92,7 +92,7 @@ struct ingenic_adc_soc_data {
const int *battery_scale_avail;
size_t battery_scale_avail_size;
unsigned int battery_vref_mode: 1;
- unsigned int has_aux2: 1;
+ unsigned int has_aux_md: 1;
const struct iio_chan_spec *channels;
unsigned int num_channels;
int (*init_clk_div)(struct device *dev, struct ingenic_adc *adc);
@@ -506,7 +506,7 @@ static const struct ingenic_adc_soc_data jz4725b_adc_soc_data = {
.battery_scale_avail = jz4725b_adc_battery_scale_avail,
.battery_scale_avail_size = ARRAY_SIZE(jz4725b_adc_battery_scale_avail),
.battery_vref_mode = true,
- .has_aux2 = false,
+ .has_aux_md = false,
.channels = jz4740_channels,
.num_channels = ARRAY_SIZE(jz4740_channels),
.init_clk_div = jz4725b_adc_init_clk_div,
@@ -520,7 +520,7 @@ static const struct ingenic_adc_soc_data jz4740_adc_soc_data = {
.battery_scale_avail = jz4740_adc_battery_scale_avail,
.battery_scale_avail_size = ARRAY_SIZE(jz4740_adc_battery_scale_avail),
.battery_vref_mode = true,
- .has_aux2 = false,
+ .has_aux_md = false,
.channels = jz4740_channels,
.num_channels = ARRAY_SIZE(jz4740_channels),
.init_clk_div = NULL, /* no ADCLK register on JZ4740 */
@@ -534,7 +534,7 @@ static const struct ingenic_adc_soc_data jz4770_adc_soc_data = {
.battery_scale_avail = jz4770_adc_battery_scale_avail,
.battery_scale_avail_size = ARRAY_SIZE(jz4770_adc_battery_scale_avail),
.battery_vref_mode = false,
- .has_aux2 = true,
+ .has_aux_md = true,
.channels = jz4770_channels,
.num_channels = ARRAY_SIZE(jz4770_channels),
.init_clk_div = jz4770_adc_init_clk_div,
@@ -581,7 +581,7 @@ static int ingenic_adc_read_chan_info_raw(struct iio_dev *iio_dev,

/* We cannot sample AUX/AUX2 in parallel. */
mutex_lock(&adc->aux_lock);
- if (adc->soc_data->has_aux2 && engine == 0) {
+ if (adc->soc_data->has_aux_md && engine == 0) {
bit = BIT(chan->channel == INGENIC_ADC_AUX2);
ingenic_adc_set_config(adc, JZ_ADC_REG_CFG_AUX_MD, bit);
}
--
2.30.2

2021-07-23 09:04:08

by Christophe Branchereau

[permalink] [raw]
Subject: [PATCH V2 4/5] iio/adc: ingenic: add JZ4760B support to the sadc driver

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 adding the
"ingenic,use-internal-divider" property to a devicetree.

Signed-off-by: Christophe Branchereau <[email protected]>
---
drivers/iio/adc/ingenic-adc.c | 8 ++++++++
1 file changed, 8 insertions(+)

diff --git a/drivers/iio/adc/ingenic-adc.c b/drivers/iio/adc/ingenic-adc.c
index 6b9af0530590..09937c05d2af 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,12 @@ 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);
+
+ if (device_property_present(dev, "ingenic,use-internal-divider")) /* JZ4760B specific */
+ 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);

@@ -906,6 +913,7 @@ static const struct of_device_id ingenic_adc_of_match[] = {
{ .compatible = "ingenic,jz4725b-adc", .data = &jz4725b_adc_soc_data, },
{ .compatible = "ingenic,jz4740-adc", .data = &jz4740_adc_soc_data, },
{ .compatible = "ingenic,jz4760-adc", .data = &jz4760_adc_soc_data, },
+ { .compatible = "ingenic,jz4760b-adc", .data = &jz4760_adc_soc_data, },
{ .compatible = "ingenic,jz4770-adc", .data = &jz4770_adc_soc_data, },
{ },
};
--
2.30.2

2021-07-23 16:06:54

by Jonathan Cameron

[permalink] [raw]
Subject: Re: [PATCH V2 0/5] iio/adc: ingenic: add support for the JZ4760(B) Socs to the ingenic sadc driver

On Fri, 23 Jul 2021 10:58:08 +0200
Christophe Branchereau <[email protected]> wrote:

> This is a set of patches to add support to the JZ4760(B) socs found in numerous gaming handhelds and some
> mp3 players.

Process note. Please don't set the reply to for new revisions.
They nest deep inside threads when people read email that way and
it makes them hard to spot. I'd much rather see them as a new
thread related only by the naming.

Thanks,

Jonathan

>
> Christophe Branchereau (5):
> iio/adc: ingenic: rename has_aux2 to has_aux_md
> dt-bindings: iio/adc: add an INGENIC_ADC_AUX0 entry
> iio/adc: ingenic: add JZ4760 support to the sadc driver
> iio/adc: ingenic: add JZ4760B support to the sadc driver
> dt-bindings: iio/adc: ingenic: add the JZ4760(B) socs to the sadc
> Documentation
>

2021-07-23 16:15:29

by Jonathan Cameron

[permalink] [raw]
Subject: Re: [PATCH 3/6] iio/adc: ingenic: add JZ4760 support to the sadc driver

On Wed, 21 Jul 2021 19:15:47 +0100
Paul Cercueil <[email protected]> wrote:

> Hi Christophe,
>
> Le mer., juil. 21 2021 at 12:53:14 +0200, citral23
> <[email protected]> a ?crit :
> > Signed-off-by: citral23 <[email protected]>
> > ---
> > drivers/iio/adc/ingenic-adc.c | 64
> > +++++++++++++++++++++++++++++++++++
> > 1 file changed, 64 insertions(+)
> >
> > diff --git a/drivers/iio/adc/ingenic-adc.c
> > b/drivers/iio/adc/ingenic-adc.c
> > index 40f2d8c2cf72..285e7aa8e37a 100644
> > --- a/drivers/iio/adc/ingenic-adc.c
> > +++ b/drivers/iio/adc/ingenic-adc.c
> > @@ -71,6 +71,7 @@
> > #define JZ4725B_ADC_BATTERY_HIGH_VREF_BITS 10
> > #define JZ4740_ADC_BATTERY_HIGH_VREF (7500 * 0.986)
> > #define JZ4740_ADC_BATTERY_HIGH_VREF_BITS 12
> > +#define JZ4760_ADC_BATTERY_VREF 2500
> > #define JZ4770_ADC_BATTERY_VREF 1200
> > #define JZ4770_ADC_BATTERY_VREF_BITS 12
> >
> > @@ -295,6 +296,10 @@ static const int
> > jz4740_adc_battery_scale_avail[] = {
> > JZ_ADC_BATTERY_LOW_VREF, JZ_ADC_BATTERY_LOW_VREF_BITS,
> > };
> >
> > +static const int jz4760_adc_battery_scale_avail[] = {
> > + JZ4760_ADC_BATTERY_VREF, JZ4770_ADC_BATTERY_VREF_BITS,
> > +};
> > +
> > static const int jz4770_adc_battery_raw_avail[] = {
> > 0, 1, (1 << JZ4770_ADC_BATTERY_VREF_BITS) - 1,
> > };
> > @@ -339,6 +344,8 @@ static int jz4725b_adc_init_clk_div(struct device
> > *dev, struct ingenic_adc *adc)
> > return 0;
> > }
> >
> > +
> > +
>
> Unrelated cosmetic change - remove it.
>
> > static int jz4770_adc_init_clk_div(struct device *dev, struct
> > ingenic_adc *adc)
> > {
> > struct clk *parent_clk;
> > @@ -400,6 +407,47 @@ static const struct iio_chan_spec
> > jz4740_channels[] = {
> > },
> > };
> >
> > +static const struct iio_chan_spec jz4760_channels[] = {
> > + {
> > + .extend_name = "aux0",
> > + .type = IIO_VOLTAGE,
> > + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .indexed = 1,
> > + .channel = INGENIC_ADC_AUX0,
> > + .scan_index = -1,
> > + },
> > + {
> > + .extend_name = "aux",
> > + .type = IIO_VOLTAGE,
> > + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .indexed = 1,
> > + .channel = INGENIC_ADC_AUX,
> > + .scan_index = -1,
> > + },
>
> A couple of things. First, ".extend_name" is deprecated now... But
> since the driver used it before, I suppose it doesn't make sense to use
> labels just for this SoC (as we can't remove .extend_name for other
> SoCs because of ABI). So I suppose it works here, but maybe Jonathan
> disagrees.

Hmm. Interesting question. We could attempt to force new device
support added to older drivers not to use extend_name but it seems
likely in this case at least, that the same board specific code might run
on this devices and the others, so I'll make an exception.

I'd be less keen if this was a stand alone ADC,

Jonathan

>
> Also, you should probably use "aux1" as the channel's name instead of
> "aux", independently of the macro name you used in the .channel field.
>
> > + {
> > + .extend_name = "battery",
> > + .type = IIO_VOLTAGE,
> > + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .info_mask_separate_available = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .indexed = 1,
> > + .channel = INGENIC_ADC_BATTERY,
> > + .scan_index = -1,
> > + },
>
> Swap the battery channel at the end, no? First the three AUX then the
> battery channel?
>
> The rest looks pretty good to me.
>
> Cheers,
> -Paul
>
> > + {
> > + .extend_name = "aux2",
> > + .type = IIO_VOLTAGE,
> > + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
> > + BIT(IIO_CHAN_INFO_SCALE),
> > + .indexed = 1,
> > + .channel = INGENIC_ADC_AUX2,
> > + .scan_index = -1,
> > + },
> > +};
> > +
> > static const struct iio_chan_spec jz4770_channels[] = {
> > {
> > .type = IIO_VOLTAGE,
> > @@ -526,6 +574,20 @@ static const struct ingenic_adc_soc_data
> > jz4740_adc_soc_data = {
> > .init_clk_div = NULL, /* no ADCLK register on JZ4740 */
> > };
> >
> > +static const struct ingenic_adc_soc_data jz4760_adc_soc_data = {
> > + .battery_high_vref = JZ4760_ADC_BATTERY_VREF,
> > + .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
> > + .battery_raw_avail = jz4770_adc_battery_raw_avail,
> > + .battery_raw_avail_size = ARRAY_SIZE(jz4770_adc_battery_raw_avail),
> > + .battery_scale_avail = jz4760_adc_battery_scale_avail,
> > + .battery_scale_avail_size =
> > ARRAY_SIZE(jz4760_adc_battery_scale_avail),
> > + .battery_vref_mode = false,
> > + .has_aux_md = true,
> > + .channels = jz4760_channels,
> > + .num_channels = ARRAY_SIZE(jz4760_channels),
> > + .init_clk_div = jz4770_adc_init_clk_div,
> > +};
> > +
> > static const struct ingenic_adc_soc_data jz4770_adc_soc_data = {
> > .battery_high_vref = JZ4770_ADC_BATTERY_VREF,
> > .battery_high_vref_bits = JZ4770_ADC_BATTERY_VREF_BITS,
> > @@ -621,6 +683,7 @@ static int ingenic_adc_read_raw(struct iio_dev
> > *iio_dev,
> > return ingenic_adc_read_chan_info_raw(iio_dev, chan, val);
> > case IIO_CHAN_INFO_SCALE:
> > switch (chan->channel) {
> > + case INGENIC_ADC_AUX0:
> > case INGENIC_ADC_AUX:
> > case INGENIC_ADC_AUX2:
> > *val = JZ_ADC_AUX_VREF;
> > @@ -832,6 +895,7 @@ static int ingenic_adc_probe(struct
> > platform_device *pdev)
> > static const struct of_device_id ingenic_adc_of_match[] = {
> > { .compatible = "ingenic,jz4725b-adc", .data =
> > &jz4725b_adc_soc_data, },
> > { .compatible = "ingenic,jz4740-adc", .data = &jz4740_adc_soc_data,
> > },
> > + { .compatible = "ingenic,jz4760-adc", .data = &jz4760_adc_soc_data,
> > },
> > { .compatible = "ingenic,jz4770-adc", .data = &jz4770_adc_soc_data,
> > },
> > { },
> > };
> > --
> > 2.30.2
> >
>
>

2021-07-23 16:18:53

by Jonathan Cameron

[permalink] [raw]
Subject: Re: [PATCH V2 4/5] iio/adc: ingenic: add JZ4760B support to the sadc driver

On Fri, 23 Jul 2021 10:58:12 +0200
Christophe Branchereau <[email protected]> wrote:

> 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 adding the
> "ingenic,use-internal-divider" property to a devicetree.
>
> Signed-off-by: Christophe Branchereau <[email protected]>

One minor formatting comment inline. If that is all that comes up in
review I can just change it whilst applying.

Jonathan

> ---
> drivers/iio/adc/ingenic-adc.c | 8 ++++++++
> 1 file changed, 8 insertions(+)
>
> diff --git a/drivers/iio/adc/ingenic-adc.c b/drivers/iio/adc/ingenic-adc.c
> index 6b9af0530590..09937c05d2af 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,12 @@ 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);
> +
> + if (device_property_present(dev, "ingenic,use-internal-divider")) /* JZ4760B specific */
> + ingenic_adc_set_config(adc, JZ_ADC_REG_CFG_VBAT_SEL, JZ_ADC_REG_CFG_VBAT_SEL);
Please break this line and move the comment on the one above.

Whilst we have relaxed the kernel style to allow longer lines, it's nice
to still keep them to the 80 char limit when it doesn't really hurt readability.
Here I don't think it would make much difference.

> + 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);
>
> @@ -906,6 +913,7 @@ static const struct of_device_id ingenic_adc_of_match[] = {
> { .compatible = "ingenic,jz4725b-adc", .data = &jz4725b_adc_soc_data, },
> { .compatible = "ingenic,jz4740-adc", .data = &jz4740_adc_soc_data, },
> { .compatible = "ingenic,jz4760-adc", .data = &jz4760_adc_soc_data, },
> + { .compatible = "ingenic,jz4760b-adc", .data = &jz4760_adc_soc_data, },
> { .compatible = "ingenic,jz4770-adc", .data = &jz4770_adc_soc_data, },
> { },
> };

2021-07-23 16:19:23

by Jonathan Cameron

[permalink] [raw]
Subject: Re: [PATCH V2 5/5] dt-bindings: iio/adc: ingenic: add the JZ4760(B) socs to the sadc Documentation

On Fri, 23 Jul 2021 10:58:13 +0200
Christophe Branchereau <[email protected]> wrote:

> The jz4760b variant differs slightly from the jz4760, add a property to
> let users sample the internal divider if needed and document it.
>
> Signed-off-by: Christophe Branchereau <[email protected]>
> ---
> .../devicetree/bindings/iio/adc/ingenic,adc.yaml | 9 +++++++++
> 1 file changed, 9 insertions(+)
>
> diff --git a/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml b/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
> index 433a3fb55a2e..0dc42959a64f 100644
> --- a/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
> +++ b/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
> @@ -23,6 +23,8 @@ properties:
> enum:
> - ingenic,jz4725b-adc
> - ingenic,jz4740-adc
> + - ingenic,jz4760-adc
> + - ingenic,jz4760b-adc
> - ingenic,jz4770-adc
>
> '#io-channel-cells':
> @@ -43,6 +45,13 @@ properties:
> interrupts:
> maxItems: 1
>
> + ingenic,use-internal-divider:
> + description:
> + This property can be used to set VBAT_SEL in the JZ4760B CFG register
> + to sample the battery voltage from the internal divider. If absent, it
> + will sample the external divider.
> + type: boolean
> +
See reply to the v1 patch for hint on how to 'enforce' that this
only exists for the jz4760b

Thanks,

Jonathan

> required:
> - compatible
> - '#io-channel-cells'

2021-07-24 07:35:46

by Christophe Branchereau

[permalink] [raw]
Subject: Re: [PATCH V2 5/5] dt-bindings: iio/adc: ingenic: add the JZ4760(B) socs to the sadc Documentation

Hello Johnathan, am I allowed to declare the property within the if
block like this?

# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
# Copyright 2019-2020 Artur Rojek
%YAML 1.2
---
$id: "http://devicetree.org/schemas/iio/adc/ingenic,adc.yaml#"
$schema: "http://devicetree.org/meta-schemas/core.yaml#"

title: Ingenic JZ47xx ADC controller IIO bindings

maintainers:
- Artur Rojek <[email protected]>

description: >
Industrial I/O subsystem bindings for ADC controller found in
Ingenic JZ47xx SoCs.

ADC clients must use the format described in
https://github.com/devicetree-org/dt-schema/blob/master/schemas/iio/iio-consumer.yaml,
giving a phandle and IIO specifier pair ("io-channels") to the ADC controller.

properties:
compatible:
enum:
- ingenic,jz4725b-adc
- ingenic,jz4740-adc
- ingenic,jz4760-adc
- ingenic,jz4760b-adc
- ingenic,jz4770-adc

'#io-channel-cells':
const: 1
description:
Must be set to <1> to indicate channels are selected by index.

reg:
maxItems: 1

clocks:
maxItems: 1

clock-names:
items:
- const: adc

interrupts:
maxItems: 1

allOf:
- if:
properties:
compatible:
contains:
enum:
- ingenic,jz4760b-adc
then:
properties:
ingenic,use-internal-divider:
description:
If present, battery voltage is read from the VBAT_IR pin, which has an
internal 1/4 divider. If absent, it is read through the VBAT_ER pin,
which does not have such a divider.
type: boolean

required:
- compatible
- '#io-channel-cells'
- reg
- clocks
- clock-names
- interrupts

additionalProperties: false

examples:
- |
#include <dt-bindings/clock/jz4740-cgu.h>
#include <dt-bindings/iio/adc/ingenic,adc.h>

adc@10070000 {
compatible = "ingenic,jz4740-adc";
#io-channel-cells = <1>;

reg = <0x10070000 0x30>;

clocks = <&cgu JZ4740_CLK_ADC>;
clock-names = "adc";

interrupt-parent = <&intc>;
interrupts = <18>;
};

On Fri, Jul 23, 2021 at 6:17 PM Jonathan Cameron
<[email protected]> wrote:
>
> On Fri, 23 Jul 2021 10:58:13 +0200
> Christophe Branchereau <[email protected]> wrote:
>
> > The jz4760b variant differs slightly from the jz4760, add a property to
> > let users sample the internal divider if needed and document it.
> >
> > Signed-off-by: Christophe Branchereau <[email protected]>
> > ---
> > .../devicetree/bindings/iio/adc/ingenic,adc.yaml | 9 +++++++++
> > 1 file changed, 9 insertions(+)
> >
> > diff --git a/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml b/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
> > index 433a3fb55a2e..0dc42959a64f 100644
> > --- a/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
> > +++ b/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
> > @@ -23,6 +23,8 @@ properties:
> > enum:
> > - ingenic,jz4725b-adc
> > - ingenic,jz4740-adc
> > + - ingenic,jz4760-adc
> > + - ingenic,jz4760b-adc
> > - ingenic,jz4770-adc
> >
> > '#io-channel-cells':
> > @@ -43,6 +45,13 @@ properties:
> > interrupts:
> > maxItems: 1
> >
> > + ingenic,use-internal-divider:
> > + description:
> > + This property can be used to set VBAT_SEL in the JZ4760B CFG register
> > + to sample the battery voltage from the internal divider. If absent, it
> > + will sample the external divider.
> > + type: boolean
> > +
> See reply to the v1 patch for hint on how to 'enforce' that this
> only exists for the jz4760b
>
> Thanks,
>
> Jonathan
>
> > required:
> > - compatible
> > - '#io-channel-cells'
>

2021-07-24 15:23:07

by Jonathan Cameron

[permalink] [raw]
Subject: Re: [PATCH V2 5/5] dt-bindings: iio/adc: ingenic: add the JZ4760(B) socs to the sadc Documentation

On Sat, 24 Jul 2021 09:33:46 +0200
Christophe Branchereau <[email protected]> wrote:

> Hello Johnathan, am I allowed to declare the property within the if
> block like this?

Test it...

Short answer is no you aren't. As someone explained it to me the other
day, each layer of the yaml is checked independently so if you declare
a property in the if block and not the outer layer the additionalProperties
check will fail should it be present.

So declare it outside, then set it false for the cases where it's not valid.

Jonathan

>
> # SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
> # Copyright 2019-2020 Artur Rojek
> %YAML 1.2
> ---
> $id: "http://devicetree.org/schemas/iio/adc/ingenic,adc.yaml#"
> $schema: "http://devicetree.org/meta-schemas/core.yaml#"
>
> title: Ingenic JZ47xx ADC controller IIO bindings
>
> maintainers:
> - Artur Rojek <[email protected]>
>
> description: >
> Industrial I/O subsystem bindings for ADC controller found in
> Ingenic JZ47xx SoCs.
>
> ADC clients must use the format described in
> https://github.com/devicetree-org/dt-schema/blob/master/schemas/iio/iio-consumer.yaml,
> giving a phandle and IIO specifier pair ("io-channels") to the ADC controller.
>
> properties:
> compatible:
> enum:
> - ingenic,jz4725b-adc
> - ingenic,jz4740-adc
> - ingenic,jz4760-adc
> - ingenic,jz4760b-adc
> - ingenic,jz4770-adc
>
> '#io-channel-cells':
> const: 1
> description:
> Must be set to <1> to indicate channels are selected by index.
>
> reg:
> maxItems: 1
>
> clocks:
> maxItems: 1
>
> clock-names:
> items:
> - const: adc
>
> interrupts:
> maxItems: 1
>
> allOf:
> - if:
> properties:
> compatible:
> contains:
> enum:
> - ingenic,jz4760b-adc
> then:
> properties:
> ingenic,use-internal-divider:
> description:
> If present, battery voltage is read from the VBAT_IR pin, which has an
> internal 1/4 divider. If absent, it is read through the VBAT_ER pin,
> which does not have such a divider.
> type: boolean
>
> required:
> - compatible
> - '#io-channel-cells'
> - reg
> - clocks
> - clock-names
> - interrupts
>
> additionalProperties: false
>
> examples:
> - |
> #include <dt-bindings/clock/jz4740-cgu.h>
> #include <dt-bindings/iio/adc/ingenic,adc.h>
>
> adc@10070000 {
> compatible = "ingenic,jz4740-adc";
> #io-channel-cells = <1>;
>
> reg = <0x10070000 0x30>;
>
> clocks = <&cgu JZ4740_CLK_ADC>;
> clock-names = "adc";
>
> interrupt-parent = <&intc>;
> interrupts = <18>;
> };
>
> On Fri, Jul 23, 2021 at 6:17 PM Jonathan Cameron
> <[email protected]> wrote:
> >
> > On Fri, 23 Jul 2021 10:58:13 +0200
> > Christophe Branchereau <[email protected]> wrote:
> >
> > > The jz4760b variant differs slightly from the jz4760, add a property to
> > > let users sample the internal divider if needed and document it.
> > >
> > > Signed-off-by: Christophe Branchereau <[email protected]>
> > > ---
> > > .../devicetree/bindings/iio/adc/ingenic,adc.yaml | 9 +++++++++
> > > 1 file changed, 9 insertions(+)
> > >
> > > diff --git a/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml b/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
> > > index 433a3fb55a2e..0dc42959a64f 100644
> > > --- a/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
> > > +++ b/Documentation/devicetree/bindings/iio/adc/ingenic,adc.yaml
> > > @@ -23,6 +23,8 @@ properties:
> > > enum:
> > > - ingenic,jz4725b-adc
> > > - ingenic,jz4740-adc
> > > + - ingenic,jz4760-adc
> > > + - ingenic,jz4760b-adc
> > > - ingenic,jz4770-adc
> > >
> > > '#io-channel-cells':
> > > @@ -43,6 +45,13 @@ properties:
> > > interrupts:
> > > maxItems: 1
> > >
> > > + ingenic,use-internal-divider:
> > > + description:
> > > + This property can be used to set VBAT_SEL in the JZ4760B CFG register
> > > + to sample the battery voltage from the internal divider. If absent, it
> > > + will sample the external divider.
> > > + type: boolean
> > > +
> > See reply to the v1 patch for hint on how to 'enforce' that this
> > only exists for the jz4760b
> >
> > Thanks,
> >
> > Jonathan
> >
> > > required:
> > > - compatible
> > > - '#io-channel-cells'
> >