diff options
author | Craig Topper <craig.topper@gmail.com> | 2012-02-09 07:45:30 +0000 |
---|---|---|
committer | Craig Topper <craig.topper@gmail.com> | 2012-02-09 07:45:30 +0000 |
commit | 487e744f66a11a419e29923ed09cc5f50b650e69 (patch) | |
tree | 175bd8b3c306aebb0311a0e6e6a7ad159cce245b /llvm/lib/Target/X86/Disassembler/X86DisassemblerDecoder.c | |
parent | 5605de7c8b6890be137493998d7aa9709248c65c (diff) | |
download | bcm5719-llvm-487e744f66a11a419e29923ed09cc5f50b650e69.tar.gz bcm5719-llvm-487e744f66a11a419e29923ed09cc5f50b650e69.zip |
Flatten some of the arrays in the X86 disassembler tables to reduce space needed to store pointers on 64-bit hosts and reduce relocations needed at startup. Part of PR11953.
llvm-svn: 150161
Diffstat (limited to 'llvm/lib/Target/X86/Disassembler/X86DisassemblerDecoder.c')
-rw-r--r-- | llvm/lib/Target/X86/Disassembler/X86DisassemblerDecoder.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/llvm/lib/Target/X86/Disassembler/X86DisassemblerDecoder.c b/llvm/lib/Target/X86/Disassembler/X86DisassemblerDecoder.c index 958f653eb73..9a628f2163d 100644 --- a/llvm/lib/Target/X86/Disassembler/X86DisassemblerDecoder.c +++ b/llvm/lib/Target/X86/Disassembler/X86DisassemblerDecoder.c @@ -131,14 +131,13 @@ static InstrUID decode(OpcodeType type, debug("Corrupt table! Unknown modrm_type"); return 0; case MODRM_ONEENTRY: - return dec->instructionIDs[0]; + return modRMTable[dec->instructionIDs]; case MODRM_SPLITRM: if (modFromModRM(modRM) == 0x3) - return dec->instructionIDs[1]; - else - return dec->instructionIDs[0]; + return modRMTable[dec->instructionIDs+1]; + return modRMTable[dec->instructionIDs]; case MODRM_FULL: - return dec->instructionIDs[modRM]; + return modRMTable[dec->instructionIDs+modRM]; } } |