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

Last change on this file since 5972 was 5889, checked in by cameron, 20 months ago

BitByteGrepKernel? initial check-in

File size: 9.9 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/pabloAST.h>
11#include <pablo/pablo_kernel.h>
12#include <pablo/pe_integer.h>
13namespace llvm { class Type; }
14namespace llvm { class raw_ostream; }
15namespace pablo { class Add; }
16namespace pablo { class Advance; }
17namespace pablo { class IndexedAdvance; }
18namespace pablo { class AdvanceThenScanThru; }
19namespace pablo { class AdvanceThenScanTo; }
20namespace pablo { class And; }
21namespace pablo { class Assign; }
22namespace pablo { class AtEOF; }
23namespace pablo { class Branch; }
24namespace pablo { class If; }
25namespace pablo { class While; }
26namespace pablo { class Count; }
27namespace pablo { class Extract; }
28namespace pablo { class InFile; }
29namespace pablo { class LessThan; }
30namespace pablo { class Equals; }
31namespace pablo { class Lookahead; }
32namespace pablo { class MatchStar; }
33namespace pablo { class Not; }
34namespace pablo { class Ones; }
35namespace pablo { class Or; }
36namespace pablo { class PabloKernel; }
37namespace pablo { class PackH; }
38namespace pablo { class PackL; }
39namespace pablo { class ScanThru; }
40namespace pablo { class ScanTo; }
41namespace pablo { class Sel; }
42namespace pablo { class Repeat; }
43namespace pablo { class String; }
44namespace pablo { class Subtract; }
45namespace pablo { class Var; }
46namespace pablo { class Xor; }
47namespace pablo { class Zeroes; }
48
49namespace pablo {
50
51class PabloBlock : public PabloAST, public StatementList {
52    friend class PabloAST;
53    friend class Branch;
54    friend class PabloBuilder;
55    friend class PabloKernel;
56public:
57
58    static bool classof(const PabloBlock *) {
59        return true;
60    }
61    static bool classof(const Statement *) {
62        return false;
63    }
64    static bool classof(const PabloAST * e) {
65        return e->getClassTypeId() == ClassTypeId::Block;
66    }
67    static bool classof(const void *) {
68        return false;
69    }
70
71    PabloBlock * createScope() noexcept;
72
73    Advance * createAdvance(PabloAST * expr, Integer * shiftAmount) {
74        return createAdvance(expr, shiftAmount, nullptr);
75    }
76   
77    Advance * createAdvance(PabloAST * expr, Integer * shiftAmount, const llvm::StringRef & prefix) {
78        return createAdvance(expr, shiftAmount, makeName(prefix));
79    }
80   
81    Advance * createAdvance(PabloAST * expr, Integer * shiftAmount, const String * const name);
82   
83    IndexedAdvance * createIndexedAdvance(PabloAST * expr, PabloAST * indexStream, Integer * shiftAmount) {
84        return createIndexedAdvance(expr, indexStream, shiftAmount, nullptr);
85    }
86   
87    IndexedAdvance * createIndexedAdvance(PabloAST * expr, PabloAST * indexStream, Integer * shiftAmount, const llvm::StringRef & prefix) {
88        return createIndexedAdvance(expr, indexStream, shiftAmount, makeName(prefix));
89    }
90   
91    IndexedAdvance * createIndexedAdvance(PabloAST * expr, PabloAST * indexStream, Integer * shiftAmount, const String * const name);
92   
93    Lookahead * createLookahead(PabloAST * expr, Integer * shiftAmount) {
94        return createLookahead(expr, shiftAmount, nullptr);
95    }
96
97    Lookahead * createLookahead(PabloAST * expr, Integer * shiftAmount, const llvm::StringRef & prefix) {
98        return createLookahead(expr, shiftAmount, makeName(prefix));
99    }
100
101    Lookahead * createLookahead(PabloAST * expr, Integer * shiftAmount, const String * const name);
102
103    Zeroes * createZeroes(llvm::Type * const type = nullptr) {
104        return mParent->getNullValue(type);
105    }
106
107    Ones * createOnes(llvm::Type * const type = nullptr) {
108        return mParent->getAllOnesValue(type);
109    }
110
111    Not * createNot(PabloAST * expr) {
112        return createNot(expr, nullptr);
113    }
114
115    Not * createNot(PabloAST * expr, const llvm::StringRef & prefix) {
116        return createNot(expr, makeName(prefix));
117    }
118
119    Not * createNot(PabloAST * expr, const String * const name);
120
121    Var * createVar(const llvm::StringRef & name, llvm::Type * const type = nullptr) {
122        return createVar(makeName(name), type);
123    }
124
125    Var * createVar(const String * const name, llvm::Type * const type = nullptr);
126
127    Count * createCount(PabloAST * expr, const llvm::StringRef & prefix) {
128        return createCount(expr, makeName(prefix));
129    }
130
131    Count * createCount(PabloAST * expr, const String * const name = nullptr);
132
133    InFile * createInFile(PabloAST * expr, const llvm::StringRef & prefix) {
134        return createInFile(expr, makeName(prefix));
135    }
136
137    InFile * createInFile(PabloAST * expr, const String * const name = nullptr);
138
139    AtEOF * createAtEOF(PabloAST * expr, const llvm::StringRef & prefix) {
140        return createAtEOF(expr, makeName(prefix));
141    }
142
143    AtEOF * createAtEOF(PabloAST * expr, const String * const name = nullptr);
144
145    Extract * createExtract(Var * array, Integer * index);
146
147    Assign * createAssign(PabloAST * const var, PabloAST * const value);
148
149    And * createAnd(PabloAST * expr1, PabloAST * expr2, const llvm::StringRef & prefix) {
150        return createAnd(expr1, expr2, makeName(prefix));
151    }
152
153    And * createAnd(PabloAST * expr1, PabloAST * expr2, const String * const name = nullptr);
154
155    Or * createOr(PabloAST * expr1, PabloAST * expr2, const llvm::StringRef & prefix) {
156        return createOr(expr1, expr2, makeName(prefix));
157    }
158
159    Or * createOr(PabloAST * expr1, PabloAST * expr2, const String * const name = nullptr);
160
161    Xor * createXor(PabloAST * expr1, PabloAST * expr2, const llvm::StringRef & prefix) {
162        return createXor(expr1, expr2, makeName(prefix));
163    }
164
165    Xor * createXor(PabloAST * expr1, PabloAST * expr2, const String * const name = nullptr);
166
167    Sel * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr, const llvm::StringRef & prefix) {
168        return createSel(condition, trueExpr, falseExpr, makeName(prefix));
169    }
170
171    Sel * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr, const String * const name = nullptr);
172
173    Add * createAdd(PabloAST * expr1, PabloAST * expr2);
174
175    Subtract * createSubtract(PabloAST * expr1, PabloAST * expr2);
176
177    LessThan * createLessThan(PabloAST * expr1, PabloAST * expr2);
178
179    Equals * createEquals(PabloAST * expr1, PabloAST * expr2);
180
181    MatchStar * createMatchStar(PabloAST * marker, PabloAST * charclass, const llvm::StringRef & prefix) {
182        return createMatchStar(marker, charclass, makeName(prefix));
183    }
184
185    MatchStar * createMatchStar(PabloAST * marker, PabloAST * charclass, const String * const name = nullptr);
186
187    ScanThru * createScanThru(PabloAST * from, PabloAST * thru, const llvm::StringRef & prefix) {
188        return createScanThru(from, thru, makeName(prefix));
189    }
190
191    ScanThru * createScanThru(PabloAST * from, PabloAST * thru, const String * const name = nullptr);
192
193    ScanTo * createScanTo(PabloAST * from, PabloAST * to, const llvm::StringRef & prefix) {
194        return createScanTo(from, to, makeName(prefix));
195    }
196
197    ScanTo * createScanTo(PabloAST * from, PabloAST * to, const String * const name = nullptr);
198
199    AdvanceThenScanThru * createAdvanceThenScanThru(PabloAST * from, PabloAST * thru, const llvm::StringRef & prefix) {
200        return createAdvanceThenScanThru(from, thru, makeName(prefix));
201    }
202
203    AdvanceThenScanThru * createAdvanceThenScanThru(PabloAST * from, PabloAST * thru, const String * const name = nullptr);
204
205    AdvanceThenScanTo * createAdvanceThenScanTo(PabloAST * from, PabloAST * to, const llvm::StringRef & prefix) {
206        return createAdvanceThenScanTo(from, to, makeName(prefix));
207    }
208
209    AdvanceThenScanTo * createAdvanceThenScanTo(PabloAST * from, PabloAST * to, const String * const name = nullptr);
210
211    If * createIf(PabloAST * condition, PabloBlock * body);
212
213    While * createWhile(PabloAST * condition, PabloBlock * body);
214
215    Repeat * createRepeat(Integer * fieldWidth, PabloAST * value, const llvm::StringRef & prefix) {
216        return createRepeat(fieldWidth, value, makeName(prefix));
217    }
218
219    Repeat * createRepeat(Integer * fieldWidth, PabloAST * value, const String * const name = nullptr);
220
221    PackH * createPackH(Integer * width, PabloAST * value, const llvm::StringRef & prefix) {
222        return createPackH(width, value, makeName(prefix));
223    }
224
225    PackH * createPackH(Integer * fieldWidth, PabloAST * value, const String * const name = nullptr);
226
227    PackL * createPackL(Integer * fieldWidth, PabloAST * value, const llvm::StringRef & prefix) {
228        return createPackL(fieldWidth, value, makeName(prefix));
229    }
230
231    PackL * createPackL(Integer * fieldWidth, PabloAST * value, const String * const name = nullptr);
232
233    PabloBlock * getPredecessor() const;
234
235    PabloKernel * getParent() const {
236        return mParent;
237    }
238
239    void insert(Statement * const statement);
240
241    void eraseFromParent(const bool recursively = false);
242
243    Branch * getBranch() const {
244        return mBranch;
245    }
246
247    void setBranch(Branch * const branch) {
248        mBranch = branch;
249    }
250
251    String * makeName(const llvm::StringRef & prefix) const {
252        return mParent->makeName(prefix);
253    }
254
255    Integer * getInteger(const int64_t value) const {
256        return mParent->getInteger(value);
257    }
258
259    llvm::LLVMContext & getContext() const {
260        return mParent->getContext();
261    }
262
263    void print(llvm::raw_ostream & O, const bool expandNested = true) const;
264
265    virtual ~PabloBlock() {}
266
267protected:
268
269    PabloBlock(PabloKernel * const parent, Allocator & allocator) noexcept
270    : PabloAST(PabloAST::ClassTypeId::Block, nullptr, allocator)
271    , mParent(parent)
272    , mBranch(nullptr)
273    , mAllocator(allocator) {
274
275    }
276
277    template<typename Type>
278    Type * insertAtInsertionPoint(Type * expr) {
279        if (llvm::isa<Statement>(expr)) {
280            insert(llvm::cast<Statement>(expr));
281        }
282        return expr;
283    }
284
285private:       
286    PabloKernel * const         mParent;
287    Branch *                    mBranch;
288    Allocator &                 mAllocator;
289};
290
291}
292
293#endif // PS_PABLOS_H
Note: See TracBrowser for help on using the repository browser.