Re: [PATCH v2 1/1] x86/fred: Fix INT80 emulation for FRED
From: H. Peter Anvin
Date: Tue Apr 16 2024 - 14:24:28 EST
On 4/16/24 10:58, Xin Li (Intel) wrote:
Add a FRED-specific INT80 handler fred_int80_emulation().
Commit
55617fb991df ("x86/entry: Do not allow external 0x80 interrupts")
added a bunch of checks to the int $0x80 path, however they are
unnecessary and event wrong in fact under FRED.
I think the following points should be added to the head comment, and
not just the commit log:
1) FRED distinguishes external interrupts from software interrupts,
thus int80_emulation() should NEVER be called for handling an
external interrupt, and then int80_is_external() is meaningless
when FRED is enabled.
1a) As INT instructions and hardware interrupts are separate event
types, FRED does not preclude the use of vector 0x80 for external
interrupts. As a result the FRED setup code does *NOT* reserve vector
0x80 and calling int80_is_external() is not merely suboptimal but
actively incorrect: it could could cause a system call to be incorrectly
ignored.
2) The FRED kernel entry handler NEVER dispatches INTx, which is
of event type EVENT_TYPE_SWINT, so the user mode checking in
do_int80_emulation() is redundant.
3) int80_emulation() does a CLEAR_BRANCH_HISTORY, which is likly
s/likly/likely/
an overkill for new x86 CPU implementations that support FRED.
s/an //
4) int $0x80 is the FAST path for 32-bit system calls under FRED.
[...]
A dedicated FRED INT80 handler duplicates most of the code in
s/most/quite a bit/
(I think there is actually less than half the code left. This could be
further cleaned up by inlining the common code, but if I were still
maintainer I would not want that for x86/urgent. This patch has the very
nice property for x86/urgent purposes that it doesn't touch non-FRED
code at all.)
do_int80_emulation(), but it avoids sprinkling moar tests and
s/moar/more/
seems more readable.
Suggested-by: H. Peter Anvin (Intel) <hpa@xxxxxxxxx>
Signed-off-by: Xin Li (Intel) <xin@xxxxxxxxx>
So, as Borislav pointed out:
Fixes: 55617fb991df ("x86/entry: Do not allow external 0x80 interrupts")
My fault.