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

Last change on this file since 5828 was 5828, checked in by nmedfort, 17 months ago

Pablo support for byte comparisions; LineFeed? kernel processes byte streams directly. Some clean up of PabloBuilder? functionality.

File size: 12.1 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 inline bool classof(const PabloBlock *) {
59        return true;
60    }
61    static inline bool classof(const Statement *) {
62        return false;
63    }
64    static inline bool classof(const PabloAST * e) {
65        return e->getClassTypeId() == ClassTypeId::Block;
66    }
67    static inline bool classof(const void *) {
68        return false;
69    }
70
71    static PabloBlock * Create(PabloKernel * const parent) 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, String * 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, String * 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, String * name);
102
103    inline Zeroes * createZeroes(llvm::Type * const type = nullptr) {
104        return mParent->getNullValue(type);
105    }
106
107    inline 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, String * name);
120
121    inline Var * createVar(const llvm::StringRef & name, llvm::Type * const type = nullptr) {
122        return createVar(makeName(name), type);
123    }
124
125    inline Var * createVar(String * name, llvm::Type * const type = nullptr) {
126        return createVar(reinterpret_cast<PabloAST *>(name), type);
127    }
128
129    Count * createCount(PabloAST * expr);
130
131    Count * createCount(PabloAST * expr, const llvm::StringRef & prefix);
132
133    InFile * createInFile(PabloAST * expr) {
134        return createInFile(expr, nullptr);
135    }
136
137    InFile * createInFile(PabloAST * expr, const llvm::StringRef & prefix) {
138        return createInFile(expr, makeName(prefix));
139    }
140
141    InFile * createInFile(PabloAST * expr, String * name);
142
143    AtEOF * createAtEOF(PabloAST * expr) {
144        return createAtEOF(expr, nullptr);
145    }
146
147    AtEOF * createAtEOF(PabloAST * expr, const llvm::StringRef & prefix) {
148        return createAtEOF(expr, makeName(prefix));
149    }
150
151    AtEOF * createAtEOF(PabloAST * expr, String * name);
152
153    Extract * createExtract(Var * array, Integer * index);
154
155    Assign * createAssign(PabloAST * const var, PabloAST * const value);
156
157    And * createAnd(PabloAST * expr1, PabloAST * expr2) {
158        return createAnd(expr1, expr2, nullptr);
159    }
160
161    And * createAnd(PabloAST * expr1, PabloAST * expr2, const llvm::StringRef & prefix) {
162        return createAnd(expr1, expr2, makeName(prefix));
163    }
164
165    And * createAnd(PabloAST * expr1, PabloAST * expr2, String * name);
166
167    And * createAnd(llvm::Type * const type, const unsigned reserved) {
168        return createAnd(type, reserved, nullptr);
169    }
170
171    And * createAnd(llvm::Type * const type, const unsigned reserved, String * name);
172
173    Or * createOr(PabloAST * expr1, PabloAST * expr2) {
174        return createOr(expr1, expr2, nullptr);
175    }
176
177    Or * createOr(PabloAST * expr1, PabloAST * expr2, const llvm::StringRef & prefix) {
178        return createOr(expr1, expr2, makeName(prefix));
179    }
180
181    Or * createOr(PabloAST * expr1, PabloAST * expr2, String * name);
182
183    Or * createOr(llvm::Type * const type, const unsigned reserved) {
184        return createOr(type, reserved, nullptr);
185    }
186
187    Or * createOr(llvm::Type * const type, const unsigned reserved, String * name);
188
189    Xor * createXor(PabloAST * expr1, PabloAST * expr2) {
190        return createXor(expr1, expr2, nullptr);
191    }
192
193    Xor * createXor(PabloAST * expr1, PabloAST * expr2, const llvm::StringRef & prefix) {
194        return createXor(expr1, expr2, makeName(prefix));
195    }
196
197    Xor * createXor(PabloAST * expr1, PabloAST * expr2, String * name);
198
199    Xor * createXor(llvm::Type * const type, const unsigned reserved) {
200        return createXor(type, reserved, nullptr);
201    }
202
203    Xor * createXor(llvm::Type * const type, const unsigned reserved, String * name);
204
205    Sel * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr) {
206        return createSel(condition, trueExpr, falseExpr, nullptr);
207    }
208
209    Sel * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr, const llvm::StringRef & prefix) {
210        return createSel(condition, trueExpr, falseExpr, makeName(prefix));
211    }
212
213    Sel * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr, String * name);
214
215    Add * createAdd(PabloAST * expr1, PabloAST * expr2);
216
217    Subtract * createSubtract(PabloAST * expr1, PabloAST * expr2);
218
219    LessThan * createLessThan(PabloAST * expr1, PabloAST * expr2);
220
221    Equals * createEquals(PabloAST * expr1, PabloAST * expr2);
222
223    MatchStar * createMatchStar(PabloAST * marker, PabloAST * charclass) {
224        return createMatchStar(marker, charclass, nullptr);
225    }
226
227    MatchStar * createMatchStar(PabloAST * marker, PabloAST * charclass, const llvm::StringRef & prefix) {
228        return createMatchStar(marker, charclass, makeName(prefix));
229    }
230
231    MatchStar * createMatchStar(PabloAST * marker, PabloAST * charclass, String * name);
232
233    ScanThru * createScanThru(PabloAST * from, PabloAST * thru) {
234        return createScanThru(from, thru, nullptr);
235    }
236
237    ScanThru * createScanThru(PabloAST * from, PabloAST * thru, const llvm::StringRef & prefix) {
238        return createScanThru(from, thru, makeName(prefix));
239    }
240
241    ScanThru * createScanThru(PabloAST * from, PabloAST * thru, String * name);
242
243    ScanTo * createScanTo(PabloAST * from, PabloAST * to) {
244        return createScanTo(from, to, nullptr);
245    }
246
247    ScanTo * createScanTo(PabloAST * from, PabloAST * to, const llvm::StringRef & prefix) {
248        return createScanTo(from, to, makeName(prefix));
249    }
250
251    ScanTo * createScanTo(PabloAST * from, PabloAST * to, String * name);
252
253    AdvanceThenScanThru * createAdvanceThenScanThru(PabloAST * from, PabloAST * thru) {
254        return createAdvanceThenScanThru(from, thru, nullptr);
255    }
256
257    AdvanceThenScanThru * createAdvanceThenScanThru(PabloAST * from, PabloAST * thru, const llvm::StringRef & prefix) {
258        return createAdvanceThenScanThru(from, thru, makeName(prefix));
259    }
260
261    AdvanceThenScanThru * createAdvanceThenScanThru(PabloAST * from, PabloAST * thru, String * name);
262
263    AdvanceThenScanTo * createAdvanceThenScanTo(PabloAST * from, PabloAST * to) {
264        return createAdvanceThenScanTo(from, to, nullptr);
265    }
266
267    AdvanceThenScanTo * createAdvanceThenScanTo(PabloAST * from, PabloAST * to, const llvm::StringRef & prefix) {
268        return createAdvanceThenScanTo(from, to, makeName(prefix));
269    }
270
271    AdvanceThenScanTo * createAdvanceThenScanTo(PabloAST * from, PabloAST * to, String * name);
272
273    If * createIf(PabloAST * condition, PabloBlock * body);
274
275    While * createWhile(PabloAST * condition, PabloBlock * body);
276
277    Repeat * createRepeat(Integer * fieldWidth, PabloAST * value) {
278        return createRepeat(fieldWidth, value, nullptr);
279    }
280
281    Repeat * createRepeat(Integer * fieldWidth, PabloAST * value, const llvm::StringRef & prefix) {
282        return createRepeat(fieldWidth, value, makeName(prefix));
283    }
284
285    Repeat * createRepeat(Integer * fieldWidth, PabloAST * value, String * name);
286
287    PackH * createPackH(Integer * fieldWidth, PabloAST * value) {
288        return createPackH(fieldWidth, value, nullptr);
289    }
290
291    PackH * createPackH(Integer * width, PabloAST * value, const llvm::StringRef & prefix) {
292        return createPackH(width, value, makeName(prefix));
293    }
294
295    PackH * createPackH(Integer * fieldWidth, PabloAST * value, String * name);
296
297    PackL * createPackL(Integer * fieldWidth, PabloAST * value) {
298        return createPackL(fieldWidth, value, nullptr);
299    }
300
301    PackL * createPackL(Integer * fieldWidth, PabloAST * value, const llvm::StringRef & prefix) {
302        return createPackL(fieldWidth, value, makeName(prefix));
303    }
304
305    PackL * createPackL(Integer * fieldWidth, PabloAST * value, String * name);
306
307    PabloBlock * getPredecessor() const;
308
309    inline PabloKernel * getParent() const {
310        return mParent;
311    }
312
313    void insert(Statement * const statement);
314
315    void eraseFromParent(const bool recursively = false);
316
317    inline Branch * getBranch() const {
318        return mBranch;
319    }
320
321    inline void setBranch(Branch * const branch) {
322        mBranch = branch;
323    }
324
325    inline String * makeName(const llvm::StringRef & prefix) const {
326        return mParent->makeName(prefix);
327    }
328
329    inline Integer * getInteger(const int64_t value) const {
330        return mParent->getInteger(value);
331    }
332
333    llvm::LLVMContext & getContext() const {
334        return mParent->getContext();
335    }
336
337    void print(llvm::raw_ostream & O, const bool expandNested = true) const;
338
339    virtual ~PabloBlock() {}
340
341protected:
342
343    PabloBlock(PabloKernel * const parent, Allocator & allocator) noexcept
344    : PabloAST(PabloAST::ClassTypeId::Block, nullptr, allocator)
345    , mParent(parent)
346    , mBranch(nullptr)
347    , mAllocator(allocator) {
348
349    }
350
351    template<typename Type>
352    inline Type * insertAtInsertionPoint(Type * expr) {
353        if (llvm::isa<Statement>(expr)) {
354            insert(llvm::cast<Statement>(expr));
355        }
356        return expr;
357    }
358
359    Var * createVar(PabloAST * name, llvm::Type * const type);
360
361private:       
362    PabloKernel * const         mParent;
363    Branch *                    mBranch;
364    Allocator &                 mAllocator;
365};
366
367}
368
369#endif // PS_PABLOS_H
Note: See TracBrowser for help on using the repository browser.