]> git.baikalelectronics.ru Git - kernel.git/commit
parisc: Fix lpa and lpa_user defines
authorJohn David Anglin <dave.anglin@bell.net>
Wed, 22 Dec 2021 16:01:31 +0000 (16:01 +0000)
committerHelge Deller <deller@gmx.de>
Fri, 7 Jan 2022 00:29:20 +0000 (01:29 +0100)
commit695a81e21da904c8ff9846e287413b09e4dd031f
tree8db186ad620adca2e96c51ec9fd30cd2e67e534d
parentb64d493f320680554141e9a6027fd7ae00b47087
parisc: Fix lpa and lpa_user defines

While working on the rewrite to the light-weight syscall and futex code, I
experimented with using a hash index based on the user physical address of
atomic variable. This exposed two problems with the lpa and lpa_user defines.

Because of the copy instruction, the pa argument needs to be an early clobber
argument. This prevents gcc from allocating the va and pa arguments to the same
register.

Secondly, the lpa instruction can cause a page fault so we need to catch
exceptions.

Signed-off-by: John David Anglin <dave.anglin@bell.net>
Fixes: 3d356ba9826e ("parisc: Use lpa instruction to load physical addresses in driver code")
Signed-off-by: Helge Deller <deller@gmx.de>
Cc: stable@vger.kernel.org # v5.2+
arch/parisc/include/asm/special_insns.h