mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-23 14:25:07 +00:00
For PR411:
This patch replaces the SymbolTable class with ValueSymbolTable which does not support types planes. This means that all symbol names in LLVM must now be unique. The patch addresses the necessary changes to deal with this and removes code no longer needed as a result. This completes the bulk of the changes for this PR. Some cleanup patches will follow. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33918 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -26,8 +26,8 @@
|
||||
#include "llvm/InlineAsm.h"
|
||||
#include "llvm/Instructions.h"
|
||||
#include "llvm/Module.h"
|
||||
#include "llvm/SymbolTable.h"
|
||||
#include "llvm/TypeSymbolTable.h"
|
||||
#include "llvm/ValueSymbolTable.h"
|
||||
#include "llvm/Support/GetElementPtrTypeIterator.h"
|
||||
#include "llvm/Support/Compressor.h"
|
||||
#include "llvm/Support/MathExtras.h"
|
||||
@@ -1144,21 +1144,31 @@ void BytecodeWriter::outputTypeSymbolTable(const TypeSymbolTable &TST) {
|
||||
}
|
||||
}
|
||||
|
||||
void BytecodeWriter::outputValueSymbolTable(const SymbolTable &MST) {
|
||||
void BytecodeWriter::outputValueSymbolTable(const ValueSymbolTable &VST) {
|
||||
// Do not output the Bytecode block for an empty symbol table, it just wastes
|
||||
// space!
|
||||
if (MST.isEmpty()) return;
|
||||
if (VST.empty()) return;
|
||||
|
||||
BytecodeBlock SymTabBlock(BytecodeFormat::ValueSymbolTableBlockID, *this,
|
||||
true/*ElideIfEmpty*/);
|
||||
|
||||
// Now do each of the type planes in order.
|
||||
for (SymbolTable::plane_const_iterator PI = MST.plane_begin(),
|
||||
PE = MST.plane_end(); PI != PE; ++PI) {
|
||||
SymbolTable::value_const_iterator I = MST.value_begin(PI->first);
|
||||
SymbolTable::value_const_iterator End = MST.value_end(PI->first);
|
||||
// Organize the symbol table by type
|
||||
typedef std::pair<std::string, const Value*> PlaneMapEntry;
|
||||
typedef std::vector<PlaneMapEntry> PlaneMapVector;
|
||||
typedef std::map<const Type*, PlaneMapVector > PlaneMap;
|
||||
PlaneMap Planes;
|
||||
for (ValueSymbolTable::const_iterator SI = VST.begin(), SE = VST.end();
|
||||
SI != SE; ++SI)
|
||||
Planes[SI->second->getType()].push_back(
|
||||
std::make_pair(SI->first,SI->second));
|
||||
|
||||
for (PlaneMap::const_iterator PI = Planes.begin(), PE = Planes.end();
|
||||
PI != PE; ++PI) {
|
||||
int Slot;
|
||||
|
||||
PlaneMapVector::const_iterator I = PI->second.begin();
|
||||
PlaneMapVector::const_iterator End = PI->second.end();
|
||||
|
||||
if (I == End) continue; // Don't mess with an absent type...
|
||||
|
||||
// Write the number of values in this plane
|
||||
|
Reference in New Issue
Block a user