CIRCT 23.0.0git
Loading...
Searching...
No Matches
SVVisitors.h
Go to the documentation of this file.
1//===- SVVisitors.h - SV Dialect Visitors -----------------------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file defines visitors that make it easier to work with SV IR.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef CIRCT_DIALECT_SV_SVVISITORS_H
14#define CIRCT_DIALECT_SV_SVVISITORS_H
15
17#include "llvm/ADT/TypeSwitch.h"
18
19namespace circt {
20namespace sv {
21
22template <typename ConcreteType, typename ResultType = void,
23 typename... ExtraArgs>
24class Visitor {
25public:
26 ResultType dispatchSVVisitor(Operation *op, ExtraArgs... args) {
27 auto *thisCast = static_cast<ConcreteType *>(this);
28 return TypeSwitch<Operation *, ResultType>(op)
29 .template Case<
30 // Expressions
31 ReadInOutOp, ArrayIndexInOutOp, VerbatimExprOp, VerbatimExprSEOp,
32 IndexedPartSelectInOutOp, IndexedPartSelectOp, StructFieldInOutOp,
33 ConstantXOp, ConstantZOp, ConstantStrOp, MacroRefExprOp,
34 MacroRefExprSEOp, UnpackedArrayCreateOp, UnpackedOpenArrayCastOp,
35 SFormatFOp,
36 // Declarations.
37 RegOp, WireOp, LogicOp, LocalParamOp, XMROp, XMRRefOp,
38 // Control flow.
39 OrderedOutputOp, IfDefOp, IfDefProceduralOp, IfOp, AlwaysOp,
40 AlwaysCombOp, AlwaysFFOp, InitialOp, CaseOp,
41 // Other Statements.
42 AssignOp, BPAssignOp, PAssignOp, ForceOp, ReleaseOp, AliasOp,
43 WriteOp, FWriteOp, FFlushOp, SystemFunctionOp, VerbatimOp,
44 MacroRefOp, FuncCallOp, FuncCallProceduralOp, ReturnOp, IncludeOp,
45 MacroErrorOp,
46 // Type declarations.
47 InterfaceOp, SVVerbatimSourceOp, InterfaceSignalOp,
48 InterfaceModportOp, InterfaceInstanceOp, GetModportOp,
49 AssignInterfaceSignalOp, ReadInterfaceSignalOp, MacroDeclOp,
50 MacroDefOp, FuncOp, FuncDPIImportOp,
51 // Verification statements.
52 AssertOp, AssumeOp, CoverOp, AssertConcurrentOp, AssumeConcurrentOp,
53 CoverConcurrentOp, AssertPropertyOp, AssumePropertyOp,
54 CoverPropertyOp,
55 // Bind Statements
56 BindOp,
57 // Simulator control tasks
58 StopOp, FinishOp, ExitOp,
59 // Severity message tasks
60 FatalProceduralOp, FatalOp, ErrorProceduralOp, WarningProceduralOp,
61 InfoProceduralOp, ErrorOp, WarningOp, InfoOp,
62 // Memory loading tasks
63 ReadMemOp,
64 // Generate statements
65 GenerateOp, GenerateCaseOp,
66 // For statements
67 ForOp,
68 // Sampled value functiions
69 SampledOp,
70 // Time system functions
71 TimeOp, STimeOp>([&](auto expr) -> ResultType {
72 return thisCast->visitSV(expr, args...);
73 })
74 .Default([&](auto expr) -> ResultType {
75 return thisCast->visitInvalidSV(op, args...);
76 });
77 }
78
79 /// This callback is invoked on any invalid operations.
80 ResultType visitInvalidSV(Operation *op, ExtraArgs... args) {
81 op->emitOpError("unknown SV node");
82 abort();
83 }
84
85 /// This callback is invoked on any SV operations that are not handled by the
86 /// concrete visitor.
87 ResultType visitUnhandledSV(Operation *op, ExtraArgs... args) {
88 return ResultType();
89 }
90
91#define HANDLE(OPTYPE, OPKIND) \
92 ResultType visitSV(OPTYPE op, ExtraArgs... args) { \
93 return static_cast<ConcreteType *>(this)->visit##OPKIND##SV(op, args...); \
94 }
95
96 // Declarations
97 HANDLE(RegOp, Unhandled);
98 HANDLE(WireOp, Unhandled);
99 HANDLE(LogicOp, Unhandled);
100 HANDLE(LocalParamOp, Unhandled);
101 HANDLE(XMROp, Unhandled);
102 HANDLE(XMRRefOp, Unhandled);
103
104 // Expressions
105 HANDLE(ReadInOutOp, Unhandled);
106 HANDLE(ArrayIndexInOutOp, Unhandled);
107 HANDLE(VerbatimExprOp, Unhandled);
108 HANDLE(VerbatimExprSEOp, Unhandled);
109 HANDLE(IndexedPartSelectInOutOp, Unhandled);
110 HANDLE(IndexedPartSelectOp, Unhandled);
111 HANDLE(StructFieldInOutOp, Unhandled);
112 HANDLE(ConstantXOp, Unhandled);
113 HANDLE(ConstantZOp, Unhandled);
114 HANDLE(ConstantStrOp, Unhandled);
115 HANDLE(MacroRefExprOp, Unhandled);
116 HANDLE(MacroRefExprSEOp, Unhandled);
117 HANDLE(UnpackedArrayCreateOp, Unhandled);
118 HANDLE(UnpackedOpenArrayCastOp, Unhandled);
119 HANDLE(SFormatFOp, Unhandled);
120
121 // Control flow.
122 HANDLE(OrderedOutputOp, Unhandled);
123 HANDLE(IfDefOp, Unhandled);
124 HANDLE(IfDefProceduralOp, Unhandled);
125 HANDLE(IfOp, Unhandled);
126 HANDLE(AlwaysOp, Unhandled);
127 HANDLE(AlwaysCombOp, Unhandled);
128 HANDLE(AlwaysFFOp, Unhandled);
129 HANDLE(InitialOp, Unhandled);
130 HANDLE(CaseOp, Unhandled);
131
132 // Other Statements.
133 HANDLE(AssignOp, Unhandled);
134 HANDLE(BPAssignOp, Unhandled);
135 HANDLE(PAssignOp, Unhandled);
136 HANDLE(ForceOp, Unhandled);
137 HANDLE(ReleaseOp, Unhandled);
138 HANDLE(AliasOp, Unhandled);
139 HANDLE(WriteOp, Unhandled);
140 HANDLE(FWriteOp, Unhandled);
141 HANDLE(FFlushOp, Unhandled);
142 HANDLE(SystemFunctionOp, Unhandled);
143 HANDLE(FuncCallProceduralOp, Unhandled);
144 HANDLE(FuncCallOp, Unhandled);
145 HANDLE(ReturnOp, Unhandled);
146 HANDLE(VerbatimOp, Unhandled);
147 HANDLE(MacroRefOp, Unhandled);
148 HANDLE(IncludeOp, Unhandled);
149 HANDLE(MacroErrorOp, Unhandled);
150
151 // Type declarations.
152 HANDLE(InterfaceOp, Unhandled);
153 HANDLE(SVVerbatimSourceOp, Unhandled);
154 HANDLE(InterfaceInstanceOp, Unhandled);
155 HANDLE(InterfaceSignalOp, Unhandled);
156 HANDLE(InterfaceModportOp, Unhandled);
157 HANDLE(GetModportOp, Unhandled);
158 HANDLE(AssignInterfaceSignalOp, Unhandled);
159 HANDLE(ReadInterfaceSignalOp, Unhandled);
160 HANDLE(MacroDefOp, Unhandled);
161 HANDLE(MacroDeclOp, Unhandled);
162 HANDLE(FuncDPIImportOp, Unhandled);
163 HANDLE(FuncOp, Unhandled);
164
165 // Verification statements.
166 HANDLE(AssertOp, Unhandled);
167 HANDLE(AssumeOp, Unhandled);
168 HANDLE(CoverOp, Unhandled);
169 HANDLE(AssertConcurrentOp, Unhandled);
170 HANDLE(AssumeConcurrentOp, Unhandled);
171 HANDLE(CoverConcurrentOp, Unhandled);
172 HANDLE(AssertPropertyOp, Unhandled);
173 HANDLE(AssumePropertyOp, Unhandled);
174 HANDLE(CoverPropertyOp, Unhandled);
175
176 // Bind statements.
177 HANDLE(BindOp, Unhandled);
178
179 // Simulator control tasks
180 HANDLE(StopOp, Unhandled);
181 HANDLE(FinishOp, Unhandled);
182 HANDLE(ExitOp, Unhandled);
183
184 // Severity message tasks
185 HANDLE(FatalProceduralOp, Unhandled);
186 HANDLE(FatalOp, Unhandled);
187 HANDLE(ErrorProceduralOp, Unhandled);
188 HANDLE(WarningProceduralOp, Unhandled);
189 HANDLE(InfoProceduralOp, Unhandled);
190 HANDLE(ErrorOp, Unhandled);
191 HANDLE(WarningOp, Unhandled);
192 HANDLE(InfoOp, Unhandled);
193
194 // Memory loading tasks
195 HANDLE(ReadMemOp, Unhandled);
196
197 // Generate statements
198 HANDLE(GenerateOp, Unhandled);
199 HANDLE(GenerateCaseOp, Unhandled);
200
201 // For loop.
202 HANDLE(ForOp, Unhandled);
203
204 // Sampled Value Functions
205 HANDLE(SampledOp, Unhandled);
206
207 // Time System Functions
208 HANDLE(TimeOp, Unhandled);
209 HANDLE(STimeOp, Unhandled);
210#undef HANDLE
211};
212
213} // namespace sv
214} // namespace circt
215
216#endif // CIRCT_DIALECT_SV_SVVISITORS_H
HANDLE(MacroErrorOp, Unhandled)
HANDLE(AssumePropertyOp, Unhandled)
HANDLE(FatalProceduralOp, Unhandled)
HANDLE(BindOp, Unhandled)
HANDLE(ConstantXOp, Unhandled)
HANDLE(InterfaceSignalOp, Unhandled)
HANDLE(ConstantStrOp, Unhandled)
HANDLE(WarningProceduralOp, Unhandled)
HANDLE(ReadInterfaceSignalOp, Unhandled)
HANDLE(StopOp, Unhandled)
HANDLE(SFormatFOp, Unhandled)
HANDLE(ExitOp, Unhandled)
HANDLE(ForOp, Unhandled)
HANDLE(TimeOp, Unhandled)
HANDLE(FinishOp, Unhandled)
HANDLE(XMRRefOp, Unhandled)
HANDLE(FWriteOp, Unhandled)
HANDLE(AssumeOp, Unhandled)
HANDLE(IfDefOp, Unhandled)
HANDLE(AssertOp, Unhandled)
HANDLE(ForceOp, Unhandled)
HANDLE(AssignOp, Unhandled)
HANDLE(CoverOp, Unhandled)
HANDLE(RegOp, Unhandled)
HANDLE(FuncOp, Unhandled)
HANDLE(FuncCallOp, Unhandled)
HANDLE(ReadInOutOp, Unhandled)
ResultType dispatchSVVisitor(Operation *op, ExtraArgs... args)
Definition SVVisitors.h:26
HANDLE(UnpackedOpenArrayCastOp, Unhandled)
HANDLE(WarningOp, Unhandled)
HANDLE(SampledOp, Unhandled)
HANDLE(VerbatimExprOp, Unhandled)
HANDLE(InfoProceduralOp, Unhandled)
HANDLE(IncludeOp, Unhandled)
HANDLE(XMROp, Unhandled)
HANDLE(ReleaseOp, Unhandled)
HANDLE(MacroDeclOp, Unhandled)
HANDLE(IfOp, Unhandled)
HANDLE(InterfaceOp, Unhandled)
HANDLE(FFlushOp, Unhandled)
HANDLE(AlwaysCombOp, Unhandled)
HANDLE(AlwaysOp, Unhandled)
HANDLE(CoverPropertyOp, Unhandled)
HANDLE(InitialOp, Unhandled)
HANDLE(GenerateCaseOp, Unhandled)
HANDLE(GetModportOp, Unhandled)
HANDLE(InterfaceInstanceOp, Unhandled)
HANDLE(StructFieldInOutOp, Unhandled)
HANDLE(ArrayIndexInOutOp, Unhandled)
HANDLE(FatalOp, Unhandled)
HANDLE(AlwaysFFOp, Unhandled)
HANDLE(AssertPropertyOp, Unhandled)
HANDLE(CoverConcurrentOp, Unhandled)
HANDLE(ErrorProceduralOp, Unhandled)
HANDLE(BPAssignOp, Unhandled)
HANDLE(CaseOp, Unhandled)
HANDLE(InterfaceModportOp, Unhandled)
HANDLE(OrderedOutputOp, Unhandled)
HANDLE(WriteOp, Unhandled)
HANDLE(InfoOp, Unhandled)
HANDLE(UnpackedArrayCreateOp, Unhandled)
HANDLE(PAssignOp, Unhandled)
ResultType visitUnhandledSV(Operation *op, ExtraArgs... args)
This callback is invoked on any SV operations that are not handled by the concrete visitor.
Definition SVVisitors.h:87
ResultType visitInvalidSV(Operation *op, ExtraArgs... args)
This callback is invoked on any invalid operations.
Definition SVVisitors.h:80
HANDLE(AssignInterfaceSignalOp, Unhandled)
HANDLE(VerbatimOp, Unhandled)
HANDLE(FuncDPIImportOp, Unhandled)
HANDLE(MacroRefOp, Unhandled)
HANDLE(AliasOp, Unhandled)
HANDLE(GenerateOp, Unhandled)
HANDLE(MacroRefExprOp, Unhandled)
HANDLE(WireOp, Unhandled)
HANDLE(SVVerbatimSourceOp, Unhandled)
HANDLE(ReturnOp, Unhandled)
HANDLE(STimeOp, Unhandled)
HANDLE(IndexedPartSelectOp, Unhandled)
HANDLE(IndexedPartSelectInOutOp, Unhandled)
HANDLE(ConstantZOp, Unhandled)
HANDLE(AssumeConcurrentOp, Unhandled)
HANDLE(LocalParamOp, Unhandled)
HANDLE(FuncCallProceduralOp, Unhandled)
HANDLE(ReadMemOp, Unhandled)
HANDLE(MacroRefExprSEOp, Unhandled)
HANDLE(AssertConcurrentOp, Unhandled)
HANDLE(SystemFunctionOp, Unhandled)
HANDLE(ErrorOp, Unhandled)
HANDLE(LogicOp, Unhandled)
HANDLE(IfDefProceduralOp, Unhandled)
HANDLE(VerbatimExprSEOp, Unhandled)
HANDLE(MacroDefOp, Unhandled)
The InstanceGraph op interface, see InstanceGraphInterface.td for more details.
Definition sv.py:1