提交 ca57926d 编写于 作者: C Catalin Marinas 提交者: Russell King

ARM: 6187/1: The v6_dma_inv_range() function must preserve data on SMP

A recent patch for DMA cache maintenance on ARM11MPCore added a write
for ownership trick to the v6_dma_inv_range() function. Such operation
destroys data already present in the buffer. However, this function is
used with with dma_sync_single_for_device() which is supposed to
preserve the existing data transfered into the buffer. This patch adds a
combination of read/write for ownership to preserve the original data.
Reported-by: NRonen Shitrit <rshitrit@marvell.com>
Signed-off-by: NCatalin Marinas <catalin.marinas@arm.com>
Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
上级 a5e9d38b
...@@ -212,7 +212,8 @@ v6_dma_inv_range: ...@@ -212,7 +212,8 @@ v6_dma_inv_range:
#endif #endif
1: 1:
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
str r0, [r0] @ write for ownership ldr r2, [r0] @ read for ownership
str r2, [r0] @ write for ownership
#endif #endif
#ifdef HARVARD_CACHE #ifdef HARVARD_CACHE
mcr p15, 0, r0, c7, c6, 1 @ invalidate D line mcr p15, 0, r0, c7, c6, 1 @ invalidate D line
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册