]> git.baikalelectronics.ru Git - kernel.git/commit
parisc: fix race condition in patching code
authorSven Schnelle <svens@stackframe.org>
Tue, 23 Jul 2019 20:37:54 +0000 (22:37 +0200)
committerHelge Deller <deller@gmx.de>
Wed, 31 Jul 2019 14:20:57 +0000 (16:20 +0200)
commit2134d0d5dbc07c3ccd24fadffe3bdd9d67b10dd6
tree7177aaf87236e725de630783278873059f41d023
parent49a5c7adda5a7f497c4487b41f7c08e014b63481
parisc: fix race condition in patching code

Assume the following ftrace code sequence that was patched in earlier by
ftrace_make_call():

PAGE A:
ffc: addr of ftrace_caller()
PAGE B:
000: 0x6fc10080 /* stw,ma r1,40(sp) */
004: 0x48213fd1 /* ldw -18(r1),r1 */
008: 0xe820c002 /* bv,n r0(r1) */
00c: 0xe83f1fdf /* b,l,n .-c,r1 */

When a Code sequences that is to be patched spans a page break, we might
have already cleared the part on the PAGE A. If an interrupt is coming in
during the remap of the fixed mapping to PAGE B, it might execute the
patched function with only parts of the FTRACE code cleared. To prevent
this, clear the jump to our mini trampoline first, and clear the remaining
parts after this. This might also happen when patch_text() patches a
function that it calls during remap.

Signed-off-by: Sven Schnelle <svens@stackframe.org>
Cc: <stable@vger.kernel.org> # 5.2+
Signed-off-by: Helge Deller <deller@gmx.de>
arch/parisc/kernel/ftrace.c