[<prev] [next>] [day] [month] [year] [list]
Message-ID: <20251106175320.2745006-1-david.kaplan@amd.com>
Date: Thu, 6 Nov 2025 11:53:20 -0600
From: David Kaplan <david.kaplan@....com>
To: Peter Zijlstra <peterz@...radead.org>, Josh Poimboeuf
<jpoimboe@...nel.org>, Jason Baron <jbaron@...mai.com>, Steven Rostedt
<rostedt@...dmis.org>, Ard Biesheuvel <ardb@...nel.org>, Thomas Gleixner
<tglx@...utronix.de>, Ingo Molnar <mingo@...hat.com>, Borislav Petkov
<bp@...en8.de>, Dave Hansen <dave.hansen@...ux.intel.com>, <x86@...nel.org>,
"H. Peter Anvin" <hpa@...or.com>
CC: <linux-kernel@...r.kernel.org>
Subject: [PATCH] x86/static_call: Remove text_mutex from __static_call_fixup()
__static_call_fixup() is only called from apply_returns() which modifies
text either on boot when only one CPU is active, or on module load. In
both cases, it does not modify live code. This is why this function passes
'true' for the modinit argument to __static_call_transform() which causes
__static_call_transform() to use text_poke_early().
text_poke_early() does not require that the text_mutex is held, as this
function is only used when free of any races with other CPUs. Therefore
__static_call_fixup() does not need to take the mutex so remove it.
Signed-off-by: David Kaplan <david.kaplan@....com>
---
arch/x86/kernel/static_call.c | 2 --
1 file changed, 2 deletions(-)
diff --git a/arch/x86/kernel/static_call.c b/arch/x86/kernel/static_call.c
index 378c388d1b31..748fc98d416f 100644
--- a/arch/x86/kernel/static_call.c
+++ b/arch/x86/kernel/static_call.c
@@ -212,10 +212,8 @@ bool __static_call_fixup(void *tramp, u8 op, void *dest)
return false;
}
- mutex_lock(&text_mutex);
if (op == RET_INSN_OPCODE || dest == &__x86_return_thunk)
__static_call_transform(tramp, RET, NULL, true);
- mutex_unlock(&text_mutex);
return true;
}
base-commit: 8411fdb92360d0b4d3337492a25ee2de7fb6c425
--
2.34.1
Powered by blists - more mailing lists