summaryrefslogtreecommitdiffstats
path: root/Makefile
diff options
context:
space:
mode:
authorDavid Daney <david.daney@cavium.com>2015-08-04 02:48:43 +0200
committerRalf Baechle <ralf@linux-mips.org>2015-08-05 11:11:10 +0200
commit46011e6ea39235e4aca656673c500eac81a07a17 (patch)
tree40c529d5bb47cc8fc7380df3ac4e918fd76852b3 /Makefile
parentMIPS: Replace add and sub instructions in relocate_kernel.S with addiu (diff)
downloadlinux-46011e6ea39235e4aca656673c500eac81a07a17.tar.xz
linux-46011e6ea39235e4aca656673c500eac81a07a17.zip
MIPS: Make set_pte() SMP safe.
On MIPS the GLOBAL bit of the PTE must have the same value in any aligned pair of PTEs. These pairs of PTEs are referred to as "buddies". In a SMP system is is possible for two CPUs to be calling set_pte() on adjacent PTEs at the same time. There is a race between setting the PTE and a different CPU setting the GLOBAL bit in its buddy PTE. This race can be observed when multiple CPUs are executing vmap()/vfree() at the same time. Make setting the buddy PTE's GLOBAL bit an atomic operation to close the race condition. The case of CONFIG_64BIT_PHYS_ADDR && CONFIG_CPU_MIPS32 is *not* handled. Signed-off-by: David Daney <david.daney@cavium.com> Cc: <stable@vger.kernel.org> Cc: linux-mips@linux-mips.org Patchwork: https://patchwork.linux-mips.org/patch/10835/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'Makefile')
0 files changed, 0 insertions, 0 deletions