diff options
| author | Takashi Iwai <tiwai@suse.de> | 2013-04-18 16:24:31 +0200 | 
|---|---|---|
| committer | Takashi Iwai <tiwai@suse.de> | 2013-04-18 16:24:31 +0200 | 
| commit | 8dd2b66d1a961231685a3bfe5937c85d846fbf5d (patch) | |
| tree | 8117553488bf4ef09b048a4b343cf37cc16bf46d /drivers/dma/omap-dma.c | |
| parent | 126825e7ea271ae8e3172e10ca1fc22c908b5385 (diff) | |
| parent | 24568ea4bef5ab8106206eddf5512434421c00ed (diff) | |
| download | olio-linux-3.10-8dd2b66d1a961231685a3bfe5937c85d846fbf5d.tar.xz olio-linux-3.10-8dd2b66d1a961231685a3bfe5937c85d846fbf5d.zip  | |
Merge tag 'asoc-v3.10-2' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-next
ASoC: More updates for v3.10
The main additional change here is Lars-Peter's DMA work plus the
platform conversions which have been tested - getting this in mainline
will make life easier for development after the merge window.  These
factor a large chunk of code out of the drivers for the platforms using
dmaengine, greatly simplifying development.
Diffstat (limited to 'drivers/dma/omap-dma.c')
| -rw-r--r-- | drivers/dma/omap-dma.c | 20 | 
1 files changed, 14 insertions, 6 deletions
diff --git a/drivers/dma/omap-dma.c b/drivers/dma/omap-dma.c index c4b4fd2acc4..08b43bf3715 100644 --- a/drivers/dma/omap-dma.c +++ b/drivers/dma/omap-dma.c @@ -276,12 +276,20 @@ static void omap_dma_issue_pending(struct dma_chan *chan)  	spin_lock_irqsave(&c->vc.lock, flags);  	if (vchan_issue_pending(&c->vc) && !c->desc) { -		struct omap_dmadev *d = to_omap_dma_dev(chan->device); -		spin_lock(&d->lock); -		if (list_empty(&c->node)) -			list_add_tail(&c->node, &d->pending); -		spin_unlock(&d->lock); -		tasklet_schedule(&d->task); +		/* +		 * c->cyclic is used only by audio and in this case the DMA need +		 * to be started without delay. +		 */ +		if (!c->cyclic) { +			struct omap_dmadev *d = to_omap_dma_dev(chan->device); +			spin_lock(&d->lock); +			if (list_empty(&c->node)) +				list_add_tail(&c->node, &d->pending); +			spin_unlock(&d->lock); +			tasklet_schedule(&d->task); +		} else { +			omap_dma_start_desc(c); +		}  	}  	spin_unlock_irqrestore(&c->vc.lock, flags);  }  |