iop-adma: remove the workaround for missed interrupts on iop3xx
authorDan Williams <dan.j.williams@intel.com>
Fri, 18 Apr 2008 03:17:26 +0000 (20:17 -0700)
committerDan Williams <dan.j.williams@intel.com>
Thu, 17 Apr 2008 20:25:54 +0000 (13:25 -0700)
This workaround was covering the dependency submission bug in async_tx.

Signed-off-by: Dan Williams <dan.j.williams@intel.com>
drivers/dma/iop-adma.c
include/asm-arm/arch-iop13xx/adma.h
include/asm-arm/hardware/iop3xx-adma.h
include/asm-arm/hardware/iop_adma.h

index 2aa3df50c842bc5d45a42dc16ca9dc5d9a109f06..93252294f32bf0d35a75e261f6ed6fbb17c3f662 100644 (file)
@@ -255,8 +255,6 @@ static void __iop_adma_slot_cleanup(struct iop_adma_chan *iop_chan)
 
        BUG_ON(!seen_current);
 
-       iop_chan_idle(busy, iop_chan);
-
        if (cookie > 0) {
                iop_chan->completed_cookie = cookie;
                pr_debug("\tcompleted cookie %d\n", cookie);
@@ -1226,9 +1224,6 @@ static int __devinit iop_adma_probe(struct platform_device *pdev)
        }
 
        spin_lock_init(&iop_chan->lock);
-       init_timer(&iop_chan->cleanup_watchdog);
-       iop_chan->cleanup_watchdog.data = (unsigned long) iop_chan;
-       iop_chan->cleanup_watchdog.function = iop_adma_tasklet;
        INIT_LIST_HEAD(&iop_chan->chain);
        INIT_LIST_HEAD(&iop_chan->all_slots);
        INIT_RCU_HEAD(&iop_chan->common.rcu);
index efd9a5eb10081275859eb5605e78611f149572da..90d14ee564f567c2515dbced773eebda2d494063 100644 (file)
@@ -454,11 +454,6 @@ static inline void iop_chan_append(struct iop_adma_chan *chan)
        __raw_writel(adma_accr, ADMA_ACCR(chan));
 }
 
-static inline void iop_chan_idle(int busy, struct iop_adma_chan *chan)
-{
-       do { } while (0);
-}
-
 static inline u32 iop_chan_get_status(struct iop_adma_chan *chan)
 {
        return __raw_readl(ADMA_ACSR(chan));
index 5c529e6a5e3b6a7c0336ca0b6a205887fb443f55..84d635b0a71ad514e8dd5ef937654e20596d1d88 100644 (file)
@@ -767,20 +767,12 @@ static inline int iop_desc_get_zero_result(struct iop_adma_desc_slot *desc)
 static inline void iop_chan_append(struct iop_adma_chan *chan)
 {
        u32 dma_chan_ctrl;
-       /* workaround dropped interrupts on 3xx */
-       mod_timer(&chan->cleanup_watchdog, jiffies + msecs_to_jiffies(3));
 
        dma_chan_ctrl = __raw_readl(DMA_CCR(chan));
        dma_chan_ctrl |= 0x2;
        __raw_writel(dma_chan_ctrl, DMA_CCR(chan));
 }
 
-static inline void iop_chan_idle(int busy, struct iop_adma_chan *chan)
-{
-       if (!busy)
-               del_timer(&chan->cleanup_watchdog);
-}
-
 static inline u32 iop_chan_get_status(struct iop_adma_chan *chan)
 {
        return __raw_readl(DMA_CSR(chan));
index ca8e71f443465d8aae6cf507b41719771dbe4700..cb7e3611bcba748352d4227c19104e46fc47d08e 100644 (file)
@@ -51,7 +51,6 @@ struct iop_adma_device {
  * @common: common dmaengine channel object members
  * @last_used: place holder for allocation to continue from where it left off
  * @all_slots: complete domain of slots usable by the channel
- * @cleanup_watchdog: workaround missed interrupts on iop3xx
  * @slots_allocated: records the actual size of the descriptor slot pool
  * @irq_tasklet: bottom half where iop_adma_slot_cleanup runs
  */
@@ -65,7 +64,6 @@ struct iop_adma_chan {
        struct dma_chan common;
        struct iop_adma_desc_slot *last_used;
        struct list_head all_slots;
-       struct timer_list cleanup_watchdog;
        int slots_allocated;
        struct tasklet_struct irq_tasklet;
 };