summaryrefslogtreecommitdiffstats
path: root/arch/arm/mm
diff options
context:
space:
mode:
authorSteven Capper <steve.capper@linaro.org>2014-07-18 17:15:27 +0200
committerRussell King <rmk+kernel@arm.linux.org.uk>2014-07-24 15:27:07 +0200
commitf2950706871c4b6e8c0f0d7c3f62d35930b8de63 (patch)
treea76e0ebc8a16e6384b3b28d4777ca68335f496f3 /arch/arm/mm
parentARM: 8103/1: save/restore Cortex-A9 CP15 registers on suspend/resume (diff)
downloadlinux-f2950706871c4b6e8c0f0d7c3f62d35930b8de63.tar.xz
linux-f2950706871c4b6e8c0f0d7c3f62d35930b8de63.zip
ARM: 8108/1: mm: Introduce {pte,pmd}_isset and {pte,pmd}_isclear
Long descriptors on ARM are 64 bits, and some pte functions such as pte_dirty return a bitwise-and of a flag with the pte value. If the flag to be tested resides in the upper 32 bits of the pte, then we run into the danger of the result being dropped if downcast. For example: gather_stats(page, md, pte_dirty(*pte), 1); where pte_dirty(*pte) is downcast to an int. This patch introduces a new macro pte_isset which performs the bitwise and, then performs a double logical invert (where needed) to ensure predictable downcasting. The logical inverse pte_isclear is also introduced. Equivalent pmd functions for Transparent HugePages have also been added. Signed-off-by: Steve Capper <steve.capper@linaro.org> Reviewed-by: Will Deacon <will.deacon@arm.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/mm')
0 files changed, 0 insertions, 0 deletions