提交 3e1a80f1 编写于 作者: L Lennert Buytenhek 提交者: Russell King

[ARM] 4153/1: fix consistent_sync() off-by-one BUG check

In consistent_sync(), start + size can end up pointing one byte
beyond the end of the direct RAM mapping.  We shouldn't BUG() when
this happens.
Signed-off-by: NLennert Buytenhek <buytenh@wantstofly.org>
Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
上级 7ae5a761
...@@ -485,7 +485,7 @@ void consistent_sync(const void *start, size_t size, int direction) ...@@ -485,7 +485,7 @@ void consistent_sync(const void *start, size_t size, int direction)
{ {
const void *end = start + size; const void *end = start + size;
BUG_ON(!virt_addr_valid(start) || !virt_addr_valid(end)); BUG_ON(!virt_addr_valid(start) || !virt_addr_valid(end - 1));
switch (direction) { switch (direction) {
case DMA_FROM_DEVICE: /* invalidate only */ case DMA_FROM_DEVICE: /* invalidate only */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册