From 16aced1b3f00fa10720e4990c37aa85d5da3be2a Mon Sep 17 00:00:00 2001 From: Viresh Kumar Date: Fri, 29 Jul 2011 16:21:57 +0530 Subject: [PATCH] --- yaml --- r: 273851 b: refs/heads/master c: 9704efaa52ab18eb3504c4e0bc421c1d01b7981a h: refs/heads/master i: 273849: afbd11a8f0526e145610b624b7e7bf46822ecb99 273847: a0c0db7702b5fe5378c1da6315b37ecdc427e91e v: v3 --- [refs] | 2 +- trunk/drivers/dma/dmatest.c | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index b90404b5eca5..e0ca88e1b166 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 90b44f8ffdf6c66d190ee71b330009bf7f11a208 +refs/heads/master: 9704efaa52ab18eb3504c4e0bc421c1d01b7981a diff --git a/trunk/drivers/dma/dmatest.c b/trunk/drivers/dma/dmatest.c index 765f5ff22304..accc18441b16 100644 --- a/trunk/drivers/dma/dmatest.c +++ b/trunk/drivers/dma/dmatest.c @@ -477,6 +477,8 @@ static int dmatest_func(void *data) pr_notice("%s: terminating after %u tests, %u failures (status %d)\n", thread_name, total_tests, failed_tests, ret); + /* terminate all transfers on specified channels */ + chan->device->device_control(chan, DMA_TERMINATE_ALL, 0); if (iterations > 0) while (!kthread_should_stop()) { DECLARE_WAIT_QUEUE_HEAD_ONSTACK(wait_dmatest_exit); @@ -499,6 +501,10 @@ static void dmatest_cleanup_channel(struct dmatest_chan *dtc) list_del(&thread->node); kfree(thread); } + + /* terminate all transfers on specified channels */ + dtc->chan->device->device_control(dtc->chan, DMA_TERMINATE_ALL, 0); + kfree(dtc); }