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

Last change on this file since 4723 was 4718, checked in by cameron, 4 years ago

add Pablo count operation - not yet functional

File size: 7.6 KB
RevLine 
[3850]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
[4244]10#include <pablo/pabloAST.h>
[4416]11#include <pablo/symbol_generator.h>
[4207]12#include <pablo/pe_advance.h>
13#include <pablo/pe_and.h>
14#include <pablo/pe_call.h>
15#include <pablo/pe_matchstar.h>
[4252]16#include <pablo/pe_next.h>
[4207]17#include <pablo/pe_not.h>
[4252]18#include <pablo/pe_ones.h>
[4207]19#include <pablo/pe_or.h>
20#include <pablo/pe_scanthru.h>
21#include <pablo/pe_sel.h>
[4415]22#include <pablo/pe_integer.h>
[4252]23#include <pablo/pe_string.h>
[4207]24#include <pablo/pe_var.h>
25#include <pablo/pe_xor.h>
[4252]26#include <pablo/pe_zeroes.h>
[4718]27#include <pablo/pe_count.h>
[4207]28#include <pablo/ps_assign.h>
29#include <pablo/ps_if.h>
30#include <pablo/ps_while.h>
[4680]31#include <pablo/function.h>
[4681]32#include <llvm/ADT/ArrayRef.h>
[4416]33#include <stdexcept>
[3850]34
[4206]35namespace pablo {
36
[4432]37class PabloBlock : public PabloAST, public StatementList {
[4602]38    friend class PabloAST;
39    friend class PabloBuilder;
[4227]40public:
[4206]41
[4432]42    static inline bool classof(const PabloBlock *) {
43        return true;
44    }
45    static inline bool classof(const Statement *) {
46        return false;
47    }
48    static inline bool classof(const PabloAST * e) {
49        return e->getClassTypeId() == ClassTypeId::Block;
50    }
51    static inline bool classof(const void *) {
52        return false;
53    }
54
[4510]55    inline static PabloBlock & Create(SymbolGenerator & symbolGenerator) {
56        return *(new PabloBlock(symbolGenerator));
[4210]57    }
58
[4521]59    inline static PabloBlock & Create(PabloBlock & parent) {
60        return *(new PabloBlock(&parent));
[4210]61    }
62
[4699]63    PabloAST * createAdvance(PabloAST * expr, const Integer::Type shiftAmount);
[4214]64
[4432]65    PabloAST * createAdvance(PabloAST * expr, PabloAST * shiftAmount);
66
[4699]67    PabloAST * createAdvance(PabloAST * expr, const Integer::Type shiftAmount, const std::string prefix);
[4438]68
69    PabloAST * createAdvance(PabloAST * expr, PabloAST * shiftAmount, const std::string prefix);
70
[4247]71    inline Zeroes * createZeroes() const {
72        return mZeroes;
[4211]73    }
[4210]74
[4247]75    inline Ones * createOnes() const {
76        return mOnes;
77    }
78
[4681]79    inline Call * createCall(Prototype * prototype, const std::vector<Var *> & args) {
80        return createCall(prototype, reinterpret_cast<const std::vector<PabloAST *> &>(args));
[4432]81    }
[4213]82
[4692]83    inline Call * createCall(Prototype * prototype, const std::vector<PabloAST *> & args) {
84        if (prototype == nullptr) {
85            throw std::runtime_error("Call object cannot be created with a Null prototype!");
86        }
87        if (args.size() != cast<Prototype>(prototype)->getNumOfParameters()) {
88            throw std::runtime_error("Invalid number of arguments passed into Call object!");
89        }
90        return createCall(static_cast<PabloAST *>(prototype), args);
91    }
92
[4657]93    Assign * createAssign(const std::string && prefix, PabloAST * expr);
[4252]94
[4432]95    inline Var * createVar(const std::string name) {
[4433]96        return createVar(getName(name, false));
[4432]97    }
[4254]98
[4602]99    inline Var * createVar(String * name) {
100        return createVar(cast<PabloAST>(name));
[4252]101    }
102
103    Next * createNext(Assign * assign, PabloAST * expr);
104
[4244]105    PabloAST * createAnd(PabloAST * expr1, PabloAST * expr2);
[4209]106
[4438]107    PabloAST * createAnd(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
108
[4244]109    PabloAST * createNot(PabloAST * expr);
[4209]110
[4438]111    PabloAST * createNot(PabloAST * expr, const std::string prefix);
112
[4244]113    PabloAST * createOr(PabloAST * expr1, PabloAST * expr2);
[4209]114
[4438]115    PabloAST * createOr(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
116
[4244]117    PabloAST * createXor(PabloAST * expr1, PabloAST * expr2);
[4209]118
[4438]119    PabloAST * createXor(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
120
[4255]121    PabloAST * createMatchStar(PabloAST * marker, PabloAST * charclass);
[4207]122
[4438]123    PabloAST * createMatchStar(PabloAST * marker, PabloAST * charclass, const std::string prefix);
124
[4255]125    PabloAST * createScanThru(PabloAST * from, PabloAST * thru);
[4209]126
[4438]127    PabloAST * createScanThru(PabloAST * from, PabloAST * thru, const std::string prefix);
128
[4244]129    PabloAST * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr);
[4207]130
[4438]131    PabloAST * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr, const std::string prefix);
132
[4718]133    PabloAST * createCount(PabloAST * expr);
134   
135    PabloAST * createCount(PabloAST * expr, const std::string prefix);
136   
[4524]137    If * createIf(PabloAST * condition, const std::initializer_list<Assign *> definedVars, PabloBlock & body);
[4215]138
[4511]139    If * createIf(PabloAST * condition, const std::vector<Assign *> & definedVars, PabloBlock & body);
140
141    If * createIf(PabloAST * condition, std::vector<Assign *> && definedVars, PabloBlock & body);
142
[4641]143    While * createWhile(PabloAST * condition, const std::initializer_list<Next *> nextVars, PabloBlock & body);
[4215]144
[4641]145    While * createWhile(PabloAST * condition, const std::vector<Next *> & nextVars, PabloBlock & body);
146
147    While * createWhile(PabloAST * condition, std::vector<Next *> && nextVars, PabloBlock & body);
148
[4717]149    PabloAST * createMod64Advance(PabloAST * expr, const Integer::Type shiftAmount);
[4641]150
[4717]151    PabloAST * createMod64Advance(PabloAST * expr, PabloAST * shiftAmount);
152
153    PabloAST * createMod64Advance(PabloAST * expr, const Integer::Type shiftAmount, const std::string prefix);
154
155    PabloAST * createMod64Advance(PabloAST * expr, PabloAST * shiftAmount, const std::string prefix);
156
157    PabloAST * createMod64MatchStar(PabloAST * marker, PabloAST * charclass);
158
159    PabloAST * createMod64MatchStar(PabloAST * marker, PabloAST * charclass, const std::string prefix);
160
161    PabloAST * createMod64ScanThru(PabloAST * from, PabloAST * thru);
162
163    PabloAST * createMod64ScanThru(PabloAST * from, PabloAST * thru, const std::string prefix);
164
165
[4276]166    inline StatementList & statements() {
[4404]167        return *this;
[4276]168    }
169
[4268]170    inline const StatementList & statements() const {
[4404]171        return *this;
[4210]172    }
[4416]173
[4433]174    inline String * getName(const std::string name, const bool generated = true) const {
[4510]175        return mSymbolGenerator.get(name, generated);
[4410]176    }
[4416]177
[4433]178    inline String * makeName(const std::string prefix, const bool generated = true) const {
[4510]179        return mSymbolGenerator.make(prefix, generated);
[4410]180    }
[4416]181
[4699]182    inline Integer * getInteger(Integer::Type value) {
[4510]183        return mSymbolGenerator.getInteger(value);
[4443]184    }
185
[4521]186    inline PabloBlock * getParent() const {
187        return mParent;
188    }
[4540]189   
[4650]190    void insert(Statement * const statement);
191
[4687]192    unsigned enumerateScopes(unsigned baseScopeIndex);
[4540]193   
[4687]194    inline unsigned getScopeIndex() const {
195        return mScopeIndex;
196    }
197   
[4432]198    virtual ~PabloBlock();
199
[4404]200protected:
[4680]201
[4510]202    PabloBlock(SymbolGenerator & symbolGenerator);
[4276]203
[4416]204    PabloBlock(PabloBlock * predecessor);
[4404]205
[4438]206    PabloAST * renameNonNamedNode(PabloAST * expr, const std::string && prefix);
207
[4410]208    template<typename Type>
[4416]209    inline Type * insertAtInsertionPoint(Type * expr) {
210        if (isa<Statement>(expr)) {
[4611]211            if (LLVM_UNLIKELY(isa<If>(expr) || isa<While>(expr))) {
212                PabloBlock & body = isa<If>(expr) ? cast<If>(expr)->getBody() : cast<While>(expr)->getBody();
213                this->addUser(&body);
214            }
[4416]215            insert(cast<Statement>(expr));
[4410]216        }
[4416]217        return expr;
[4410]218    }
[4692]219
[4602]220private:
[4410]221
[4692]222    Call * createCall(PabloAST * prototype, const std::vector<PabloAST *> &);
[4602]223
224    Var * createVar(PabloAST * name);
225
[4258]226private:       
227    Zeroes * const                                      mZeroes;
228    Ones * const                                        mOnes;
[4510]229    SymbolGenerator &                                   mSymbolGenerator;
[4521]230    PabloBlock *                                        mParent;
[4687]231    unsigned                                            mScopeIndex;
[4197]232};
233
[4206]234}
235
[3850]236#endif // PS_PABLOS_H
Note: See TracBrowser for help on using the repository browser.