diff options
author | Adrian Hunter <adrian.hunter@intel.com> | 2024-05-02 13:58:50 +0300 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2024-05-02 13:13:45 +0200 |
commit | 87bbaf1a4be4904fcf04a024e7c1d9f9d1fa945b (patch) | |
tree | caefeb3858545b5ea88eacc72b98f6e812e0d531 /tools/arch/x86/include/asm/insn.h | |
parent | 159039af8c074a14545fd695c38d2772b3c98b12 (diff) | |
download | linux-87bbaf1a4be4904fcf04a024e7c1d9f9d1fa945b.tar.gz linux-87bbaf1a4be4904fcf04a024e7c1d9f9d1fa945b.tar.bz2 linux-87bbaf1a4be4904fcf04a024e7c1d9f9d1fa945b.zip |
x86/insn: Add support for APX EVEX to the instruction decoder logic
Intel Advanced Performance Extensions (APX) extends the EVEX prefix to
support:
- extended general purpose registers (EGPRs) i.e. r16 to r31
- Push-Pop Acceleration (PPX) hints
- new data destination (NDD) register
- suppress status flags writes (NF) of common instructions
- new instructions
Refer to the Intel Advanced Performance Extensions (Intel APX) Architecture
Specification for details.
The extended EVEX prefix does not need amended instruction decoder logic,
except in one area. Some instructions are defined as SCALABLE which means
the EVEX.W bit and EVEX.pp bits are used to determine operand size.
Specifically, if an instruction is SCALABLE and EVEX.W is zero, then
EVEX.pp value 0 (representing no prefix NP) means default operand size,
whereas EVEX.pp value 1 (representing 66 prefix) means operand size
override i.e. 16 bits
Add an attribute (INAT_EVEX_SCALABLE) to identify such instructions, and
amend the logic appropriately.
Amend the awk script that generates the attribute tables from the opcode
map, to recognise "(es)" as attribute INAT_EVEX_SCALABLE.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Link: https://lore.kernel.org/r/20240502105853.5338-8-adrian.hunter@intel.com
Diffstat (limited to 'tools/arch/x86/include/asm/insn.h')
-rw-r--r-- | tools/arch/x86/include/asm/insn.h | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/tools/arch/x86/include/asm/insn.h b/tools/arch/x86/include/asm/insn.h index 1a7e8fc4d75a..0e5abd896ad4 100644 --- a/tools/arch/x86/include/asm/insn.h +++ b/tools/arch/x86/include/asm/insn.h @@ -215,6 +215,13 @@ static inline insn_byte_t insn_vex_p_bits(struct insn *insn) return X86_VEX_P(insn->vex_prefix.bytes[2]); } +static inline insn_byte_t insn_vex_w_bit(struct insn *insn) +{ + if (insn->vex_prefix.nbytes < 3) + return 0; + return X86_VEX_W(insn->vex_prefix.bytes[2]); +} + /* Get the last prefix id from last prefix or VEX prefix */ static inline int insn_last_prefix_id(struct insn *insn) { |