提交 e748783c 编写于 作者: J Jean-Christophe PLAGNIOL-VILLARD 提交者: Jonathan Cameron

iio: at91_adc: add sleep mode support

The sleep mode will allow to put the adc in sleep between conversion.
Signed-off-by: NJean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
Signed-off-by: NLudovic Desroches <ludovic.desroches@atmel.com>
Acked-by: NMaxime Ripard <maxime.ripard@free-electrons.com>
Signed-off-by: NJonathan Cameron <jic23@kernel.org>
上级 47be16b6
...@@ -25,6 +25,7 @@ Optional properties: ...@@ -25,6 +25,7 @@ Optional properties:
- atmel,adc-use-res: String corresponding to an identifier from - atmel,adc-use-res: String corresponding to an identifier from
atmel,adc-res-names property. If not specified, the highest atmel,adc-res-names property. If not specified, the highest
resolution will be used. resolution will be used.
- atmel,adc-sleep-mode: Boolean to enable sleep mode when no conversion
Optional trigger Nodes: Optional trigger Nodes:
- Required properties: - Required properties:
......
...@@ -52,6 +52,7 @@ struct at91_adc_state { ...@@ -52,6 +52,7 @@ struct at91_adc_state {
void __iomem *reg_base; void __iomem *reg_base;
struct at91_adc_reg_desc *registers; struct at91_adc_reg_desc *registers;
u8 startup_time; u8 startup_time;
bool sleep_mode;
struct iio_trigger **trig; struct iio_trigger **trig;
struct at91_adc_trigger *trigger_list; struct at91_adc_trigger *trigger_list;
u32 trigger_number; u32 trigger_number;
...@@ -455,6 +456,8 @@ static int at91_adc_probe_dt(struct at91_adc_state *st, ...@@ -455,6 +456,8 @@ static int at91_adc_probe_dt(struct at91_adc_state *st,
} }
st->num_channels = prop; st->num_channels = prop;
st->sleep_mode = of_property_read_bool(node, "atmel,adc-sleep-mode");
if (of_property_read_u32(node, "atmel,adc-startup-time", &prop)) { if (of_property_read_u32(node, "atmel,adc-startup-time", &prop)) {
dev_err(&idev->dev, "Missing adc-startup-time property in the DT.\n"); dev_err(&idev->dev, "Missing adc-startup-time property in the DT.\n");
ret = -EINVAL; ret = -EINVAL;
...@@ -580,6 +583,7 @@ static int at91_adc_probe(struct platform_device *pdev) ...@@ -580,6 +583,7 @@ static int at91_adc_probe(struct platform_device *pdev)
struct iio_dev *idev; struct iio_dev *idev;
struct at91_adc_state *st; struct at91_adc_state *st;
struct resource *res; struct resource *res;
u32 reg;
idev = iio_device_alloc(sizeof(struct at91_adc_state)); idev = iio_device_alloc(sizeof(struct at91_adc_state));
if (idev == NULL) { if (idev == NULL) {
...@@ -687,16 +691,13 @@ static int at91_adc_probe(struct platform_device *pdev) ...@@ -687,16 +691,13 @@ static int at91_adc_probe(struct platform_device *pdev)
*/ */
ticks = round_up((st->startup_time * adc_clk / ticks = round_up((st->startup_time * adc_clk /
1000000) - 1, 8) / 8; 1000000) - 1, 8) / 8;
reg = AT91_ADC_PRESCAL_(prsc) & AT91_ADC_PRESCAL;
reg |= AT91_ADC_STARTUP_(ticks) & AT91_ADC_STARTUP;
if (st->low_res) if (st->low_res)
at91_adc_writel(st, AT91_ADC_MR, reg |= AT91_ADC_LOWRES;
AT91_ADC_LOWRES | if (st->sleep_mode)
(AT91_ADC_PRESCAL_(prsc) & AT91_ADC_PRESCAL) | reg |= AT91_ADC_SLEEP;
(AT91_ADC_STARTUP_(ticks) & AT91_ADC_STARTUP)); at91_adc_writel(st, AT91_ADC_MR, reg);
else
at91_adc_writel(st, AT91_ADC_MR,
(AT91_ADC_PRESCAL_(prsc) & AT91_ADC_PRESCAL) |
(AT91_ADC_STARTUP_(ticks) & AT91_ADC_STARTUP));
/* Setup the ADC channels available on the board */ /* Setup the ADC channels available on the board */
ret = at91_adc_channel_init(idev); ret = at91_adc_channel_init(idev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册