blob: 105e585d852f78fe8e3d0a266d3e017a767914cb [file] [log] [blame]
Chris Lattner48486892003-09-30 18:37:50 +00001//===-- llvm/SlotCalculator.h - Calculate value slots -----------*- C++ -*-===//
John Criswell6fbcc262003-10-20 20:19:47 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file was developed by the LLVM research group and is distributed under
6// the University of Illinois Open Source License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
Chris Lattner00950542001-06-06 20:29:01 +00009//
Chris Lattnerb5794002002-04-07 22:49:37 +000010// This class calculates the slots that values will land in. This is useful for
11// when writing bytecode or assembly out, because you have to know these things.
12//
13// Specifically, this class calculates the "type plane numbering" that you see
14// for a function if you strip out all of the symbols in it. For assembly
15// writing, this is used when a symbol does not have a name. For bytecode
16// writing, this is always used, and the symbol table is added on later.
Chris Lattner00950542001-06-06 20:29:01 +000017//
18//===----------------------------------------------------------------------===//
19
Chris Lattnerb5794002002-04-07 22:49:37 +000020#ifndef LLVM_SLOTCALCULATOR_H
21#define LLVM_SLOTCALCULATOR_H
Chris Lattner00950542001-06-06 20:29:01 +000022
Chris Lattner00950542001-06-06 20:29:01 +000023#include <vector>
24#include <map>
Chris Lattneraf894e92004-01-18 21:03:49 +000025#include <cassert>
Brian Gaeked0fde302003-11-11 22:41:34 +000026
27namespace llvm {
28
Chris Lattner644dc172001-07-14 06:08:51 +000029class Value;
Chris Lattner4c4007b2001-09-07 16:27:05 +000030class Module;
Chris Lattnere7506a32002-03-23 22:51:58 +000031class Function;
Chris Lattner184b2fa2002-04-09 18:35:38 +000032class SymbolTable;
Chris Lattner7851e1b2004-01-14 23:37:43 +000033class ConstantArray;
Chris Lattner00950542001-06-06 20:29:01 +000034
Chris Lattner4c4007b2001-09-07 16:27:05 +000035class SlotCalculator {
Chris Lattner00950542001-06-06 20:29:01 +000036 const Module *TheModule;
Chris Lattner8ce75012004-01-14 02:49:34 +000037
Chris Lattner7851e1b2004-01-14 23:37:43 +000038 /// BuildBytecodeInfo - If true, this is the creating information for the
39 /// bytecode writer, if false, we are building information for the assembly
40 /// emitter. The assembly emitter doesn't need named objects numbered, among
41 /// other differences.
Chris Lattner8ce75012004-01-14 02:49:34 +000042 bool BuildBytecodeInfo;
Chris Lattner00950542001-06-06 20:29:01 +000043
Chris Lattner697954c2002-01-20 22:54:45 +000044 typedef std::vector<const Value*> TypePlane;
45 std::vector<TypePlane> Table;
Chris Lattner7851e1b2004-01-14 23:37:43 +000046 std::map<const Value*, unsigned> NodeMap;
Chris Lattner00950542001-06-06 20:29:01 +000047
Chris Lattner7851e1b2004-01-14 23:37:43 +000048 /// ConstantStrings - If we are indexing for a bytecode file, this keeps track
49 /// of all of the constants strings that need to be emitted.
50 std::vector<const ConstantArray*> ConstantStrings;
51
52 /// ModuleLevel - Used to keep track of which values belong to the module,
53 /// and which values belong to the currently incorporated function.
54 ///
Chris Lattner697954c2002-01-20 22:54:45 +000055 std::vector<unsigned> ModuleLevel;
Chris Lattner00950542001-06-06 20:29:01 +000056
Chris Lattneraf894e92004-01-18 21:03:49 +000057 /// ModuleContainsAllFunctionConstants - This flag is set to true if all
58 /// function constants are incorporated into the module constant table. This
59 /// is only possible if building information for a bytecode file.
60 bool ModuleContainsAllFunctionConstants;
61
62 /// CompactionTable/NodeMap - When function compaction has been performed,
63 /// these entries provide a compacted view of the namespace needed to emit
64 /// instructions in a function body. The 'getSlot()' method automatically
65 /// returns these entries if applicable, or the global entries if not.
66 std::vector<TypePlane> CompactionTable;
67 std::map<const Value*, unsigned> CompactionNodeMap;
68
69 SlotCalculator(const SlotCalculator &); // DO NOT IMPLEMENT
70 void operator=(const SlotCalculator &); // DO NOT IMPLEMENT
Chris Lattner00950542001-06-06 20:29:01 +000071public:
Chris Lattner8ce75012004-01-14 02:49:34 +000072 SlotCalculator(const Module *M, bool BuildBytecodeInfo);
Chris Lattnere7506a32002-03-23 22:51:58 +000073 // Start out in incorp state
Chris Lattner7851e1b2004-01-14 23:37:43 +000074 SlotCalculator(const Function *F, bool BuildBytecodeInfo);
Chris Lattner00950542001-06-06 20:29:01 +000075
Chris Lattneraf894e92004-01-18 21:03:49 +000076 /// getSlot - Return the slot number of the specified value in it's type
77 /// plane. This returns < 0 on error!
Chris Lattner7851e1b2004-01-14 23:37:43 +000078 ///
Chris Lattneraf894e92004-01-18 21:03:49 +000079 int getSlot(const Value *V) const;
Chris Lattner00950542001-06-06 20:29:01 +000080
Chris Lattneraf894e92004-01-18 21:03:49 +000081 /// getGlobalSlot - Return a slot number from the global table. This can only
82 /// be used when a compaction table is active.
83 unsigned getGlobalSlot(const Value *V) const;
84
85 inline unsigned getNumPlanes() const {
86 if (CompactionTable.empty())
87 return Table.size();
88 else
89 return CompactionTable.size();
90 }
Chris Lattner00950542001-06-06 20:29:01 +000091 inline unsigned getModuleLevel(unsigned Plane) const {
92 return Plane < ModuleLevel.size() ? ModuleLevel[Plane] : 0;
93 }
94
95 inline const TypePlane &getPlane(unsigned Plane) const {
Chris Lattneraf894e92004-01-18 21:03:49 +000096 if (CompactionTable.empty() || CompactionTable.size() <= Plane ||
97 CompactionTable[Plane].empty())
98 return Table[Plane];
99 else
100 return CompactionTable[Plane];
Chris Lattner00950542001-06-06 20:29:01 +0000101 }
102
Chris Lattner7851e1b2004-01-14 23:37:43 +0000103 /// incorporateFunction/purgeFunction - If you'd like to deal with a function,
104 /// use these two methods to get its data into the SlotCalculator!
105 ///
Chris Lattnerb5794002002-04-07 22:49:37 +0000106 void incorporateFunction(const Function *F);
107 void purgeFunction();
Chris Lattner00950542001-06-06 20:29:01 +0000108
Chris Lattner7851e1b2004-01-14 23:37:43 +0000109 /// string_iterator/string_begin/end - Access the list of module-level
110 /// constant strings that have been incorporated. This is only applicable to
111 /// bytecode files.
112 typedef std::vector<const ConstantArray*>::const_iterator string_iterator;
113 string_iterator string_begin() const { return ConstantStrings.begin(); }
114 string_iterator string_end() const { return ConstantStrings.end(); }
115
Chris Lattneraf894e92004-01-18 21:03:49 +0000116 const std::vector<TypePlane> &getCompactionTable() const {
117 return CompactionTable;
118 }
Chris Lattner7851e1b2004-01-14 23:37:43 +0000119
Chris Lattneraf894e92004-01-18 21:03:49 +0000120private:
Alkis Evlogimenos60596382003-10-17 02:02:40 +0000121 // getOrCreateSlot - Values can be crammed into here at will... if
122 // they haven't been inserted already, they get inserted, otherwise
123 // they are ignored.
Chris Lattner00950542001-06-06 20:29:01 +0000124 //
Alkis Evlogimenos60596382003-10-17 02:02:40 +0000125 int getOrCreateSlot(const Value *D);
Chris Lattner00950542001-06-06 20:29:01 +0000126
Alkis Evlogimenos60596382003-10-17 02:02:40 +0000127 // insertValue - Insert a value into the value table... Return the
128 // slot that it occupies, or -1 if the declaration is to be ignored
129 // because of the IgnoreNamedNodes flag.
Chris Lattner00950542001-06-06 20:29:01 +0000130 //
Alkis Evlogimenos60596382003-10-17 02:02:40 +0000131 int insertValue(const Value *D, bool dontIgnore = false);
Chris Lattner00950542001-06-06 20:29:01 +0000132
Alkis Evlogimenos60596382003-10-17 02:02:40 +0000133 // doInsertValue - Small helper function to be called only be insertVal.
134 int doInsertValue(const Value *D);
Chris Lattner00950542001-06-06 20:29:01 +0000135
Chris Lattnerb5794002002-04-07 22:49:37 +0000136 // processModule - Process all of the module level function declarations and
Chris Lattner4c4007b2001-09-07 16:27:05 +0000137 // types that are available.
Chris Lattner00950542001-06-06 20:29:01 +0000138 //
Chris Lattner4c4007b2001-09-07 16:27:05 +0000139 void processModule();
Chris Lattner00950542001-06-06 20:29:01 +0000140
Chris Lattner4c4007b2001-09-07 16:27:05 +0000141 // processSymbolTable - Insert all of the values in the specified symbol table
142 // into the values table...
Chris Lattner00950542001-06-06 20:29:01 +0000143 //
Chris Lattner4c4007b2001-09-07 16:27:05 +0000144 void processSymbolTable(const SymbolTable *ST);
145 void processSymbolTableConstants(const SymbolTable *ST);
Chris Lattneraf894e92004-01-18 21:03:49 +0000146
147 void buildCompactionTable(const Function *F);
148 unsigned getOrCreateCompactionTableSlot(const Value *V);
Chris Lattner00950542001-06-06 20:29:01 +0000149};
150
Brian Gaeked0fde302003-11-11 22:41:34 +0000151} // End llvm namespace
152
Chris Lattner00950542001-06-06 20:29:01 +0000153#endif