summaryrefslogtreecommitdiff
path: root/arch/arm64/mm/init.c
diff options
context:
space:
mode:
authorMark Rutland <mark.rutland@arm.com>2016-03-22 10:11:28 +0000
committerCatalin Marinas <catalin.marinas@arm.com>2016-03-24 16:32:54 +0000
commit691b1e2ebf727167a2e3cdcd1ea0851dee10247b (patch)
tree26293df09c6c48a48f1644fb8d91e33fa7e5b2f1 /arch/arm64/mm/init.c
parentc661cb1c537e2364bfdabb298fb934fd77445e98 (diff)
downloadlwn-691b1e2ebf727167a2e3cdcd1ea0851dee10247b.tar.gz
lwn-691b1e2ebf727167a2e3cdcd1ea0851dee10247b.zip
arm64: mm: allow preemption in copy_to_user_page
Currently we disable preemption in copy_to_user_page; a behaviour that we inherited from the 32-bit arm code. This was necessary for older cores without broadcast data cache maintenance, and ensured that cache lines were dirtied and cleaned by the same CPU. On these systems dirty cache line migration was not possible, so this was sufficient to guarantee coherency. On contemporary systems, cache coherence protocols permit (dirty) cache lines to migrate between CPUs as a result of speculation, prefetching, and other behaviours. To account for this, in ARMv8 data cache maintenance operations are broadcast and affect all data caches in the domain associated with the VA (i.e. ISH for kernel and user mappings). In __switch_to we ensure that tasks can be safely migrated in the middle of a maintenance sequence, using a dsb(ish) to ensure prior explicit memory accesses are observed and cache maintenance operations are completed before a task can be run on another CPU. Given the above, it is not necessary to disable preemption in copy_to_user_page. This patch removes the preempt_{disable,enable} calls, permitting preemption. Signed-off-by: Mark Rutland <mark.rutland@arm.com> Cc: Will Deacon <will.deacon@arm.com> Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
Diffstat (limited to 'arch/arm64/mm/init.c')
0 files changed, 0 insertions, 0 deletions