mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	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.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@150161 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -78,7 +78,7 @@ | ||||
|   const char*             name; | ||||
|  | ||||
| #define INSTRUCTION_IDS               \ | ||||
|   const InstrUID *instructionIDs; | ||||
|   unsigned instructionIDs; | ||||
|  | ||||
| #include "X86DisassemblerDecoderCommon.h" | ||||
|  | ||||
|   | ||||
| @@ -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]; | ||||
|   } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -24,7 +24,7 @@ extern "C" { | ||||
|   const char*             name; | ||||
|  | ||||
| #define INSTRUCTION_IDS     \ | ||||
|   const InstrUID *instructionIDs; | ||||
|   unsigned instructionIDs; | ||||
|  | ||||
| #include "X86DisassemblerDecoderCommon.h" | ||||
|    | ||||
|   | ||||
| @@ -196,8 +196,7 @@ void DisassemblerTables::emitOneID(raw_ostream &o, | ||||
| /// @param i        - The indentation level for that output stream. | ||||
| static void emitEmptyTable(raw_ostream &o, uint32_t &i) | ||||
| { | ||||
|   o.indent(i * 2) << "static const InstrUID modRMEmptyTable[1] = { 0 };\n"; | ||||
|   o << "\n"; | ||||
|   o.indent(i * 2) << "0x0, /* EmptyTable */\n"; | ||||
| } | ||||
|  | ||||
| /// getDecisionType - Determines whether a ModRM decision with 255 entries can | ||||
| @@ -293,71 +292,67 @@ void DisassemblerTables::emitModRMDecision(raw_ostream &o1, | ||||
|                                            ModRMDecision &decision) | ||||
|   const { | ||||
|   static uint64_t sTableNumber = 0; | ||||
|   uint64_t thisTableNumber = sTableNumber; | ||||
|   static uint64_t sEntryNumber = 1; | ||||
|   ModRMDecisionType dt = getDecisionType(decision); | ||||
|   uint16_t index; | ||||
|    | ||||
|  | ||||
|   if (dt == MODRM_ONEENTRY && decision.instructionIDs[0] == 0) | ||||
|   { | ||||
|     o2.indent(i2) << "{ /* ModRMDecision */" << "\n"; | ||||
|     i2++; | ||||
|      | ||||
|  | ||||
|     o2.indent(i2) << stringForDecisionType(dt) << "," << "\n"; | ||||
|     o2.indent(i2) << "modRMEmptyTable"; | ||||
|      | ||||
|     o2.indent(i2) << 0 << " /* EmptyTable */\n"; | ||||
|  | ||||
|     i2--; | ||||
|     o2.indent(i2) << "}"; | ||||
|     return; | ||||
|   } | ||||
|      | ||||
|   o1.indent(i1) << "static const InstrUID modRMTable" << thisTableNumber; | ||||
|      | ||||
|   switch (dt) { | ||||
|     default: | ||||
|       llvm_unreachable("Unknown decision type"); | ||||
|     case MODRM_ONEENTRY: | ||||
|       o1 << "[1]"; | ||||
|       break; | ||||
|     case MODRM_SPLITRM: | ||||
|       o1 << "[2]"; | ||||
|       break; | ||||
|     case MODRM_FULL: | ||||
|       o1 << "[256]"; | ||||
|       break;       | ||||
|   } | ||||
|  | ||||
|   o1 << " = {" << "\n"; | ||||
|   o1 << "/* Table" << sTableNumber << " */\n"; | ||||
|   i1++; | ||||
|      | ||||
|  | ||||
|   switch (dt) { | ||||
|     default: | ||||
|       llvm_unreachable("Unknown decision type"); | ||||
|     case MODRM_ONEENTRY: | ||||
|       emitOneID(o1, i1, decision.instructionIDs[0], false); | ||||
|       emitOneID(o1, i1, decision.instructionIDs[0], true); | ||||
|       break; | ||||
|     case MODRM_SPLITRM: | ||||
|       emitOneID(o1, i1, decision.instructionIDs[0x00], true); // mod = 0b00 | ||||
|       emitOneID(o1, i1, decision.instructionIDs[0xc0], false); // mod = 0b11 | ||||
|       emitOneID(o1, i1, decision.instructionIDs[0xc0], true); // mod = 0b11 | ||||
|       break; | ||||
|     case MODRM_FULL: | ||||
|       for (index = 0; index < 256; ++index) | ||||
|         emitOneID(o1, i1, decision.instructionIDs[index], index < 255); | ||||
|         emitOneID(o1, i1, decision.instructionIDs[index], true); | ||||
|       break; | ||||
|   } | ||||
|      | ||||
|  | ||||
|   i1--; | ||||
|   o1.indent(i1) << "};" << "\n"; | ||||
|   o1 << "\n"; | ||||
|      | ||||
|  | ||||
|   o2.indent(i2) << "{ /* struct ModRMDecision */" << "\n"; | ||||
|   i2++; | ||||
|      | ||||
|  | ||||
|   o2.indent(i2) << stringForDecisionType(dt) << "," << "\n"; | ||||
|   o2.indent(i2) << "modRMTable" << sTableNumber << "\n"; | ||||
|      | ||||
|   o2.indent(i2) << sEntryNumber << " /* Table" << sTableNumber << " */\n"; | ||||
|  | ||||
|   i2--; | ||||
|   o2.indent(i2) << "}"; | ||||
|      | ||||
|  | ||||
|   switch (dt) { | ||||
|     default: | ||||
|       llvm_unreachable("Unknown decision type"); | ||||
|     case MODRM_ONEENTRY: | ||||
|       sEntryNumber += 1; | ||||
|       break; | ||||
|     case MODRM_SPLITRM: | ||||
|       sEntryNumber += 2; | ||||
|       break; | ||||
|     case MODRM_FULL: | ||||
|       sEntryNumber += 256; | ||||
|       break; | ||||
|   } | ||||
|  | ||||
|   ++sTableNumber; | ||||
| } | ||||
|  | ||||
| @@ -598,11 +593,16 @@ void DisassemblerTables::emit(raw_ostream &o) const { | ||||
|  | ||||
|   emitContextTable(o, i2); | ||||
|   o << "\n"; | ||||
|    | ||||
|  | ||||
|   o << "static const InstrUID modRMTable[] = {\n"; | ||||
|   i1++; | ||||
|   emitEmptyTable(o1, i1); | ||||
|   i1--; | ||||
|   emitContextDecisions(o1, o2, i1, i2); | ||||
|    | ||||
|  | ||||
|   o << o1.str(); | ||||
|   o << "  0x0\n"; | ||||
|   o << "};\n"; | ||||
|   o << "\n"; | ||||
|   o << o2.str(); | ||||
|   o << "\n"; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user