Commit b61ec8d0 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'x86_urgent_for_v6.6-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip

Pull x86 rethunk fixes from Borislav Petkov:
 "Fix the patching ordering between static calls and return thunks"

* tag 'x86_urgent_for_v6.6-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
  x86,static_call: Fix static-call vs return-thunk
  x86/alternatives: Remove faulty optimization
parents e583bffe aee9d30b
...@@ -720,13 +720,8 @@ void __init_or_module noinline apply_returns(s32 *start, s32 *end) ...@@ -720,13 +720,8 @@ void __init_or_module noinline apply_returns(s32 *start, s32 *end)
{ {
s32 *s; s32 *s;
/* if (cpu_feature_enabled(X86_FEATURE_RETHUNK))
* Do not patch out the default return thunks if those needed are the static_call_force_reinit();
* ones generated by the compiler.
*/
if (cpu_feature_enabled(X86_FEATURE_RETHUNK) &&
(x86_return_thunk == __x86_return_thunk))
return;
for (s = start; s < end; s++) { for (s = start; s < end; s++) {
void *dest = NULL, *addr = (void *)s + *s; void *dest = NULL, *addr = (void *)s + *s;
......
...@@ -272,7 +272,6 @@ void __init callthunks_patch_builtin_calls(void) ...@@ -272,7 +272,6 @@ void __init callthunks_patch_builtin_calls(void)
pr_info("Setting up call depth tracking\n"); pr_info("Setting up call depth tracking\n");
mutex_lock(&text_mutex); mutex_lock(&text_mutex);
callthunks_setup(&cs, &builtin_coretext); callthunks_setup(&cs, &builtin_coretext);
static_call_force_reinit();
thunks_initialized = true; thunks_initialized = true;
mutex_unlock(&text_mutex); mutex_unlock(&text_mutex);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment