[llvm-commits] [llvm] r152105 - /llvm/trunk/utils/TableGen/AsmWriterEmitter.cpp
Craig Topper
craig.topper at gmail.com
Mon Mar 5 22:04:39 PST 2012
Author: ctopper
Date: Tue Mar 6 00:04:39 2012
New Revision: 152105
URL: http://llvm.org/viewvc/llvm-project?rev=152105&view=rev
Log:
Use uint16_t to store indices into string table since C++ only allows 64K string literals so the index into the big string can never be larger than that.
Modified:
llvm/trunk/utils/TableGen/AsmWriterEmitter.cpp
Modified: llvm/trunk/utils/TableGen/AsmWriterEmitter.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/utils/TableGen/AsmWriterEmitter.cpp?rev=152105&r1=152104&r2=152105&view=diff
==============================================================================
--- llvm/trunk/utils/TableGen/AsmWriterEmitter.cpp (original)
+++ llvm/trunk/utils/TableGen/AsmWriterEmitter.cpp Tue Mar 6 00:04:39 2012
@@ -463,7 +463,7 @@
emitRegisterNameString(raw_ostream &O, StringRef AltName,
const std::vector<CodeGenRegister*> &Registers) {
StringToOffsetTable StringTable;
- O << " static const unsigned RegAsmOffset" << AltName << "[] = {\n ";
+ O << " static const uint16_t RegAsmOffset" << AltName << "[] = {\n ";
for (unsigned i = 0, e = Registers.size(); i != e; ++i) {
const CodeGenRegister &Reg = *Registers[i];
@@ -507,7 +507,7 @@
<< " };\n"
<< "\n";
- O << " const char *AsmStrs" << AltName << " =\n";
+ O << " const char *const AsmStrs" << AltName << " =\n";
StringTable.EmitString(O);
O << ";\n";
}
@@ -541,7 +541,7 @@
emitRegisterNameString(O, "", Registers);
if (hasAltNames) {
- O << " const unsigned *RegAsmOffset;\n"
+ O << " const uint16_t *RegAsmOffset;\n"
<< " const char *AsmStrs;\n"
<< " switch(AltIdx) {\n"
<< " default: llvm_unreachable(\"Invalid register alt name index!\");\n";
@@ -583,7 +583,7 @@
<< " assert(Opcode < " << NumberedInstructions.size()
<< " && \"Invalid instruction number!\");\n"
<< "\n"
- << " static const unsigned InstAsmOffset[] = {";
+ << " static const uint16_t InstAsmOffset[] = {";
for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i) {
const CodeGenInstruction &Inst = *NumberedInstructions[i];
@@ -597,7 +597,7 @@
<< " };\n"
<< "\n";
- O << " const char *Strs =\n";
+ O << " const char *const Strs =\n";
StringTable.EmitString(O);
O << ";\n";
More information about the llvm-commits
mailing list