#include <linux/bitops.h>
 #include <linux/clk.h>
+#include <linux/delay.h>
 #include <linux/dma-mapping.h>
 #include <linux/dmaengine.h>
 #include <linux/interrupt.h>
 #define AT91_SAMA5D2_IER_YRDY   BIT(21)
 /* Interrupt Enable Register - TS pressure measurement ready */
 #define AT91_SAMA5D2_IER_PRDY   BIT(22)
+/* Interrupt Enable Register - Data ready */
+#define AT91_SAMA5D2_IER_DRDY   BIT(24)
 /* Interrupt Enable Register - general overrun error */
 #define AT91_SAMA5D2_IER_GOVRE BIT(25)
 /* Interrupt Enable Register - Pen detect */
        return at91_adc_chan_xlate(indio_dev, iiospec->args[0]);
 }
 
+static unsigned int at91_adc_active_scan_mask_to_reg(struct iio_dev *indio_dev)
+{
+       u32 mask = 0;
+       u8 bit;
+
+       for_each_set_bit(bit, indio_dev->active_scan_mask,
+                        indio_dev->num_channels) {
+               struct iio_chan_spec const *chan =
+                        at91_adc_chan_get(indio_dev, bit);
+               mask |= BIT(chan->channel);
+       }
+
+       return mask & GENMASK(11, 0);
+}
+
 static void at91_adc_config_emr(struct at91_adc_state *st)
 {
        /* configure the extended mode register */
                        at91_adc_writel(st, AT91_SAMA5D2_COR, cor);
                }
 
-               if (state) {
+               if (state)
                        at91_adc_writel(st, AT91_SAMA5D2_CHER,
                                        BIT(chan->channel));
-                       /* enable irq only if not using DMA */
-                       if (!st->dma_st.dma_chan) {
-                               at91_adc_writel(st, AT91_SAMA5D2_IER,
-                                               BIT(chan->channel));
-                       }
-               } else {
-                       /* disable irq only if not using DMA */
-                       if (!st->dma_st.dma_chan) {
-                               at91_adc_writel(st, AT91_SAMA5D2_IDR,
-                                               BIT(chan->channel));
-                       }
+               else
                        at91_adc_writel(st, AT91_SAMA5D2_CHDR,
                                        BIT(chan->channel));
-               }
        }
 
+       /* Nothing to do if using DMA */
+       if (st->dma_st.dma_chan)
+               return 0;
+
+       if (state)
+               at91_adc_writel(st, AT91_SAMA5D2_IER, AT91_SAMA5D2_IER_DRDY);
+       else
+               at91_adc_writel(st, AT91_SAMA5D2_IDR, AT91_SAMA5D2_IER_DRDY);
+
        return 0;
 }
 
 
        /* Needed to ACK the DRDY interruption */
        at91_adc_readl(st, AT91_SAMA5D2_LCDR);
+
        return 0;
 }
 
        int i = 0;
        int val;
        u8 bit;
+       u32 mask = at91_adc_active_scan_mask_to_reg(indio_dev);
+       unsigned int timeout = 50;
+
+       /*
+        * Check if the conversion is ready. If not, wait a little bit, and
+        * in case of timeout exit with an error.
+        */
+       while ((at91_adc_readl(st, AT91_SAMA5D2_ISR) & mask) != mask &&
+              timeout) {
+               usleep_range(50, 100);
+               timeout--;
+       }
+
+       /* Cannot read data, not ready. Continue without reporting data */
+       if (!timeout)
+               return;
 
        for_each_set_bit(bit, indio_dev->active_scan_mask,
                         indio_dev->num_channels) {
                status = at91_adc_readl(st, AT91_SAMA5D2_XPOSR);
                status = at91_adc_readl(st, AT91_SAMA5D2_YPOSR);
                status = at91_adc_readl(st, AT91_SAMA5D2_PRESSR);
-       } else if (iio_buffer_enabled(indio) && !st->dma_st.dma_chan) {
+       } else if (iio_buffer_enabled(indio) &&
+                  (status & AT91_SAMA5D2_IER_DRDY)) {
                /* triggered buffer without DMA */
                disable_irq_nosync(irq);
                iio_trigger_poll(indio->trig);