diff options
| -rw-r--r-- | drivers/dma/dw_dmac.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/drivers/dma/dw_dmac.c b/drivers/dma/dw_dmac.c index 9ca9ca41b83e..c4b0eb3cde81 100644 --- a/drivers/dma/dw_dmac.c +++ b/drivers/dma/dw_dmac.c | |||
| @@ -716,6 +716,7 @@ dwc_prep_dma_memcpy(struct dma_chan *chan, dma_addr_t dest, dma_addr_t src, | |||
| 716 | size_t offset; | 716 | size_t offset; |
| 717 | unsigned int src_width; | 717 | unsigned int src_width; |
| 718 | unsigned int dst_width; | 718 | unsigned int dst_width; |
| 719 | unsigned int data_width; | ||
| 719 | u32 ctllo; | 720 | u32 ctllo; |
| 720 | 721 | ||
| 721 | dev_vdbg(chan2dev(chan), | 722 | dev_vdbg(chan2dev(chan), |
| @@ -728,11 +729,11 @@ dwc_prep_dma_memcpy(struct dma_chan *chan, dma_addr_t dest, dma_addr_t src, | |||
| 728 | return NULL; | 729 | return NULL; |
| 729 | } | 730 | } |
| 730 | 731 | ||
| 731 | src_width = min_t(unsigned int, dwc->dw->data_width[dwc_get_sms(dws)], | 732 | data_width = min_t(unsigned int, dwc->dw->data_width[dwc_get_sms(dws)], |
| 732 | dwc_fast_fls(src | len)); | 733 | dwc->dw->data_width[dwc_get_dms(dws)]); |
| 733 | 734 | ||
| 734 | dst_width = min_t(unsigned int, dwc->dw->data_width[dwc_get_dms(dws)], | 735 | src_width = dst_width = min_t(unsigned int, data_width, |
| 735 | dwc_fast_fls(dest | len)); | 736 | dwc_fast_fls(src | dest | len)); |
| 736 | 737 | ||
| 737 | ctllo = DWC_DEFAULT_CTLLO(chan) | 738 | ctllo = DWC_DEFAULT_CTLLO(chan) |
| 738 | | DWC_CTLL_DST_WIDTH(dst_width) | 739 | | DWC_CTLL_DST_WIDTH(dst_width) |
