x86/entry: Use the correct fence macro after swapgs in kernel CR3
[ Upstream commit 1367afaa2ee90d1c956dfc224e199fcb3ff3f8cc ] The commitc758907004
("x86/entry/64: Remove unneeded kernel CR3 switching") removed a CR3 write in the faulting path of load_gs_index(). But the path's FENCE_SWAPGS_USER_ENTRY has no fence operation if PTI is enabled, see spectre_v1_select_mitigation(). Rather, it depended on the serializing CR3 write of SWITCH_TO_KERNEL_CR3 and since it got removed, add a FENCE_SWAPGS_KERNEL_ENTRY call to make sure speculation is blocked. [ bp: Massage commit message and comment. ] Fixes:c758907004
("x86/entry/64: Remove unneeded kernel CR3 switching") Signed-off-by: Lai Jiangshan <laijs@linux.alibaba.com> Signed-off-by: Borislav Petkov <bp@suse.de> Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org> Link: https://lkml.kernel.org/r/20211126101209.8613-3-jiangshanlai@gmail.com Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
c8e3411918
commit
8b9279cad2
@@ -1035,11 +1035,6 @@ SYM_CODE_START_LOCAL(error_entry)
|
|||||||
pushq %r12
|
pushq %r12
|
||||||
ret
|
ret
|
||||||
|
|
||||||
.Lerror_entry_done_lfence:
|
|
||||||
FENCE_SWAPGS_KERNEL_ENTRY
|
|
||||||
.Lerror_entry_done:
|
|
||||||
ret
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* There are two places in the kernel that can potentially fault with
|
* There are two places in the kernel that can potentially fault with
|
||||||
* usergs. Handle them here. B stepping K8s sometimes report a
|
* usergs. Handle them here. B stepping K8s sometimes report a
|
||||||
@@ -1062,8 +1057,14 @@ SYM_CODE_START_LOCAL(error_entry)
|
|||||||
* .Lgs_change's error handler with kernel gsbase.
|
* .Lgs_change's error handler with kernel gsbase.
|
||||||
*/
|
*/
|
||||||
SWAPGS
|
SWAPGS
|
||||||
FENCE_SWAPGS_USER_ENTRY
|
|
||||||
jmp .Lerror_entry_done
|
/*
|
||||||
|
* Issue an LFENCE to prevent GS speculation, regardless of whether it is a
|
||||||
|
* kernel or user gsbase.
|
||||||
|
*/
|
||||||
|
.Lerror_entry_done_lfence:
|
||||||
|
FENCE_SWAPGS_KERNEL_ENTRY
|
||||||
|
ret
|
||||||
|
|
||||||
.Lbstep_iret:
|
.Lbstep_iret:
|
||||||
/* Fix truncated RIP */
|
/* Fix truncated RIP */
|
||||||
|
Reference in New Issue
Block a user