source: icGREP/icgrep-devel/icgrep/pablo/codegenstate.h @ 4602

Last change on this file since 4602 was 4602, checked in by nmedfort, 4 years ago

Fixed PabloBuilder? and intergrated it into CC Compiler.

File size: 6.0 KB
Line 
1/*
2 *  Copyright (c) 2014 International Characters.
3 *  This software is licensed to the public under the Open Software License 3.0.
4 *  icgrep is a trademark of International Characters.
5 */
6
7#ifndef PS_PABLOS_H
8#define PS_PABLOS_H
9
10#include <pablo/carry_data.h>
11#include <pablo/pabloAST.h>
12#include <pablo/symbol_generator.h>
13#include <pablo/pe_advance.h>
14#include <pablo/pe_and.h>
15#include <pablo/pe_call.h>
16#include <pablo/pe_matchstar.h>
17#include <pablo/pe_next.h>
18#include <pablo/pe_not.h>
19#include <pablo/pe_ones.h>
20#include <pablo/pe_or.h>
21#include <pablo/pe_scanthru.h>
22#include <pablo/pe_sel.h>
23#include <pablo/pe_integer.h>
24#include <pablo/pe_string.h>
25#include <pablo/pe_var.h>
26#include <pablo/pe_xor.h>
27#include <pablo/pe_zeroes.h>
28#include <pablo/ps_assign.h>
29#include <pablo/ps_if.h>
30#include <pablo/ps_while.h>
31#include <stdexcept>
32
33namespace pablo {
34
35class PabloBlock : public PabloAST, public StatementList {
36    friend class PabloAST;
37    friend class PabloBuilder;
38public:
39
40    static inline bool classof(const PabloBlock *) {
41        return true;
42    }
43    static inline bool classof(const Statement *) {
44        return false;
45    }
46    static inline bool classof(const PabloAST * e) {
47        return e->getClassTypeId() == ClassTypeId::Block;
48    }
49    static inline bool classof(const void *) {
50        return false;
51    }
52
53    inline static PabloBlock & Create(SymbolGenerator & symbolGenerator) {
54        return *(new PabloBlock(symbolGenerator));
55    }
56
57    inline static PabloBlock & Create(PabloBlock & parent) {
58        return *(new PabloBlock(&parent));
59    }
60
61    PabloAST * createAdvance(PabloAST * expr, const Integer::integer_t shiftAmount);
62
63    PabloAST * createAdvance(PabloAST * expr, PabloAST * shiftAmount);
64
65    PabloAST * createAdvance(PabloAST * expr, const Integer::integer_t shiftAmount, const std::string prefix);
66
67    PabloAST * createAdvance(PabloAST * expr, PabloAST * shiftAmount, const std::string prefix);
68
69    inline Zeroes * createZeroes() const {
70        return mZeroes;
71    }
72
73    inline Ones * createOnes() const {
74        return mOnes;
75    }
76
77    inline Call * createCall(const std::string name) {
78        return createCall(getName(name, false));
79    }
80
81    inline Call * createCall(String * name) {
82        return createCall(cast<PabloAST>(name));
83    }
84
85    Assign * createAssign(const std::string prefix, PabloAST * expr, const int outputIndex = -1);
86
87    inline Var * createVar(const std::string name) {
88        return createVar(getName(name, false));
89    }
90
91    inline Var * createVar(String * name) {
92        return createVar(cast<PabloAST>(name));
93    }
94
95    Next * createNext(Assign * assign, PabloAST * expr);
96
97    PabloAST * createAnd(PabloAST * expr1, PabloAST * expr2);
98
99    PabloAST * createAnd(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
100
101    PabloAST * createNot(PabloAST * expr);
102
103    PabloAST * createNot(PabloAST * expr, const std::string prefix);
104
105    PabloAST * createOr(PabloAST * expr1, PabloAST * expr2);
106
107    PabloAST * createOr(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
108
109    PabloAST * createXor(PabloAST * expr1, PabloAST * expr2);
110
111    PabloAST * createXor(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
112
113    PabloAST * createMatchStar(PabloAST * marker, PabloAST * charclass);
114
115    PabloAST * createMatchStar(PabloAST * marker, PabloAST * charclass, const std::string prefix);
116
117    PabloAST * createScanThru(PabloAST * from, PabloAST * thru);
118
119    PabloAST * createScanThru(PabloAST * from, PabloAST * thru, const std::string prefix);
120
121    PabloAST * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr);
122
123    PabloAST * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr, const std::string prefix);
124
125    If * createIf(PabloAST * condition, const std::initializer_list<Assign *> definedVars, PabloBlock & body);
126
127    If * createIf(PabloAST * condition, const std::vector<Assign *> & definedVars, PabloBlock & body);
128
129    If * createIf(PabloAST * condition, std::vector<Assign *> && definedVars, PabloBlock & body);
130
131    While * createWhile(PabloAST * condition, PabloBlock & body);
132
133    inline StatementList & statements() {
134        return *this;
135    }
136
137    inline const StatementList & statements() const {
138        return *this;
139    }
140
141    inline String * getName(const std::string name, const bool generated = true) const {
142        return mSymbolGenerator.get(name, generated);
143    }
144
145    inline String * makeName(const std::string prefix, const bool generated = true) const {
146        return mSymbolGenerator.make(prefix, generated);
147    }
148
149    inline Integer * getInteger(Integer::integer_t value) {
150        return mSymbolGenerator.getInteger(value);
151    }
152
153    inline PabloBlock * getParent() const {
154        return mParent;
155    }
156   
157    PabloBlockCarryData carryData;
158   
159    virtual ~PabloBlock();
160
161   
162protected:
163    PabloBlock(SymbolGenerator & symbolGenerator);
164
165    PabloBlock(PabloBlock * predecessor);
166
167    PabloAST * renameNonNamedNode(PabloAST * expr, const std::string && prefix);
168
169    template<typename Type>
170    inline Type * insertAtInsertionPoint(Type * expr) {
171        if (isa<Statement>(expr)) {
172            insert(cast<Statement>(expr));
173        }
174        return expr;
175    }
176private:
177
178    Call * createCall(PabloAST * name);
179
180    Var * createVar(PabloAST * name);
181
182private:       
183    Zeroes * const                                      mZeroes;
184    Ones * const                                        mOnes;
185    SymbolGenerator &                                   mSymbolGenerator;
186    PabloBlock *                                        mParent;
187    unsigned                                            mCarryVectorIndex;
188    unsigned                                            mPackedCarryDataIndex;
189    unsigned                                            mLocalCarryCount;
190    unsigned                                            mLocalAdvanceCount;
191    unsigned                                            mTotalCarryVectorSize;
192    unsigned                                            mTotalCarryDataSize;
193};
194
195}
196
197#endif // PS_PABLOS_H
Note: See TracBrowser for help on using the repository browser.