aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Bytecode
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Bytecode')
-rw-r--r--lib/Bytecode/Writer/SlotCalculator.h45
1 files changed, 40 insertions, 5 deletions
diff --git a/lib/Bytecode/Writer/SlotCalculator.h b/lib/Bytecode/Writer/SlotCalculator.h
index fbd0976..105e585 100644
--- a/lib/Bytecode/Writer/SlotCalculator.h
+++ b/lib/Bytecode/Writer/SlotCalculator.h
@@ -22,6 +22,7 @@
#include <vector>
#include <map>
+#include <cassert>
namespace llvm {
@@ -53,22 +54,50 @@ class SlotCalculator {
///
std::vector<unsigned> ModuleLevel;
+ /// ModuleContainsAllFunctionConstants - This flag is set to true if all
+ /// function constants are incorporated into the module constant table. This
+ /// is only possible if building information for a bytecode file.
+ bool ModuleContainsAllFunctionConstants;
+
+ /// CompactionTable/NodeMap - When function compaction has been performed,
+ /// these entries provide a compacted view of the namespace needed to emit
+ /// instructions in a function body. The 'getSlot()' method automatically
+ /// returns these entries if applicable, or the global entries if not.
+ std::vector<TypePlane> CompactionTable;
+ std::map<const Value*, unsigned> CompactionNodeMap;
+
+ SlotCalculator(const SlotCalculator &); // DO NOT IMPLEMENT
+ void operator=(const SlotCalculator &); // DO NOT IMPLEMENT
public:
SlotCalculator(const Module *M, bool BuildBytecodeInfo);
// Start out in incorp state
SlotCalculator(const Function *F, bool BuildBytecodeInfo);
- /// getSlot returns < 0 on error!
+ /// getSlot - Return the slot number of the specified value in it's type
+ /// plane. This returns < 0 on error!
///
- int getSlot(const Value *D) const;
+ int getSlot(const Value *V) const;
+
+ /// getGlobalSlot - Return a slot number from the global table. This can only
+ /// be used when a compaction table is active.
+ unsigned getGlobalSlot(const Value *V) const;
- inline unsigned getNumPlanes() const { return Table.size(); }
+ inline unsigned getNumPlanes() const {
+ if (CompactionTable.empty())
+ return Table.size();
+ else
+ return CompactionTable.size();
+ }
inline unsigned getModuleLevel(unsigned Plane) const {
return Plane < ModuleLevel.size() ? ModuleLevel[Plane] : 0;
}
inline const TypePlane &getPlane(unsigned Plane) const {
- return Table[Plane];
+ if (CompactionTable.empty() || CompactionTable.size() <= Plane ||
+ CompactionTable[Plane].empty())
+ return Table[Plane];
+ else
+ return CompactionTable[Plane];
}
/// incorporateFunction/purgeFunction - If you'd like to deal with a function,
@@ -84,8 +113,11 @@ public:
string_iterator string_begin() const { return ConstantStrings.begin(); }
string_iterator string_end() const { return ConstantStrings.end(); }
+ const std::vector<TypePlane> &getCompactionTable() const {
+ return CompactionTable;
+ }
-protected:
+private:
// getOrCreateSlot - Values can be crammed into here at will... if
// they haven't been inserted already, they get inserted, otherwise
// they are ignored.
@@ -111,6 +143,9 @@ protected:
//
void processSymbolTable(const SymbolTable *ST);
void processSymbolTableConstants(const SymbolTable *ST);
+
+ void buildCompactionTable(const Function *F);
+ unsigned getOrCreateCompactionTableSlot(const Value *V);
};
} // End llvm namespace