diff options
| author | Chris Lattner <sabre@nondot.org> | 2010-02-12 01:15:16 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2010-02-12 01:15:16 +0000 |
| commit | 336f9abb456cbb39b263bc9647c9890550485fad (patch) | |
| tree | 6d0cb743271321840689f596431f5b90c6a7cc73 /llvm | |
| parent | c780af64713705524517601ea43357d92cf2ce94 (diff) | |
| download | bcm5719-llvm-336f9abb456cbb39b263bc9647c9890550485fad.tar.gz bcm5719-llvm-336f9abb456cbb39b263bc9647c9890550485fad.zip | |
add another bit of space for new kinds of instruction prefixes.
llvm-svn: 95949
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Target/X86/X86.td | 6 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86InstrInfo.h | 14 |
2 files changed, 10 insertions, 10 deletions
diff --git a/llvm/lib/Target/X86/X86.td b/llvm/lib/Target/X86/X86.td index 7919559058b..a8f735b0ee9 100644 --- a/llvm/lib/Target/X86/X86.td +++ b/llvm/lib/Target/X86/X86.td @@ -168,11 +168,11 @@ def X86InstrInfo : InstrInfo { 6, 7, 8, - 12, 13, - 16, - 19, + 14, + 17, 20, + 21, 24]; } diff --git a/llvm/lib/Target/X86/X86InstrInfo.h b/llvm/lib/Target/X86/X86InstrInfo.h index a6b38637f50..7bd3e4f1cab 100644 --- a/llvm/lib/Target/X86/X86InstrInfo.h +++ b/llvm/lib/Target/X86/X86InstrInfo.h @@ -291,7 +291,7 @@ namespace X86II { // set, there is no prefix byte for obtaining a multibyte opcode. // Op0Shift = 8, - Op0Mask = 0xF << Op0Shift, + Op0Mask = 0x1F << Op0Shift, // TB - TwoByte - Set if this instruction has a two byte opcode, which // starts with a 0x0F byte before the real opcode. @@ -324,13 +324,13 @@ namespace X86II { // etc. We only cares about REX.W and REX.R bits and only the former is // statically determined. // - REXShift = 12, + REXShift = 13, REX_W = 1 << REXShift, //===------------------------------------------------------------------===// // This three-bit field describes the size of an immediate operand. Zero is // unused so that we can tell if we forgot to set a value. - ImmShift = 13, + ImmShift = 14, ImmMask = 7 << ImmShift, Imm8 = 1 << ImmShift, Imm16 = 2 << ImmShift, @@ -341,7 +341,7 @@ namespace X86II { // FP Instruction Classification... Zero is non-fp instruction. // FPTypeMask - Mask for all of the FP types... - FPTypeShift = 16, + FPTypeShift = 17, FPTypeMask = 7 << FPTypeShift, // NotFP - The default, set for instructions that do not use FP registers. @@ -374,17 +374,17 @@ namespace X86II { SpecialFP = 7 << FPTypeShift, // Lock prefix - LOCKShift = 19, + LOCKShift = 20, LOCK = 1 << LOCKShift, // Segment override prefixes. Currently we just need ability to address // stuff in gs and fs segments. - SegOvrShift = 20, + SegOvrShift = 21, SegOvrMask = 3 << SegOvrShift, FS = 1 << SegOvrShift, GS = 2 << SegOvrShift, - // Bits 22 -> 23 are unused + // Bit 23 is unused. OpcodeShift = 24, OpcodeMask = 0xFF << OpcodeShift }; |

