blob: 60cf516a100ef503850eddd5e8197826fd2626f0 [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>
Brian Gaeked0fde302003-11-11 22:41:34 +000025
26namespace llvm {
27
Chris Lattner644dc172001-07-14 06:08:51 +000028class Value;
Chris Lattner4c4007b2001-09-07 16:27:05 +000029class Module;
Chris Lattnere7506a32002-03-23 22:51:58 +000030class Function;
Chris Lattner184b2fa2002-04-09 18:35:38 +000031class SymbolTable;
Chris Lattner00950542001-06-06 20:29:01 +000032
Chris Lattner4c4007b2001-09-07 16:27:05 +000033class SlotCalculator {
Chris Lattner00950542001-06-06 20:29:01 +000034 const Module *TheModule;
Chris Lattner8ce75012004-01-14 02:49:34 +000035
36 // BuildBytecodeInfo - If true, this is the creating information for the
37 // bytecode writer, if false, we are building information for the assembly
38 // emitter. The assembly emitter doesn't need named objects numbered, among
39 // other differences.
40 bool BuildBytecodeInfo;
Chris Lattner00950542001-06-06 20:29:01 +000041
Chris Lattner697954c2002-01-20 22:54:45 +000042 typedef std::vector<const Value*> TypePlane;
43 std::vector<TypePlane> Table;
44 std::map<const Value *, unsigned> NodeMap;
Chris Lattner00950542001-06-06 20:29:01 +000045
46 // ModuleLevel - Used to keep track of which values belong to the module,
Chris Lattnerb5794002002-04-07 22:49:37 +000047 // and which values belong to the currently incorporated function.
Chris Lattner00950542001-06-06 20:29:01 +000048 //
Chris Lattner697954c2002-01-20 22:54:45 +000049 std::vector<unsigned> ModuleLevel;
Chris Lattner00950542001-06-06 20:29:01 +000050
51public:
Chris Lattner8ce75012004-01-14 02:49:34 +000052 SlotCalculator(const Module *M, bool BuildBytecodeInfo);
Chris Lattnere7506a32002-03-23 22:51:58 +000053 // Start out in incorp state
Chris Lattner8ce75012004-01-14 02:49:34 +000054 SlotCalculator(const Function *M, bool BuildBytecodeInfo);
Chris Lattner00950542001-06-06 20:29:01 +000055 inline ~SlotCalculator() {}
56
Alkis Evlogimenos60596382003-10-17 02:02:40 +000057 // getSlot returns < 0 on error!
58 int getSlot(const Value *D) const;
Chris Lattner00950542001-06-06 20:29:01 +000059
60 inline unsigned getNumPlanes() const { return Table.size(); }
61 inline unsigned getModuleLevel(unsigned Plane) const {
62 return Plane < ModuleLevel.size() ? ModuleLevel[Plane] : 0;
63 }
64
65 inline const TypePlane &getPlane(unsigned Plane) const {
66 return Table[Plane];
67 }
68
Chris Lattnerb5794002002-04-07 22:49:37 +000069 // If you'd like to deal with a function, use these two methods to get its
70 // data into the SlotCalculator!
Chris Lattner00950542001-06-06 20:29:01 +000071 //
Chris Lattnerb5794002002-04-07 22:49:37 +000072 void incorporateFunction(const Function *F);
73 void purgeFunction();
Chris Lattner00950542001-06-06 20:29:01 +000074
75protected:
Alkis Evlogimenos60596382003-10-17 02:02:40 +000076 // getOrCreateSlot - Values can be crammed into here at will... if
77 // they haven't been inserted already, they get inserted, otherwise
78 // they are ignored.
Chris Lattner00950542001-06-06 20:29:01 +000079 //
Alkis Evlogimenos60596382003-10-17 02:02:40 +000080 int getOrCreateSlot(const Value *D);
Chris Lattner00950542001-06-06 20:29:01 +000081
Alkis Evlogimenos60596382003-10-17 02:02:40 +000082 // insertValue - Insert a value into the value table... Return the
83 // slot that it occupies, or -1 if the declaration is to be ignored
84 // because of the IgnoreNamedNodes flag.
Chris Lattner00950542001-06-06 20:29:01 +000085 //
Alkis Evlogimenos60596382003-10-17 02:02:40 +000086 int insertValue(const Value *D, bool dontIgnore = false);
Chris Lattner00950542001-06-06 20:29:01 +000087
Alkis Evlogimenos60596382003-10-17 02:02:40 +000088 // doInsertValue - Small helper function to be called only be insertVal.
89 int doInsertValue(const Value *D);
Chris Lattner00950542001-06-06 20:29:01 +000090
Chris Lattnerb5794002002-04-07 22:49:37 +000091 // processModule - Process all of the module level function declarations and
Chris Lattner4c4007b2001-09-07 16:27:05 +000092 // types that are available.
Chris Lattner00950542001-06-06 20:29:01 +000093 //
Chris Lattner4c4007b2001-09-07 16:27:05 +000094 void processModule();
Chris Lattner00950542001-06-06 20:29:01 +000095
Chris Lattner4c4007b2001-09-07 16:27:05 +000096 // processSymbolTable - Insert all of the values in the specified symbol table
97 // into the values table...
Chris Lattner00950542001-06-06 20:29:01 +000098 //
Chris Lattner4c4007b2001-09-07 16:27:05 +000099 void processSymbolTable(const SymbolTable *ST);
100 void processSymbolTableConstants(const SymbolTable *ST);
Chris Lattner00950542001-06-06 20:29:01 +0000101};
102
Brian Gaeked0fde302003-11-11 22:41:34 +0000103} // End llvm namespace
104
Chris Lattner00950542001-06-06 20:29:01 +0000105#endif