Merge branch 'liblockdep-fixes-3.19' of git://git.kernel.org/pub/scm/linux/kernel...
[firefly-linux-kernel-4.4.55.git] / drivers / dma / cppi41.c
index 3fb793188b60532609065b05e8d3618b4ed0d1e6..b743adf56465644670ed77f4a4153cce9015491a 100644 (file)
@@ -1,3 +1,4 @@
+#include <linux/delay.h>
 #include <linux/dmaengine.h>
 #include <linux/dma-mapping.h>
 #include <linux/platform_device.h>
@@ -603,12 +604,16 @@ static int cppi41_tear_down_chan(struct cppi41_channel *c)
         * descriptor before the TD we fetch it from enqueue, it has to be
         * there waiting for us.
         */
-       if (!c->td_seen && c->td_retry)
+       if (!c->td_seen && c->td_retry) {
+               udelay(1);
                return -EAGAIN;
-
+       }
        WARN_ON(!c->td_retry);
+
        if (!c->td_desc_seen) {
                desc_phys = cppi41_pop_desc(cdd, c->q_num);
+               if (!desc_phys)
+                       desc_phys = cppi41_pop_desc(cdd, c->q_comp_num);
                WARN_ON(!desc_phys);
        }