mirror of https://github.com/torvalds/linux.git
Core x86 changes for v6.19:
- x86/alternatives: Drop unnecessary test after call to
alt_replace_call() (Juergen Gross)
- x86/dumpstack: Prevent KASAN false positive warnings in
__show_regs() (Tengda Wu)
Signed-off-by: Ingo Molnar <mingo@kernel.org>
-----BEGIN PGP SIGNATURE-----
iQJFBAABCgAvFiEEBpT5eoXrXCwVQwEKEnMQ0APhK1gFAmktetMRHG1pbmdvQGtl
cm5lbC5vcmcACgkQEnMQ0APhK1jLBRAAluu/0ACAzh1A5gw6Mr9uQ45KFxCt4HZa
gjIyfDNqsdb6fqJ3yFAzw36gYViIzEGZo26S0mGWXqLVmMHus2HqvHTxYCPA7mov
YfMxMUKsyTIaDoGHOYuhHwwdJL+KzXuKQri5/5MVbxNPPYedk4qV4weTTDPz/pkV
biYOw6S4GDsOC5O1RT1AX+NBcIZkQzqoTSnkCXjDSCxXpVxYg7CQ6besMtkCCArZ
QMl5ZCh6cEhhyOXIVL1Huz9pxxWpzxXM0oqNzhBjCjijYN5HGxL5kUv9tWHatP8h
Q5SFnhyhPu/GtzZUw32O5r7sC93HweJeUtvaE0ekTSMK8A/oIwBup3Z4pRGpY/A2
B16VAYSEYzoJEUmptPkHTbOouKMR45P02M0RM5rkojeh75LRivW6T0Zd1+LkEXJr
yVwWfr+DoXaTtyK1GYdQNbwEWjpIxUwcBtVZN2h3Ajo28yPwB6Eh0mHUpl1Yol83
Ex5XL9lsCljIkmDTup+6ai9fyVpsRUbLANnBZ76DiRRw44vUto/Dj8pkIOysZ/8/
K/zVxou2KFtIDB/oFOIc1AIEjenq6IXqLhyKoerm2c0cALH67KUsFmHTH8/6hbUV
WLWtROB9tLizBBE7Xo4uu1LkmIMWVZ8nHbX/QYQSQBv2Nhw29a681JaHjVgRYBIJ
K97PRgZS6dM=
=i6oY
-----END PGP SIGNATURE-----
Merge tag 'x86-core-2025-12-01' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull core x86 updates from Ingo Molnar:
- x86/alternatives: Drop unnecessary test after call to
alt_replace_call() (Juergen Gross)
- x86/dumpstack: Prevent KASAN false positive warnings in
__show_regs() (Tengda Wu)
* tag 'x86-core-2025-12-01' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
x86/dumpstack: Prevent KASAN false positive warnings in __show_regs()
x86/alternative: Drop not needed test after call of alt_replace_call()
This commit is contained in:
commit
dcd8637edb
|
|
@ -541,7 +541,7 @@ EXPORT_SYMBOL(BUG_func);
|
|||
* Rewrite the "call BUG_func" replacement to point to the target of the
|
||||
* indirect pv_ops call "call *disp(%ip)".
|
||||
*/
|
||||
static int alt_replace_call(u8 *instr, u8 *insn_buff, struct alt_instr *a)
|
||||
static unsigned int alt_replace_call(u8 *instr, u8 *insn_buff, struct alt_instr *a)
|
||||
{
|
||||
void *target, *bug = &BUG_func;
|
||||
s32 disp;
|
||||
|
|
@ -625,7 +625,7 @@ void __init_or_module noinline apply_alternatives(struct alt_instr *start,
|
|||
* order.
|
||||
*/
|
||||
for (a = start; a < end; a++) {
|
||||
int insn_buff_sz = 0;
|
||||
unsigned int insn_buff_sz = 0;
|
||||
|
||||
/*
|
||||
* In case of nested ALTERNATIVE()s the outer alternative might
|
||||
|
|
@ -665,11 +665,8 @@ void __init_or_module noinline apply_alternatives(struct alt_instr *start,
|
|||
memcpy(insn_buff, replacement, a->replacementlen);
|
||||
insn_buff_sz = a->replacementlen;
|
||||
|
||||
if (a->flags & ALT_FLAG_DIRECT_CALL) {
|
||||
if (a->flags & ALT_FLAG_DIRECT_CALL)
|
||||
insn_buff_sz = alt_replace_call(instr, insn_buff, a);
|
||||
if (insn_buff_sz < 0)
|
||||
continue;
|
||||
}
|
||||
|
||||
for (; insn_buff_sz < a->instrlen; insn_buff_sz++)
|
||||
insn_buff[insn_buff_sz] = 0x90;
|
||||
|
|
|
|||
|
|
@ -181,8 +181,8 @@ static void show_regs_if_on_stack(struct stack_info *info, struct pt_regs *regs,
|
|||
* in false positive reports. Disable instrumentation to avoid those.
|
||||
*/
|
||||
__no_kmsan_checks
|
||||
static void show_trace_log_lvl(struct task_struct *task, struct pt_regs *regs,
|
||||
unsigned long *stack, const char *log_lvl)
|
||||
static void __show_trace_log_lvl(struct task_struct *task, struct pt_regs *regs,
|
||||
unsigned long *stack, const char *log_lvl)
|
||||
{
|
||||
struct unwind_state state;
|
||||
struct stack_info stack_info = {0};
|
||||
|
|
@ -303,6 +303,25 @@ static void show_trace_log_lvl(struct task_struct *task, struct pt_regs *regs,
|
|||
}
|
||||
}
|
||||
|
||||
static void show_trace_log_lvl(struct task_struct *task, struct pt_regs *regs,
|
||||
unsigned long *stack, const char *log_lvl)
|
||||
{
|
||||
/*
|
||||
* Disable KASAN to avoid false positives during walking another
|
||||
* task's stacks, as values on these stacks may change concurrently
|
||||
* with task execution.
|
||||
*/
|
||||
bool disable_kasan = task && task != current;
|
||||
|
||||
if (disable_kasan)
|
||||
kasan_disable_current();
|
||||
|
||||
__show_trace_log_lvl(task, regs, stack, log_lvl);
|
||||
|
||||
if (disable_kasan)
|
||||
kasan_enable_current();
|
||||
}
|
||||
|
||||
void show_stack(struct task_struct *task, unsigned long *sp,
|
||||
const char *loglvl)
|
||||
{
|
||||
|
|
|
|||
Loading…
Reference in New Issue