diff options
author | Jan Beulich <jbeulich@suse.com> | 2023-11-09 12:54:58 +0100 |
---|---|---|
committer | Jan Beulich <jbeulich@suse.com> | 2023-11-09 12:54:58 +0100 |
commit | a5e91879d14fd5f2e477e556e629e1b8e06359a6 (patch) | |
tree | 621b421fd9d9002f8c865a55ec5797062f7505da /include/environ.h | |
parent | 3e624fa4b870f90c8f5c31ad533b3abc4a4bfa93 (diff) | |
download | gdb-a5e91879d14fd5f2e477e556e629e1b8e06359a6.zip gdb-a5e91879d14fd5f2e477e556e629e1b8e06359a6.tar.gz gdb-a5e91879d14fd5f2e477e556e629e1b8e06359a6.tar.bz2 |
x86: split insn templates' CPU field
Right now the opcode table has entries with ISA restrictions of the form
FEAT1|FEAT2, the meaning of which depends on context and requires
special treatment in tc-i386.c: Sometimes this means "both features
requires", whereas originally it was intended to solely mean "all of
these features required". Split the field, with the original one
regaining its original meaning. The new field now truly means "any of
these". The combination of both fields is still and &&-type check, i.e.
(all of these) && (any of these). In the opcode table more involved
combinations of features then also need expressing this way: "all"
entities first, follow by "any" entities enclosed in parentheses, e.g.
x64&(AVX|AVX512F). If the "all" part is empty, parentheses may not be
added around the "any" part (unless parsing logic was further relaxed).
Note that this way AVX512VL no longer needs as much special treatment,
and hence templates previously using AVX512F|AVX512VL are switched to
just AVX512VL.
Note further that this requires FMA handling as resulting from
da0784f961d8 ("x86: fold FMA VEX and EVEX templates") to be slightly
re-done: FMA now becomes more similar to AVX and AVX2.
Diffstat (limited to 'include/environ.h')
0 files changed, 0 insertions, 0 deletions