From 4e3ffc5134a06a4e6b87a02fc85bd16e77656bd4 Mon Sep 17 00:00:00 2001
From: gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4>
Date: Sun, 10 Mar 2013 11:04:37 +0000
Subject: Fixed bug 3607518.

git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@5401 35acf78f-673a-0410-8e92-d51de3d6d3f4
---
 os/hal/platforms/STM32F0xx/stm32_dma.h | 3 ++-
 os/hal/platforms/STM32F1xx/stm32_dma.h | 3 ++-
 os/hal/platforms/STM32F30x/stm32_dma.h | 3 ++-
 os/hal/platforms/STM32F37x/stm32_dma.h | 3 ++-
 os/hal/platforms/STM32F4xx/stm32_dma.h | 4 +++-
 os/hal/platforms/STM32L1xx/stm32_dma.h | 3 ++-
 6 files changed, 13 insertions(+), 6 deletions(-)

(limited to 'os/hal')

diff --git a/os/hal/platforms/STM32F0xx/stm32_dma.h b/os/hal/platforms/STM32F0xx/stm32_dma.h
index c07aa34fb..b7a07d6ea 100644
--- a/os/hal/platforms/STM32F0xx/stm32_dma.h
+++ b/os/hal/platforms/STM32F0xx/stm32_dma.h
@@ -309,7 +309,8 @@ typedef void (*stm32_dmaisr_t)(void *p, uint32_t flags);
  * @special
  */
 #define dmaStreamDisable(dmastp) {                                          \
-  (dmastp)->channel->CCR &= ~STM32_DMA_CR_EN;                               \
+  (dmastp)->channel->CCR &= ~(STM32_DMA_CR_TCIE | STM32_DMA_CR_HTIE |       \
+                              STM32_DMA_CR_TEIE | STM32_DMA_CR_EN);         \
   dmaStreamClearInterrupt(dmastp);                                          \
 }
 
diff --git a/os/hal/platforms/STM32F1xx/stm32_dma.h b/os/hal/platforms/STM32F1xx/stm32_dma.h
index ff83161fa..a0766ab06 100644
--- a/os/hal/platforms/STM32F1xx/stm32_dma.h
+++ b/os/hal/platforms/STM32F1xx/stm32_dma.h
@@ -320,7 +320,8 @@ typedef void (*stm32_dmaisr_t)(void *p, uint32_t flags);
  * @special
  */
 #define dmaStreamDisable(dmastp) {                                          \
-  (dmastp)->channel->CCR &= ~STM32_DMA_CR_EN;                               \
+  (dmastp)->channel->CCR &= ~(STM32_DMA_CR_TCIE | STM32_DMA_CR_HTIE |       \
+                              STM32_DMA_CR_TEIE | STM32_DMA_CR_EN);         \
   dmaStreamClearInterrupt(dmastp);                                          \
 }
 
diff --git a/os/hal/platforms/STM32F30x/stm32_dma.h b/os/hal/platforms/STM32F30x/stm32_dma.h
index 63e9d4265..6d82dd4b9 100644
--- a/os/hal/platforms/STM32F30x/stm32_dma.h
+++ b/os/hal/platforms/STM32F30x/stm32_dma.h
@@ -320,7 +320,8 @@ typedef void (*stm32_dmaisr_t)(void *p, uint32_t flags);
  * @special
  */
 #define dmaStreamDisable(dmastp) {                                          \
-  (dmastp)->channel->CCR &= ~STM32_DMA_CR_EN;                               \
+  (dmastp)->channel->CCR &= ~(STM32_DMA_CR_TCIE | STM32_DMA_CR_HTIE |       \
+                              STM32_DMA_CR_TEIE | STM32_DMA_CR_EN);         \
   dmaStreamClearInterrupt(dmastp);                                          \
 }
 
diff --git a/os/hal/platforms/STM32F37x/stm32_dma.h b/os/hal/platforms/STM32F37x/stm32_dma.h
index 474c94acc..257ed6054 100644
--- a/os/hal/platforms/STM32F37x/stm32_dma.h
+++ b/os/hal/platforms/STM32F37x/stm32_dma.h
@@ -320,7 +320,8 @@ typedef void (*stm32_dmaisr_t)(void *p, uint32_t flags);
  * @special
  */
 #define dmaStreamDisable(dmastp) {                                          \
-  (dmastp)->channel->CCR &= ~STM32_DMA_CR_EN;                               \
+  (dmastp)->channel->CCR &= ~(STM32_DMA_CR_TCIE | STM32_DMA_CR_HTIE |       \
+                              STM32_DMA_CR_TEIE | STM32_DMA_CR_EN);         \
   dmaStreamClearInterrupt(dmastp);                                          \
 }
 
diff --git a/os/hal/platforms/STM32F4xx/stm32_dma.h b/os/hal/platforms/STM32F4xx/stm32_dma.h
index cb4819f1d..9b745a917 100644
--- a/os/hal/platforms/STM32F4xx/stm32_dma.h
+++ b/os/hal/platforms/STM32F4xx/stm32_dma.h
@@ -373,7 +373,9 @@ typedef void (*stm32_dmaisr_t)(void *p, uint32_t flags);
  * @special
  */
 #define dmaStreamDisable(dmastp) {                                          \
-  (dmastp)->stream->CR &= ~STM32_DMA_CR_EN;                                 \
+  (dmastp)->stream->CR &= ~(STM32_DMA_CR_TCIE | STM32_DMA_CR_HTIE  |        \
+                            STM32_DMA_CR_TEIE | STM32_DMA_CR_DMEIE |        \
+                            STM32_DMA_CR_EN);                               \
   while (((dmastp)->stream->CR & STM32_DMA_CR_EN) != 0)                     \
     ;                                                                       \
   dmaStreamClearInterrupt(dmastp);                                          \
diff --git a/os/hal/platforms/STM32L1xx/stm32_dma.h b/os/hal/platforms/STM32L1xx/stm32_dma.h
index 8056428b3..3de9d4980 100644
--- a/os/hal/platforms/STM32L1xx/stm32_dma.h
+++ b/os/hal/platforms/STM32L1xx/stm32_dma.h
@@ -311,7 +311,8 @@ typedef void (*stm32_dmaisr_t)(void *p, uint32_t flags);
  * @special
  */
 #define dmaStreamDisable(dmastp) {                                          \
-  (dmastp)->channel->CCR &= ~STM32_DMA_CR_EN;                               \
+  (dmastp)->channel->CCR &= ~(STM32_DMA_CR_TCIE | STM32_DMA_CR_HTIE |       \
+                              STM32_DMA_CR_TEIE | STM32_DMA_CR_EN);         \
   dmaStreamClearInterrupt(dmastp);                                          \
 }
 
-- 
cgit v1.2.3