diff options
| author | Kuninori Morimoto <[email protected]> | 2017-11-17 11:00:28 +0900 | 
|---|---|---|
| committer | Vinod Koul <[email protected]> | 2017-11-29 19:42:57 +0530 | 
| commit | a8d46a7f5d17ca9cbe9e9c7d1d23dc6ea437e141 (patch) | |
| tree | dccacc000a57e194a089d4bb2ccc0a693fca0c5f /lib/test_fortify/write_overflow-strcpy.c | |
| parent | 4fbd8d194f06c8a3fd2af1ce560ddb31f7ec8323 (diff) | |
dmaengine: rcar-dmac: ensure CHCR DE bit is actually 0 after clearing
DMAC reads data from source device, and buffered it until transferable
size for sink device. Because of this behavior, DMAC is including
buffered data .
Now, CHCR DE bit is controlling DMA transfer enable/disable.
If DE bit was cleared during data transferring, or during buffering,
it will flush buffered data if source device was peripheral device
(The buffered data will be removed if source device was memory).
Because of this behavior, driver should ensure that DE bit is actually
0 after clearing.
This patch adds new rcar_dmac_chcr_de_barrier() and call it after CHCR
register access.
Signed-off-by: Kuninori Morimoto <[email protected]>
Tested-by: Hiroyuki Yokoyama <[email protected]>
Tested-by: Ryo Kodama <[email protected]>
Tested-by: Geert Uytterhoeven <[email protected]>
Signed-off-by: Vinod Koul <[email protected]>
Diffstat (limited to 'lib/test_fortify/write_overflow-strcpy.c')
0 files changed, 0 insertions, 0 deletions