13#ifndef CIRCT_DIALECT_SMT_SMTVISITORS_H
14#define CIRCT_DIALECT_SMT_SMTVISITORS_H
17#include "llvm/ADT/TypeSwitch.h"
23template <
typename ConcreteType,
typename ResultType = void,
24 typename... ExtraArgs>
28 auto *thisCast =
static_cast<ConcreteType *
>(
this);
29 return TypeSwitch<Operation *, ResultType>(op)
32 BoolConstantOp, IntConstantOp, BVConstantOp,
34 BVNegOp, BVAddOp, BVMulOp, BVURemOp, BVSRemOp, BVSModOp, BVShlOp,
35 BVLShrOp, BVAShrOp, BVUDivOp, BVSDivOp,
37 BVNotOp, BVAndOp, BVOrOp, BVXOrOp,
39 ConcatOp, ExtractOp, RepeatOp, BVCmpOp, BV2IntOp,
41 IntAddOp, IntMulOp, IntSubOp, IntDivOp, IntModOp, IntCmpOp,
44 EqOp, DistinctOp, IteOp,
46 DeclareFunOp, ApplyFuncOp,
48 SolverOp, AssertOp, ResetOp, PushOp, PopOp, CheckOp, SetLogicOp,
50 NotOp, AndOp, OrOp, XOrOp, ImpliesOp,
52 ArrayStoreOp, ArraySelectOp, ArrayBroadcastOp,
54 ForallOp, ExistsOp, YieldOp>([&](
auto expr) -> ResultType {
55 return thisCast->visitSMTOp(expr, args...);
57 .Default([&](
auto expr) -> ResultType {
58 return thisCast->visitInvalidSMTOp(op, args...);
64 op->emitOpError(
"unknown SMT node");
74#define HANDLE(OPTYPE, OPKIND) \
75 ResultType visitSMTOp(OPTYPE op, ExtraArgs... args) { \
76 return static_cast<ConcreteType *>(this)->visit##OPKIND##SMTOp(op, \
157template <
typename ConcreteType,
typename ResultType = void,
158 typename... ExtraArgs>
162 auto *thisCast =
static_cast<ConcreteType *
>(
this);
163 return TypeSwitch<Type, ResultType>(type)
164 .template Case<BoolType, IntType, BitVectorType, ArrayType, SMTFuncType,
165 SortType>([&](
auto expr) -> ResultType {
166 return thisCast->visitSMTType(expr, args...);
168 .Default([&](
auto expr) -> ResultType {
169 return thisCast->visitInvalidSMTType(type, args...);
182#define HANDLE(TYPE, KIND) \
183 ResultType visitSMTType(TYPE op, ExtraArgs... args) { \
184 return static_cast<ConcreteType *>(this)->visit##KIND##SMTType(op, \
This helps visit SMT nodes.
HANDLE(YieldOp, Unhandled)
HANDLE(PushOp, Unhandled)
HANDLE(SetLogicOp, Unhandled)
HANDLE(BVAddOp, Unhandled)
HANDLE(DeclareFunOp, Unhandled)
HANDLE(BVOrOp, Unhandled)
HANDLE(ForallOp, Unhandled)
HANDLE(BVLShrOp, Unhandled)
HANDLE(ResetOp, Unhandled)
ResultType visitUnhandledSMTOp(Operation *op, ExtraArgs... args)
This callback is invoked on any SMT operations that are not handled by the concrete visitor.
HANDLE(BVUDivOp, Unhandled)
HANDLE(BVConstantOp, Unhandled)
ResultType visitInvalidSMTOp(Operation *op, ExtraArgs... args)
This callback is invoked on any non-expression operations.
HANDLE(BVAndOp, Unhandled)
HANDLE(BVMulOp, Unhandled)
HANDLE(IntConstantOp, Unhandled)
HANDLE(IntDivOp, Unhandled)
HANDLE(ApplyFuncOp, Unhandled)
HANDLE(IntModOp, Unhandled)
HANDLE(BVNotOp, Unhandled)
HANDLE(BVShlOp, Unhandled)
HANDLE(SolverOp, Unhandled)
HANDLE(RepeatOp, Unhandled)
HANDLE(BVSRemOp, Unhandled)
HANDLE(IntSubOp, Unhandled)
HANDLE(DistinctOp, Unhandled)
HANDLE(ImpliesOp, Unhandled)
HANDLE(BVAShrOp, Unhandled)
HANDLE(ArraySelectOp, Unhandled)
HANDLE(BVNegOp, Unhandled)
HANDLE(ArrayBroadcastOp, Unhandled)
HANDLE(BVSDivOp, Unhandled)
HANDLE(ExistsOp, Unhandled)
HANDLE(ArrayStoreOp, Unhandled)
ResultType dispatchSMTOpVisitor(Operation *op, ExtraArgs... args)
HANDLE(IntMulOp, Unhandled)
HANDLE(BVURemOp, Unhandled)
HANDLE(BVXOrOp, Unhandled)
HANDLE(Int2BVOp, Unhandled)
HANDLE(IntAddOp, Unhandled)
HANDLE(ExtractOp, Unhandled)
HANDLE(BVSModOp, Unhandled)
HANDLE(ConcatOp, Unhandled)
HANDLE(IntCmpOp, Unhandled)
HANDLE(BV2IntOp, Unhandled)
HANDLE(AssertOp, Unhandled)
HANDLE(CheckOp, Unhandled)
HANDLE(BVCmpOp, Unhandled)
HANDLE(BoolConstantOp, Unhandled)
This helps visit SMT types.
HANDLE(BitVectorType, Unhandled)
HANDLE(ArrayType, Unhandled)
HANDLE(BoolType, Unhandled)
HANDLE(SMTFuncType, Unhandled)
ResultType visitUnhandledSMTType(Type type, ExtraArgs... args)
This callback is invoked on any SMT type that are not handled by the concrete visitor.
HANDLE(SortType, Unhandled)
ResultType dispatchSMTTypeVisitor(Type type, ExtraArgs... args)
HANDLE(IntegerType, Unhandled)
ResultType visitInvalidSMTType(Type type, ExtraArgs... args)
This callback is invoked on any non-expression types.
The InstanceGraph op interface, see InstanceGraphInterface.td for more details.