Commit d8fbf4f1 authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] ARM-related ptep_to_address() fix

From: William Lee Irwin III <wli@holomorphy.com>

rmk mentioned that ARM was borked as the relation, assumed by generic rmap,
PTRS_PER_PTE*sizeof(pte_t) == PAGE_SIZE, fails to hold.  The following
patch, developed jointly with him (or depending on POV, by him with me
acting as codemonkey), is reported to resolve the issue.

Specifically, while ARM dedicates an entire PAGE_SIZE -sized block of
memory to each PTE table, the PTE table itself only spans half that, the
remainder being dedicated to hardware-interpreted structures.  As the
hardware structure must be contiguous, wider ptes can't be used.  So the
core-visible PTE table only spans PAGE_SIZE/2 bytes, violating the
assumption.  This corrects masking and scaling done in ptep_to_address().
parent 5450c6c1
...@@ -57,7 +57,8 @@ static inline unsigned long ptep_to_address(pte_t * ptep) ...@@ -57,7 +57,8 @@ static inline unsigned long ptep_to_address(pte_t * ptep)
{ {
struct page * page = kmap_atomic_to_page(ptep); struct page * page = kmap_atomic_to_page(ptep);
unsigned long low_bits; unsigned long low_bits;
low_bits = ((unsigned long)ptep & ~PAGE_MASK) * PTRS_PER_PTE; low_bits = ((unsigned long)ptep & (PTRS_PER_PTE*sizeof(pte_t) - 1))
* (PAGE_SIZE/sizeof(pte_t));
return page->index + low_bits; return page->index + low_bits;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment