diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2017-04-02 19:29:34 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2017-04-02 19:29:34 -0400 |
commit | f49237bfcdfca0ea6e03f8f98d583ee9b7d92875 (patch) | |
tree | baf82d99d6386e5aa8e65cf94f29264039d94460 | |
parent | 496dcc5091e4c79f18ebae514e0e79e44a72993a (diff) | |
parent | 23f963e91fd81f44f6b316b1c24db563354c6be8 (diff) |
Merge tag 'dmaengine-fix-4.11-rc5' of git://git.infradead.org/users/vkoul/slave-dma
Pull dmaengine fixes from Vinod Koul:
"A couple of minor fixes for 4.11:
- array bound fix for __get_unmap_pool()
- cyclic period splitting for bcm2835"
* tag 'dmaengine-fix-4.11-rc5' of git://git.infradead.org/users/vkoul/slave-dma:
dmaengine: Fix array index out of bounds warning in __get_unmap_pool()
dmaengine: bcm2835: Fix cyclic DMA period splitting
-rw-r--r-- | drivers/dma/bcm2835-dma.c | 5 | ||||
-rw-r--r-- | drivers/dma/dmaengine.c | 2 |
2 files changed, 6 insertions, 1 deletions
diff --git a/drivers/dma/bcm2835-dma.c b/drivers/dma/bcm2835-dma.c index e18dc596cf24..6204cc32d09c 100644 --- a/drivers/dma/bcm2835-dma.c +++ b/drivers/dma/bcm2835-dma.c | |||
@@ -251,8 +251,11 @@ static void bcm2835_dma_create_cb_set_length( | |||
251 | */ | 251 | */ |
252 | 252 | ||
253 | /* have we filled in period_length yet? */ | 253 | /* have we filled in period_length yet? */ |
254 | if (*total_len + control_block->length < period_len) | 254 | if (*total_len + control_block->length < period_len) { |
255 | /* update number of bytes in this period so far */ | ||
256 | *total_len += control_block->length; | ||
255 | return; | 257 | return; |
258 | } | ||
256 | 259 | ||
257 | /* calculate the length that remains to reach period_length */ | 260 | /* calculate the length that remains to reach period_length */ |
258 | control_block->length = period_len - *total_len; | 261 | control_block->length = period_len - *total_len; |
diff --git a/drivers/dma/dmaengine.c b/drivers/dma/dmaengine.c index 24e0221fd66d..d9118ec23025 100644 --- a/drivers/dma/dmaengine.c +++ b/drivers/dma/dmaengine.c | |||
@@ -1108,12 +1108,14 @@ static struct dmaengine_unmap_pool *__get_unmap_pool(int nr) | |||
1108 | switch (order) { | 1108 | switch (order) { |
1109 | case 0 ... 1: | 1109 | case 0 ... 1: |
1110 | return &unmap_pool[0]; | 1110 | return &unmap_pool[0]; |
1111 | #if IS_ENABLED(CONFIG_DMA_ENGINE_RAID) | ||
1111 | case 2 ... 4: | 1112 | case 2 ... 4: |
1112 | return &unmap_pool[1]; | 1113 | return &unmap_pool[1]; |
1113 | case 5 ... 7: | 1114 | case 5 ... 7: |
1114 | return &unmap_pool[2]; | 1115 | return &unmap_pool[2]; |
1115 | case 8: | 1116 | case 8: |
1116 | return &unmap_pool[3]; | 1117 | return &unmap_pool[3]; |
1118 | #endif | ||
1117 | default: | 1119 | default: |
1118 | BUG(); | 1120 | BUG(); |
1119 | return NULL; | 1121 | return NULL; |