IEEE 1800-2023(Redline)
$311.46
IEEE Standard for SystemVerilog–Unified Hardware Design, Specification, and Verification Language (Redline)
Published By | Publication Date | Number of Pages |
IEEE | 2023 |
Revision Standard – Active. The definition of the language syntax and semantics for SystemVerilog, which is a unified hardware design, specification, and verification language, is provided. This standard includes support for modeling hardware at the behavioral, register transfer level (RTL), and gate-level abstraction levels, and for writing test benches using coverage, assertions, object-oriented programming, and constrained random verification. The standard also provides application programming interfaces (APIs) to foreign programming languages. (The PDF of this standard is available at no cost at https://ieeexplore.ieee.org/browse/standards/get-program/page compliments of Accellera Systems Initiative)
PDF Catalog
PDF Pages | PDF Title |
---|---|
1 | IEEE Std 1800™-2023 Front cover |
2 | Title page |
4 | Important Notices and Disclaimers Concerning IEEE Standards Documents |
8 | Participants |
10 | Introduction |
11 | Contents |
28 | List of figures |
31 | List of tables |
35 | List of syntax excerpts |
41 | Part One: Design and Verification Constructs |
42 | 1. Overview 1.1 Scope 1.2 Purpose 1.3 Content summary |
43 | 1.4 Special terms 1.5 Conventions used in this standard |
44 | 1.6 Syntactic description 1.7 Use of color in this standard 1.8 Contents of this standard |
48 | 1.9 Deprecated clauses 1.10 Examples 1.11 Prerequisites |
49 | 2. Normative references |
51 | 3. Design and verification building blocks 3.1 General 3.2 Design elements 3.3 Modules |
52 | 3.4 Programs |
53 | 3.5 Interfaces |
54 | 3.6 Checkers 3.7 Primitives 3.8 Subroutines 3.9 Packages |
55 | 3.10 Configurations 3.11 Overview of hierarchy |
56 | 3.12 Compilation and elaboration 3.12.1 Compilation units |
58 | 3.13 Name spaces |
59 | 3.14 Simulation time units and precision |
60 | 3.14.1 Time value rounding 3.14.2 Specifying time units and precision 3.14.2.1 The `timescale compiler directive |
61 | 3.14.2.2 The timeunit and timeprecision keywords 3.14.2.3 Precedence of timeunit, timeprecision, and `timescale |
62 | 3.14.3 Simulation time unit |
63 | 4. Scheduling semantics 4.1 General 4.2 Execution of a hardware model and its verification environment 4.3 Event simulation |
64 | 4.4 Stratified event scheduler |
65 | 4.4.1 Active region sets and reactive region sets 4.4.2 Simulation regions 4.4.2.1 Preponed events region 4.4.2.2 Active events region 4.4.2.3 Inactive events region 4.4.2.4 NBA events region |
66 | 4.4.2.5 Observed events region 4.4.2.6 Reactive events region 4.4.2.7 Re-Inactive events region 4.4.2.8 Re-NBA events region 4.4.2.9 Postponed events region 4.4.3 PLI regions 4.4.3.1 Preponed PLI region |
67 | 4.4.3.2 Pre-Active PLI region 4.4.3.3 Pre-NBA PLI region 4.4.3.4 Post-NBA PLI region 4.4.3.5 Pre-Observed PLI region 4.4.3.6 Post-Observed PLI region 4.4.3.7 Pre-Re-NBA PLI region 4.4.3.8 Post-Re-NBA PLI region 4.4.3.9 Pre-Postponed PLI region 4.4.3.10 Postponed PLI region |
69 | 4.5 SystemVerilog simulation reference algorithm |
70 | 4.6 Determinism 4.7 Nondeterminism 4.8 Race conditions |
71 | 4.9 Scheduling implication of assignments 4.9.1 Continuous assignment 4.9.2 Procedural continuous assignment 4.9.3 Blocking assignment 4.9.4 Nonblocking assignment 4.9.5 Switch (transistor) processing |
72 | 4.9.6 Port connections 4.9.7 Subroutines 4.10 PLI callback control points |
74 | 5. Lexical conventions 5.1 General 5.2 Lexical tokens 5.3 White space 5.4 Comments 5.5 Operators |
75 | 5.6 Identifiers, keywords, and system names 5.6.1 Escaped identifiers 5.6.2 Keywords 5.6.3 System tasks and system functions |
76 | 5.6.4 Compiler directives 5.7 Numbers |
78 | 5.7.1 Integer literal constants |
80 | 5.7.2 Real literal constants |
81 | 5.8 Time literals 5.9 String literals |
84 | 5.9.1 Special characters in strings 5.10 Structure literals |
86 | 5.11 Array literals 5.12 Attributes |
88 | 5.13 Built-in methods |
89 | 6. Data types 6.1 General 6.2 Data types and data objects 6.3 Value set 6.3.1 Logic values |
90 | 6.3.2 Strengths 6.3.2.1 Charge strength 6.3.2.2 Drive strength 6.4 Singular and aggregate types |
91 | 6.5 Nets and variables |
92 | 6.6 Net types |
93 | 6.6.1 Wire and tri nets 6.6.2 Unresolved nets 6.6.3 Wired nets |
94 | 6.6.4 Trireg net |
95 | 6.6.4.1 Capacitive networks |
97 | 6.6.4.2 Ideal capacitive state and charge decay 6.6.5 Tri0 and tri1 nets |
98 | 6.6.6 Supply nets 6.6.7 User-defined nettypes |
100 | 6.6.8 Generic interconnect |
103 | 6.7 Net declarations |
104 | 6.7.1 Net declarations with built-in net types |
105 | 6.7.2 Net declarations with user-defined nettypes 6.7.3 Initialization of nets with user-defined nettypes |
106 | 6.8 Variable declarations |
108 | 6.9 Vector declarations 6.9.1 Specifying vectors |
109 | 6.9.2 Vector net accessibility 6.10 Implicit declarations |
110 | 6.11 Integer data types 6.11.1 Integral types 6.11.2 2-state (two-value) and 4-state (four-value) data types |
111 | 6.11.3 Signed and unsigned integer types 6.12 Real, shortreal, and realtime data types 6.12.1 Conversion 6.13 Void data type |
112 | 6.14 Chandle data type 6.15 Class |
113 | 6.16 String data type |
115 | 6.16.1 Len() 6.16.2 Putc() |
116 | 6.16.3 Getc() 6.16.4 Toupper() 6.16.5 Tolower() 6.16.6 Compare() 6.16.7 Icompare() 6.16.8 Substr() |
117 | 6.16.9 Atoi(), atohex(), atooct(), atobin() 6.16.10 Atoreal() 6.16.11 Itoa() 6.16.12 Hextoa() 6.16.13 Octtoa() |
118 | 6.16.14 Bintoa() 6.16.15 Realtoa() 6.17 Event data type 6.18 User-defined types |
120 | 6.19 Enumerations |
122 | 6.19.1 Defining new data types as enumerated types 6.19.2 Enumerated type ranges |
123 | 6.19.3 Type checking 6.19.4 Enumerated types in numerical expressions |
124 | 6.19.5 Enumerated type methods 6.19.5.1 First() 6.19.5.2 Last() 6.19.5.3 Next() 6.19.5.4 Prev() |
125 | 6.19.5.5 Num() 6.19.5.6 Name() 6.19.5.7 Using enumerated type methods 6.20 Constants |
126 | 6.20.1 Parameter declaration syntax |
127 | 6.20.2 Value parameters |
128 | 6.20.3 Type parameters |
129 | 6.20.4 Local parameters (localparam) |
130 | 6.20.5 Specify parameters |
131 | 6.20.6 Const constants 6.20.7 $ as a constant |
133 | 6.21 Scope and lifetime |
135 | 6.22 Type compatibility |
136 | 6.22.1 Matching types |
137 | 6.22.2 Equivalent types |
138 | 6.22.3 Assignment compatible 6.22.4 Cast compatible 6.22.5 Type incompatible 6.22.6 Matching nettypes |
139 | 6.23 Type operator |
140 | 6.24 Casting 6.24.1 Cast operator |
142 | 6.24.2 $cast dynamic casting |
143 | 6.24.3 Bit-stream casting |
145 | 6.25 Parameterized data types |
147 | 7. Aggregate data types 7.1 General 7.2 Structures |
148 | 7.2.1 Packed structures |
149 | 7.2.2 Assigning to structures 7.3 Unions |
150 | 7.3.1 Packed unions |
152 | 7.3.2 Tagged unions |
154 | 7.4 Packed and unpacked arrays 7.4.1 Packed arrays |
155 | 7.4.2 Unpacked arrays 7.4.3 Memories 7.4.4 Multidimensional arrays |
156 | 7.4.5 Indexing and slicing of arrays |
158 | 7.4.6 Operations on arrays 7.5 Dynamic arrays |
159 | 7.5.1 New[ ] |
160 | 7.5.2 Size() |
161 | 7.5.3 Delete() 7.6 Array assignments |
163 | 7.7 Arrays as arguments to subroutines |
164 | 7.8 Associative arrays 7.8.1 Wildcard index type |
165 | 7.8.2 String index 7.8.3 Class index 7.8.4 Integral index |
166 | 7.8.5 Other user-defined types 7.8.6 Accessing invalid indices 7.8.7 Allocating associative array elements |
167 | 7.9 Associative array methods 7.9.1 Num() and size() 7.9.2 Delete() 7.9.3 Exists() |
168 | 7.9.4 First() 7.9.5 Last() 7.9.6 Next() |
169 | 7.9.7 Prev() 7.9.8 Arguments to traversal methods 7.9.9 Associative array assignment 7.9.10 Associative array arguments |
170 | 7.9.11 Associative array literals 7.10 Queues |
171 | 7.10.1 Queue operators 7.10.2 Queue methods 7.10.2.1 Size() |
172 | 7.10.2.2 Insert() 7.10.2.3 Delete() 7.10.2.4 Pop_front() 7.10.2.5 Pop_back() |
173 | 7.10.2.6 Push_front() 7.10.2.7 Push_back() 7.10.3 Persistence of references to elements of a queue 7.10.4 Updating a queue using assignment and unpacked array concatenation |
174 | 7.10.5 Bounded queues 7.11 Array querying functions 7.12 Array manipulation methods |
175 | 7.12.1 Array locator methods |
176 | 7.12.2 Array ordering methods |
177 | 7.12.3 Array reduction methods |
178 | 7.12.4 Iterator index querying |
179 | 7.12.5 Array mapping method |
180 | 8. Classes 8.1 General 8.2 Overview |
181 | 8.3 Syntax |
182 | 8.4 Objects (class instance) |
184 | 8.5 Object properties and object parameter data 8.6 Object methods |
185 | 8.7 Constructors |
186 | 8.8 Typed constructor calls |
187 | 8.9 Static class properties 8.10 Static methods |
188 | 8.11 This 8.12 Assignment, renaming, and copying |
190 | 8.13 Inheritance and subclasses |
191 | 8.14 Overridden members |
192 | 8.15 Super 8.16 Casting |
193 | 8.17 Chaining constructors |
195 | 8.18 Data hiding and encapsulation |
196 | 8.19 Constant class properties 8.20 Virtual methods |
199 | 8.21 Abstract classes and pure virtual methods |
200 | 8.22 Polymorphism: dynamic method lookup |
201 | 8.23 Class scope resolution operator :: |
203 | 8.24 Out-of-block declarations |
204 | 8.25 Parameterized classes |
206 | 8.25.1 Class scope resolution operator for parameterized classes |
207 | 8.26 Interface classes |
209 | 8.26.1 Interface class syntax 8.26.2 Extends versus implements |
211 | 8.26.3 Type access |
212 | 8.26.4 Type usage restrictions 8.26.5 Casting and object reference assignment |
213 | 8.26.6 Name conflicts and resolution 8.26.6.1 Method name conflict resolution |
214 | 8.26.6.2 Parameter and type declaration inheritance conflicts and resolution 8.26.6.3 Diamond relationship |
215 | 8.26.7 Partial implementation |
216 | 8.26.8 Method default argument values 8.26.9 Constraint blocks, covergroups, and randomization 8.27 Typedef class |
217 | 8.28 Classes and structures 8.29 Memory management |
218 | 8.30 Weak references 8.30.1 Overview |
219 | 8.30.2 New() 8.30.3 Get() |
220 | 8.30.4 Clear() 8.30.5 Get_id() |
221 | 9. Processes 9.1 General 9.2 Structured procedures |
222 | 9.2.1 Initial procedures 9.2.2 Always procedures 9.2.2.1 General purpose always procedure |
223 | 9.2.2.2 Combinational logic always_comb procedure 9.2.2.2.1 Implicit always_comb sensitivities |
224 | 9.2.2.2.2 always_comb compared to always @* 9.2.2.3 Latched logic always_latch procedure 9.2.2.4 Sequential logic always_ff procedure |
225 | 9.2.3 Final procedures 9.3 Block statements |
226 | 9.3.1 Sequential blocks |
227 | 9.3.2 Parallel blocks |
229 | 9.3.3 Statement block start and finish times |
230 | 9.3.4 Block names |
231 | 9.3.5 Statement labels 9.4 Procedural timing controls |
233 | 9.4.1 Delay control 9.4.2 Event control |
234 | 9.4.2.1 Event OR operator |
235 | 9.4.2.2 Implicit event_expression list |
236 | 9.4.2.3 Conditional event controls 9.4.2.4 Sequence events |
237 | 9.4.3 Level-sensitive event control 9.4.4 Level-sensitive sequence controls |
238 | 9.4.5 Intra-assignment timing controls |
241 | 9.5 Process execution threads 9.6 Process control |
242 | 9.6.1 Wait fork statement 9.6.2 Disable statement |
245 | 9.6.3 Disable fork statement |
246 | 9.7 Fine-grain process control |
248 | 10. Assignment statements 10.1 General 10.2 Overview |
249 | 10.3 Continuous assignments 10.3.1 The net declaration assignment |
250 | 10.3.2 The continuous assignment statement |
251 | 10.3.3 Continuous assignment delays |
252 | 10.3.4 Continuous assignment strengths 10.4 Procedural assignments |
253 | 10.4.1 Blocking procedural assignments 10.4.2 Nonblocking procedural assignments |
257 | 10.5 Variable declaration assignment (variable initialization) 10.6 Procedural continuous assignments |
258 | 10.6.1 The assign and deassign procedural statements 10.6.2 The force and release procedural statements |
259 | 10.7 Assignment extension and truncation |
260 | 10.8 Assignment-like contexts |
261 | 10.9 Assignment patterns |
262 | 10.9.1 Array assignment patterns |
264 | 10.9.2 Structure assignment patterns |
265 | 10.10 Unpacked array concatenation |
266 | 10.10.1 Unpacked array concatenations compared with array assignment patterns 10.10.2 Relationship with other constructs that use concatenation syntax |
267 | 10.10.3 Nesting of unpacked array concatenations |
268 | 10.11 Net aliasing |
270 | 11. Operators and expressions 11.1 General 11.2 Overview |
271 | 11.2.1 Constant expressions 11.2.2 Aggregate expressions 11.3 Operators |
273 | 11.3.1 Operators with real operands 11.3.2 Operator precedence |
274 | 11.3.3 Using integer literals in expressions 11.3.4 Operations on logic (4-state) and bit (2-state) types |
275 | 11.3.5 Operator expression short circuiting 11.3.6 Assignment within an expression |
276 | 11.4 Operator descriptions 11.4.1 Assignment operators 11.4.2 Increment and decrement operators 11.4.3 Arithmetic operators |
278 | 11.4.3.1 Arithmetic expressions with unsigned and signed types |
279 | 11.4.4 Relational operators |
280 | 11.4.5 Equality operators |
281 | 11.4.6 Wildcard equality operators 11.4.7 Logical operators |
282 | 11.4.8 Bitwise operators |
284 | 11.4.9 Reduction operators |
285 | 11.4.10 Shift operators |
286 | 11.4.11 Conditional operator |
287 | 11.4.12 Concatenation operators |
288 | 11.4.12.1 Replication operator |
289 | 11.4.12.2 String concatenation and replication 11.4.13 Set membership operator |
291 | 11.4.14 Streaming operators (pack/unpack) |
292 | 11.4.14.1 Concatenation of stream_expressions |
293 | 11.4.14.2 Re-ordering of the generic stream 11.4.14.3 Streaming concatenation as an assignment target (unpack) |
294 | 11.4.14.4 Streaming dynamically sized data |
296 | 11.5 Operands 11.5.1 Vector bit-select and part-select addressing |
298 | 11.5.2 Array and memory addressing |
299 | 11.5.3 Longest static prefix 11.6 Expression bit lengths |
300 | 11.6.1 Rules for expression bit lengths |
301 | 11.6.2 Example of expression bit-length problem |
302 | 11.6.3 Example of self-determined expressions 11.7 Signed expressions |
303 | 11.8 Expression evaluation rules 11.8.1 Rules for expression types 11.8.2 Steps for evaluating an expression |
304 | 11.8.3 Steps for evaluating an assignment 11.8.4 Handling x and z in signed expressions 11.9 Tagged union expressions and member access |
305 | 11.10 String literal expressions |
306 | 11.10.1 String literal operations 11.10.2 String literal value padding and potential problems |
307 | 11.10.3 Empty string literal handling 11.11 Minimum, typical, and maximum delay expressions |
308 | 11.12 Let construct |
315 | 12. Procedural programming statements 12.1 General 12.2 Overview 12.3 Syntax |
316 | 12.4 Conditional if–else statement |
317 | 12.4.1 if–else–if construct |
318 | 12.4.2 unique-if, unique0-if, and priority-if |
319 | 12.4.2.1 Violation reports generated by unique-if, unique0-if, and priority-if constructs |
320 | 12.4.2.2 If statement violation reports and multiple processes |
321 | 12.5 Case statement |
323 | 12.5.1 Case statement with do-not-cares 12.5.2 Constant expression in case statement |
324 | 12.5.3 unique-case, unique0-case, and priority-case |
325 | 12.5.3.1 Violation reports generated by unique-case, unique0-case, and priority-case constructs 12.5.3.2 Case statement violation reports and multiple processes 12.5.4 Set membership case statement |
326 | 12.6 Pattern matching conditional statements |
327 | 12.6.1 Pattern matching in case statements |
329 | 12.6.2 Pattern matching in if statements |
330 | 12.6.3 Pattern matching in conditional expressions 12.7 Loop statements |
331 | 12.7.1 The for-loop |
332 | 12.7.2 The repeat loop 12.7.3 The foreach-loop |
334 | 12.7.4 The while-loop 12.7.5 The do…while-loop 12.7.6 The forever-loop |
335 | 12.8 Jump statements |
336 | 13. Tasks and functions (subroutines) 13.1 General 13.2 Overview 13.3 Tasks |
340 | 13.3.1 Static and automatic tasks 13.3.2 Task memory usage and concurrent activation |
341 | 13.4 Functions |
343 | 13.4.1 Return values and void functions |
345 | 13.4.2 Static and automatic functions |
346 | 13.4.3 Constant functions |
347 | 13.4.4 Background processes spawned by function calls |
348 | 13.5 Subroutine calls and argument passing |
349 | 13.5.1 Pass by value 13.5.2 Pass by reference |
351 | 13.5.3 Default argument values |
352 | 13.5.4 Argument binding by name 13.5.5 Optional argument list |
353 | 13.6 Import and export functions 13.7 Task and function names 13.8 Parameterized tasks and functions |
355 | 14. Clocking blocks 14.1 General 14.2 Overview 14.3 Clocking block declaration |
357 | 14.4 Input and output skews |
358 | 14.5 Hierarchical expressions |
359 | 14.6 Signals in multiple clocking blocks 14.7 Clocking block scope and lifetime 14.8 Multiple clocking blocks example |
360 | 14.9 Interfaces and clocking blocks |
361 | 14.10 Clocking block events |
362 | 14.11 Cycle delay: ## 14.12 Default clocking |
364 | 14.13 Input sampling 14.14 Global clocking |
368 | 14.15 Synchronous events |
369 | 14.16 Synchronous drives |
370 | 14.16.1 Drives and nonblocking assignments |
371 | 14.16.2 Driving clocking output signals |
373 | 15. Interprocess synchronization and communication 15.1 General 15.2 Overview 15.3 Semaphores |
374 | 15.3.1 New() 15.3.2 Put() 15.3.3 Get() 15.3.4 Try_get() |
375 | 15.4 Mailboxes 15.4.1 New() |
376 | 15.4.2 Num() 15.4.3 Put() 15.4.4 Try_put() 15.4.5 Get() |
377 | 15.4.6 Try_get() 15.4.7 Peek() 15.4.8 Try_peek() |
378 | 15.4.9 Parameterized mailboxes 15.5 Named events |
379 | 15.5.1 Triggering an event 15.5.2 Waiting for an event 15.5.3 Persistent trigger: triggered built-in method |
380 | 15.5.4 Event sequencing: wait_order() |
381 | 15.5.5 Operations on named event variables 15.5.5.1 Merging events |
382 | 15.5.5.2 Reclaiming events 15.5.5.3 Events comparison |
384 | 16. Assertions 16.1 General 16.2 Overview 16.3 Immediate assertions |
387 | 16.4 Deferred assertions |
388 | 16.4.1 Deferred assertion reporting |
389 | 16.4.2 Deferred assertion flush points |
392 | 16.4.3 Deferred assertions outside procedural code |
393 | 16.4.4 Disabling deferred assertions 16.4.5 Deferred assertions and multiple processes |
394 | 16.5 Concurrent assertions overview 16.5.1 Sampling |
395 | 16.5.2 Assertion clock |
397 | 16.6 Boolean expressions |
399 | 16.7 Sequences |
403 | 16.8 Declaring sequences |
406 | 16.8.1 Typed formal arguments in sequence declarations |
408 | 16.8.2 Local variable formal arguments in sequence declarations |
411 | 16.9 Sequence operations 16.9.1 Operator precedence 16.9.2 Repetition in sequences |
414 | 16.9.2.1 Repetition, concatenation, and empty matches |
415 | 16.9.3 Sampled value functions |
419 | 16.9.4 Global clocking past and future sampled value functions |
422 | 16.9.5 AND operation |
424 | 16.9.6 Intersection (AND with length restriction) |
425 | 16.9.7 OR operation |
428 | 16.9.8 First_match operation |
429 | 16.9.9 Conditions over sequences |
431 | 16.9.10 Sequence contained within another sequence 16.9.11 Composing sequences from simpler subsequences |
433 | 16.10 Local variables |
439 | 16.11 Calling subroutines on match of a sequence |
440 | 16.12 Declaring properties |
444 | 16.12.1 Property instantiation 16.12.2 Sequence property |
445 | 16.12.3 Negation property 16.12.4 Disjunction property 16.12.5 Conjunction property 16.12.6 If-else property |
446 | 16.12.7 Implication |
450 | 16.12.8 Implies and iff properties 16.12.9 Followed-by property |
451 | 16.12.10 Nexttime property |
453 | 16.12.11 Always property |
454 | 16.12.12 Until property |
455 | 16.12.13 Eventually property |
457 | 16.12.14 Abort properties |
459 | 16.12.15 Weak and strong operators 16.12.16 Case |
460 | 16.12.17 Recursive properties |
464 | 16.12.18 Typed formal arguments in property declarations 16.12.19 Local variable formal arguments in property declarations 16.12.20 Property examples |
465 | 16.12.21 Finite-length versus infinite-length behavior |
466 | 16.12.22 Nondegeneracy 16.13 Multiclock support 16.13.1 Multiclocked sequences |
468 | 16.13.2 Multiclocked properties |
469 | 16.13.3 Clock flow |
470 | 16.13.4 Examples |
472 | 16.13.5 Detecting and using end point of a sequence in multiclock context 16.13.6 Sequence methods |
476 | 16.13.7 Local variable initialization assignments 16.14 Concurrent assertions |
477 | 16.14.1 Assert statement |
478 | 16.14.2 Assume statement |
480 | 16.14.3 Cover statement |
481 | 16.14.4 Restrict statement 16.14.5 Using concurrent assertion statements outside procedural code |
482 | 16.14.6 Embedding concurrent assertions in procedural code |
484 | 16.14.6.1 Arguments to procedural concurrent assertions |
486 | 16.14.6.2 Procedural assertion flush points |
488 | 16.14.6.3 Procedural concurrent assertions and glitches 16.14.6.4 Disabling procedural concurrent assertions |
489 | 16.14.7 Inferred clocking and disable functions |
491 | 16.14.8 Nonvacuous evaluations |
494 | 16.15 Disable iff resolution |
496 | 16.16 Clock resolution |
499 | 16.16.1 Semantic leading clocks for multiclocked sequences and properties |
501 | 16.17 Expect statement |
502 | 16.18 Clocking blocks and concurrent assertions |
504 | 17. Checkers 17.1 Overview 17.2 Checker declaration |
507 | 17.3 Checker instantiation |
510 | 17.4 Context inference |
511 | 17.5 Checker procedures |
513 | 17.6 Covergroups in checkers |
514 | 17.7 Checker variables |
517 | 17.7.1 Checker variable assignments |
518 | 17.7.2 Checker variable randomization with assumptions |
520 | 17.7.3 Scheduling semantics 17.8 Functions in checkers |
521 | 17.9 Complex checker example |
523 | 18. Constrained random value generation 18.1 General 18.2 Overview 18.3 Concepts and usage |
526 | 18.4 Random variables |
528 | 18.4.1 Rand modifier 18.4.2 Randc modifier |
529 | 18.5 Constraint blocks |
530 | 18.5.1 External constraint blocks |
531 | 18.5.2 Constraint inheritance |
532 | 18.5.3 Distribution |
535 | 18.5.4 Uniqueness constraints |
536 | 18.5.5 Implication |
537 | 18.5.6 if–else constraints |
538 | 18.5.7 Iterative constraints 18.5.7.1 foreach iterative constraints |
539 | 18.5.7.2 Array reduction iterative constraints |
540 | 18.5.8 Global constraints 18.5.9 Variable ordering |
543 | 18.5.10 Static constraint blocks 18.5.11 Functions in constraints |
544 | 18.5.12 Constraint guards |
547 | 18.5.13 Soft constraints |
548 | 18.5.13.1 Soft constraint priorities |
550 | 18.5.13.2 Disabling soft constraints |
551 | 18.6 Randomization methods 18.6.1 Randomize() |
552 | 18.6.2 Pre_randomize() and post_randomize() 18.6.3 Behavior of randomization methods |
553 | 18.7 Inline constraints—randomize() with |
554 | 18.7.1 local:: scope resolution |
555 | 18.8 Disabling random variables with rand_mode() |
557 | 18.9 Controlling constraints with constraint_mode() |
558 | 18.10 Dynamic constraint modification 18.11 Inline random variable control |
559 | 18.11.1 Inline constraint checker 18.12 Randomization of scope variables—std::randomize() |
560 | 18.12.1 Adding constraints to scope variables—std::randomize() with |
561 | 18.13 Random number system functions and methods 18.13.1 $urandom 18.13.2 $urandom_range() |
562 | 18.13.3 srandom() 18.13.4 get_randstate() 18.13.5 set_randstate() 18.14 Random stability |
563 | 18.14.1 Random stability properties 18.14.2 Thread stability |
564 | 18.14.3 Object stability |
565 | 18.15 Manually seeding randomize 18.16 Random weighted case—randcase |
566 | 18.17 Random sequence generation—randsequence |
568 | 18.17.1 Random production weights |
569 | 18.17.2 if–else production statements 18.17.3 Case production statements |
570 | 18.17.4 Repeat production statements 18.17.5 Interleaving productions—rand join |
571 | 18.17.6 Aborting productions—break and return |
572 | 18.17.7 Value passing between productions |
576 | 19. Functional coverage 19.1 General 19.2 Overview |
577 | 19.3 Defining the coverage model: covergroup |
579 | 19.4 Using covergroups in classes |
581 | 19.4.1 Embedded covergroup inheritance |
583 | 19.5 Defining coverage points |
585 | 19.5.1 Specifying bins for values |
590 | 19.5.1.1 Coverpoint bin with covergroup expressions |
591 | 19.5.1.2 Coverpoint bin set covergroup expressions 19.5.2 Specifying bins for transitions |
595 | 19.5.3 Automatic bin creation for coverage points of integral expressions 19.5.4 Wildcard specification of coverage point bins |
596 | 19.5.5 Excluding coverage point values or transitions 19.5.6 Specifying Illegal coverage point values or transitions |
597 | 19.5.7 Value resolution |
598 | 19.6 Defining cross coverage |
600 | 19.6.1 Defining cross coverage bins |
601 | 19.6.1.1 Example of user-defined cross coverage and select expressions |
603 | 19.6.1.2 Cross bin with covergroup expressions |
604 | 19.6.1.3 Cross bin automatically defined types 19.6.1.4 Cross bin set expression |
606 | 19.6.2 Excluding cross products 19.6.3 Specifying illegal cross products 19.7 Specifying coverage options |
609 | 19.7.1 Covergroup type options |
611 | 19.8 Predefined coverage methods |
612 | 19.8.1 Overriding the built-in sample method |
613 | 19.9 Predefined coverage system tasks and system functions |
614 | 19.10 Organization of option and type_option members |
615 | 19.11 Coverage computation |
616 | 19.11.1 Coverpoint coverage computation |
617 | 19.11.2 Cross coverage computation 19.11.3 Type coverage computation |
620 | 20. Utility system tasks and system functions 20.1 General |
621 | 20.2 Simulation control system tasks 20.3 Simulation time system functions |
622 | 20.3.1 $time 20.3.2 $stime 20.3.3 $realtime |
623 | 20.4 Timescale system tasks and system functions 20.4.1 Timescale retrieval system functions |
625 | 20.4.2 $printtimescale |
626 | 20.4.3 $timeformat |
627 | 20.5 Conversion functions |
629 | 20.6 Data query functions 20.6.1 Type name function |
630 | 20.6.2 Expression size system function |
631 | 20.6.3 Range system function 20.7 Array query functions |
633 | 20.7.1 Queries over multiple variable dimensions 20.8 Math functions 20.8.1 Integer math functions |
634 | 20.8.2 Real math functions 20.9 Bit vector system functions |
636 | 20.10 Severity system tasks |
637 | 20.10.1 Elaboration severity system tasks |
638 | 20.11 Assertion control system tasks |
645 | 20.12 Sampled value system functions 20.13 Coverage system functions 20.14 Probabilistic distribution functions |
646 | 20.14.1 $random function 20.14.2 Distribution functions |
647 | 20.15 Stochastic analysis tasks and functions |
648 | 20.15.1 $q_initialize 20.15.2 $q_add 20.15.3 $q_remove 20.15.4 $q_full 20.15.5 $q_exam |
649 | 20.15.6 Status codes 20.16 Programmable logic array modeling system tasks |
650 | 20.16.1 Array types 20.16.2 Array logic types |
651 | 20.16.3 Logic array personality declaration and loading 20.16.4 Logic array personality formats |
653 | 20.17 Miscellaneous tasks and functions 20.17.1 $system |
654 | 20.17.2 $stacktrace |
655 | 21. Input/output system tasks and system functions 21.1 General 21.2 Display system tasks 21.2.1 The display and write tasks |
657 | 21.2.1.1 Format specifications |
659 | 21.2.1.2 Size of displayed data |
661 | 21.2.1.3 Unknown and high-impedance values 21.2.1.4 Strength format |
663 | 21.2.1.5 Hierarchical name format 21.2.1.6 Assignment pattern format |
664 | 21.2.1.7 String format 21.2.2 Strobed monitoring |
666 | 21.2.3 Continuous monitoring 21.3 File input/output system tasks and system functions 21.3.1 Opening and closing files |
668 | 21.3.2 File output system tasks |
669 | 21.3.3 Formatting data to a string |
670 | 21.3.4 Reading data from a file 21.3.4.1 Reading a character at a time |
671 | 21.3.4.2 Reading a line at a time 21.3.4.3 Reading formatted data |
674 | 21.3.4.4 Reading binary data |
675 | 21.3.5 File positioning |
676 | 21.3.6 Flushing output 21.3.7 I/O error status 21.3.8 Detecting EOF |
677 | 21.4 Loading memory array data from a file |
679 | 21.4.1 Reading packed data 21.4.2 Reading 2-state types 21.4.3 File format considerations for multidimensional unpacked arrays |
680 | 21.5 Writing memory array data to a file |
681 | 21.5.1 Writing packed data 21.5.2 Writing 2-state types 21.5.3 Writing addresses to output file 21.6 Command line input |
684 | 21.7 Value change dump (VCD) files 21.7.1 Creating 4-state VCD file |
685 | 21.7.1.1 Specifying name of dump file ($dumpfile) 21.7.1.2 Specifying variables to be dumped ($dumpvars) |
686 | 21.7.1.3 Stopping and resuming the dump ($dumpoff/$dumpon) |
687 | 21.7.1.4 Generating a checkpoint ($dumpall) 21.7.1.5 Limiting size of dump file ($dumplimit) 21.7.1.6 Reading dump file during simulation ($dumpflush) |
688 | 21.7.2 Format of 4-state VCD file 21.7.2.1 Syntax of 4-state VCD file |
690 | 21.7.2.2 Formats of variable values |
691 | 21.7.2.3 Description of keyword commands |
693 | 21.7.2.4 4-state VCD file format example |
694 | 21.7.3 Creating extended VCD file 21.7.3.1 Specifying dump file name and ports to be dumped ($dumpports) |
695 | 21.7.3.2 Stopping and resuming the dump ($dumpportsoff/$dumpportson) |
696 | 21.7.3.3 Generating a checkpoint ($dumpportsall) 21.7.3.4 Limiting size of dump file ($dumpportslimit) |
697 | 21.7.3.5 Reading dump file during simulation ($dumpportsflush) 21.7.3.6 Description of keyword commands 21.7.3.6.1 $vcdclose 21.7.3.7 General rules for extended VCD system tasks |
698 | 21.7.4 Format of extended VCD file 21.7.4.1 Syntax of extended VCD file |
699 | 21.7.4.2 Extended VCD node information |
701 | 21.7.4.3 Value changes 21.7.4.3.1 State characters |
702 | 21.7.4.3.2 Drivers 21.7.4.4 Extended VCD file format example |
703 | 21.7.5 VCD SystemVerilog type mappings |
705 | 22. Compiler directives 22.1 General 22.2 Overview |
706 | 22.3 `resetall 22.4 `include |
707 | 22.5 `define, `undef, and `undefineall 22.5.1 `define |
713 | 22.5.2 `undef 22.5.3 `undefineall 22.6 `ifdef, `else, `elsif, `endif, `ifndef |
717 | 22.7 `timescale |
719 | 22.8 `default_nettype 22.9 `unconnected_drive and `nounconnected_drive 22.10 `celldefine and `endcelldefine 22.11 `pragma |
720 | 22.11.1 Standard pragmas 22.12 `line |
721 | 22.13 `__FILE__ and `__LINE__ |
722 | 22.14 `begin_keywords, `end_keywords |
723 | 22.14.1 Examples |
724 | 22.14.2 IEEE Std 1364-1995 keywords 22.14.3 IEEE Std 1364-2001 keywords |
725 | 22.14.4 IEEE Std 1364-2001-noconfig keywords 22.14.5 IEEE Std 1364-2005 keywords 22.14.6 IEEE Std 1800-2005 keywords |
726 | 22.14.7 IEEE Std 1800-2009 keywords |
727 | 22.14.8 IEEE Std 1800-2012 keywords 22.14.9 IEEE Std 1800-2017 and IEEE Std 1800-2023 keywords |
728 | Part Two: Hierarchy Constructs |
729 | 23. Modules and hierarchy 23.1 General 23.2 Module definitions 23.2.1 Module header definition |
731 | 23.2.2 Port declarations 23.2.2.1 Non-ANSI style port declarations |
734 | 23.2.2.2 ANSI style list of port declarations |
736 | 23.2.2.3 Rules for determining port kind, data type, and direction |
738 | 23.2.2.4 Default port values |
739 | 23.2.3 Parameterized modules |
740 | 23.2.4 Module contents |
741 | 23.3 Module instances (hierarchy) 23.3.1 Top-level modules and $root 23.3.2 Module instantiation syntax |
743 | 23.3.2.1 Connecting module instance ports by ordered list |
744 | 23.3.2.2 Connecting module instance ports by name |
745 | 23.3.2.3 Connecting module instance using implicit named port connections (.name) |
746 | 23.3.2.4 Connecting module instances using wildcard named port connections ( .*) |
747 | 23.3.3 Port connection rules |
748 | 23.3.3.1 Port coercion 23.3.3.2 Port connection rules for variables 23.3.3.3 Port connection rules for nets with built-in net types 23.3.3.4 Port connection rules for interfaces |
749 | 23.3.3.5 Unpacked array ports and arrays of instances |
750 | 23.3.3.6 Single source nets (uwire) 23.3.3.7 Port connections with dissimilar net types (net and port collapsing) |
751 | 23.3.3.7.1 Port connections with interconnect net types |
752 | 23.3.3.7.2 Terminal connections with interconnect net types 23.3.3.8 Connecting signed values via ports 23.4 Nested modules |
753 | 23.5 Extern modules |
754 | 23.6 Hierarchical names |
758 | 23.7 Member selects and hierarchical names |
759 | 23.7.1 Names with package or class scope resolution operator prefixes |
760 | 23.8 Upwards name referencing |
761 | 23.8.1 Task and function name resolution |
762 | 23.9 Scope rules |
764 | 23.10 Overriding module parameters |
765 | 23.10.1 defparam statement |
767 | 23.10.2 Module instance parameter value assignment 23.10.2.1 Parameter value assignment by ordered list |
768 | 23.10.2.2 Parameter value assignment by name |
769 | 23.10.3 Parameter dependence |
770 | 23.10.4 Elaboration considerations 23.10.4.1 Order of elaboration |
771 | 23.10.4.2 Early resolution of hierarchical names |
772 | 23.11 Binding auxiliary code to scopes or instances |
775 | 24. Programs 24.1 General 24.2 Overview 24.3 The program construct |
778 | 24.3.1 Scheduling semantics of code in program constructs 24.3.2 Operation of program port connections in the absence of clocking blocks |
779 | 24.4 Eliminating testbench races 24.5 Blocking tasks in cycle/event mode |
780 | 24.6 Program-wide space and anonymous programs 24.7 Program control tasks |
781 | 25. Interfaces 25.1 General 25.2 Overview |
782 | 25.3 Interface syntax |
784 | 25.3.1 Example without using interfaces 25.3.2 Interface example using a named bundle |
785 | 25.3.3 Interface example using a generic bundle |
786 | 25.4 Ports in interfaces |
787 | 25.5 Modports |
789 | 25.5.1 Example of named port bundle |
790 | 25.5.2 Example of connecting port bundle 25.5.3 Example of connecting port bundle to generic interface |
791 | 25.5.4 Modport expressions |
792 | 25.5.5 Clocking blocks and modports |
793 | 25.6 Interfaces and specify blocks |
794 | 25.7 Tasks and functions in interfaces 25.7.1 Example of using tasks in interface |
795 | 25.7.2 Example of using tasks in modports |
797 | 25.7.3 Example of exporting tasks and functions |
798 | 25.7.4 Example of multiple task exports |
800 | 25.8 Parameterized interfaces |
802 | 25.9 Virtual interfaces |
804 | 25.9.1 Virtual interfaces and clocking blocks |
805 | 25.9.2 Virtual interface modports and clocking blocks |
807 | 25.10 Access to interface objects |
808 | 26. Packages 26.1 General 26.2 Package declarations |
809 | 26.3 Referencing data in packages |
813 | 26.4 Using packages in module headers |
814 | 26.5 Search order rules |
816 | 26.6 Exporting imported names from packages |
817 | 26.7 The std built-in package |
819 | 27. Generate constructs 27.1 General 27.2 Overview 27.3 Generate construct syntax |
821 | 27.4 Loop generate constructs |
825 | 27.5 Conditional generate constructs |
828 | 27.6 External names for unnamed generate blocks |
830 | 28. Gate-level and switch-level modeling 28.1 General 28.2 Overview 28.3 Gate and switch declaration syntax |
831 | 28.3.1 The gate type specification |
832 | 28.3.2 The drive strength specification |
833 | 28.3.3 The delay specification 28.3.4 The primitive instance identifier 28.3.5 The range specification |
834 | 28.3.6 Primitive instance connection list |
836 | 28.4 and, nand, nor, or, xor, and xnor gates |
837 | 28.5 buf and not gates |
838 | 28.6 bufif1, bufif0, notif1, and notif0 gates |
839 | 28.7 MOS switches |
840 | 28.8 Bidirectional pass switches |
841 | 28.9 CMOS switches |
842 | 28.10 pullup and pulldown sources |
843 | 28.11 Logic strength modeling |
844 | 28.12 Strengths and values of combined signals 28.12.1 Combined signals of unambiguous strength |
845 | 28.12.2 Ambiguous strengths: sources and combinations |
850 | 28.12.3 Ambiguous strength signals and unambiguous signals |
854 | 28.12.4 Wired logic net types |
856 | 28.13 Strength reduction by nonresistive devices 28.14 Strength reduction by resistive devices 28.15 Strengths of net types 28.15.1 tri0 and tri1 net strengths 28.15.2 trireg strength |
857 | 28.15.3 supply0 and supply1 net strengths 28.16 Gate and net delays |
858 | 28.16.1 min:typ:max delays |
859 | 28.16.2 trireg net charge decay 28.16.2.1 Charge decay process 28.16.2.2 Delay specification for charge decay time |
861 | 29. User-defined primitives 29.1 General 29.2 Overview 29.3 UDP definition |
863 | 29.3.1 UDP header 29.3.2 UDP port declarations 29.3.3 Sequential UDP initial statement 29.3.4 UDP state table |
864 | 29.3.5 z values in UDP 29.3.6 Summary of symbols |
865 | 29.4 Combinational UDPs |
866 | 29.5 Level-sensitive sequential UDPs 29.6 Edge-sensitive sequential UDPs |
867 | 29.7 Sequential UDP initialization |
869 | 29.8 UDP instances |
870 | 29.9 Mixing level-sensitive and edge-sensitive descriptions |
871 | 29.10 Level-sensitive dominance |
872 | 30. Specify blocks 30.1 General 30.2 Overview 30.3 Specify block declaration |
873 | 30.4 Module path declarations 30.4.1 Module path restrictions |
874 | 30.4.2 Simple module paths |
875 | 30.4.3 Edge-sensitive paths |
876 | 30.4.4 State-dependent paths 30.4.4.1 Conditional expression |
877 | 30.4.4.2 Simple state-dependent paths |
878 | 30.4.4.3 Edge-sensitive state-dependent paths |
879 | 30.4.4.4 The ifnone condition |
880 | 30.4.5 Full connection and parallel connection paths |
881 | 30.4.6 Declaring multiple module paths in a single statement 30.4.7 Module path polarity |
882 | 30.4.7.1 Unknown polarity 30.4.7.2 Positive polarity 30.4.7.3 Negative polarity 30.5 Assigning delays to module paths |
883 | 30.5.1 Specifying transition delays on module paths |
885 | 30.5.2 Specifying x transition delays |
886 | 30.5.3 Delay selection 30.6 Mixing module path delays and distributed delays |
887 | 30.7 Detailed control of pulse filtering behavior |
888 | 30.7.1 Specify block control of pulse limit values |
889 | 30.7.2 Global control of pulse limit values 30.7.3 SDF annotation of pulse limit values 30.7.4 Detailed pulse control capabilities |
890 | 30.7.4.1 On-event versus on-detect pulse filtering |
891 | 30.7.4.2 Negative pulse detection |
896 | 31. Timing checks 31.1 General 31.2 Overview |
899 | 31.3 Timing checks using a stability window 31.3.1 $setup |
900 | 31.3.2 $hold |
901 | 31.3.3 $setuphold |
902 | 31.3.4 $removal |
903 | 31.3.5 $recovery |
904 | 31.3.6 $recrem |
906 | 31.4 Timing checks for clock and control signals 31.4.1 $skew |
907 | 31.4.2 $timeskew |
909 | 31.4.3 $fullskew |
912 | 31.4.4 $width |
913 | 31.4.5 $period |
914 | 31.4.6 $nochange |
915 | 31.5 Edge-control specifiers |
916 | 31.6 Notifiers: user-defined responses to timing violations |
918 | 31.7 Enabling timing checks with conditioned events |
919 | 31.8 Vector signals in timing checks |
920 | 31.9 Negative timing checks |
921 | 31.9.1 Requirements for accurate simulation |
923 | 31.9.2 Conditions in negative timing checks |
924 | 31.9.3 Notifiers in negative timing checks 31.9.4 Option behavior |
925 | 32. Backannotation using the standard delay format 32.1 General 32.2 Overview 32.3 The SDF annotator 32.4 Mapping of SDF constructs to SystemVerilog |
926 | 32.4.1 Mapping of SDF delay constructs to SystemVerilog declarations |
927 | 32.4.2 Mapping of SDF timing check constructs to SystemVerilog |
928 | 32.4.3 SDF annotation of specparams |
929 | 32.4.4 SDF annotation of interconnect delays |
930 | 32.5 Multiple annotations |
931 | 32.6 Multiple SDF files 32.7 Pulse limit annotation |
932 | 32.8 SDF to SystemVerilog delay value mapping |
933 | 32.9 Loading timing data from an SDF file |
935 | 33. Configuring the contents of a design 33.1 General 33.2 Overview 33.2.1 Library notation |
936 | 33.2.2 Basic configuration elements 33.3 Libraries 33.3.1 Specifying libraries—the library map file |
937 | 33.3.1.1 File path resolution |
938 | 33.3.2 Using multiple library map files 33.3.3 Mapping source files to libraries 33.4 Configurations |
939 | 33.4.1 Basic configuration syntax 33.4.1.1 Design statement 33.4.1.2 The default clause |
940 | 33.4.1.3 The instance clause 33.4.1.4 The cell clause 33.4.1.5 The liblist clause 33.4.1.6 The use clause 33.4.2 Hierarchical configurations |
941 | 33.4.3 Setting parameters in configurations |
944 | 33.5 Using libraries and configs 33.5.1 Precompiling in a single-pass use model |
945 | 33.5.2 Elaboration-time compiling in a single-pass use model 33.5.3 Precompiling using a separate compilation tool 33.5.4 Command line considerations 33.6 Configuration examples |
946 | 33.6.1 Default configuration from library map file 33.6.2 Using default clause 33.6.3 Using cell clause 33.6.4 Using instance clause |
947 | 33.6.5 Using hierarchical config 33.7 Displaying library binding information 33.8 Library mapping examples |
948 | 33.8.1 Using the command line to control library searching 33.8.2 File path specification examples 33.8.3 Resolving multiple path specifications |
950 | 34. Protected envelopes 34.1 General 34.2 Overview 34.3 Processing protected envelopes |
951 | 34.3.1 Encryption |
952 | 34.3.2 Decryption 34.4 Protect pragma directives |
954 | 34.5 Protect pragma keywords 34.5.1 begin 34.5.1.1 Syntax 34.5.1.2 Description 34.5.2 end 34.5.2.1 Syntax 34.5.2.2 Description |
955 | 34.5.3 begin_protected 34.5.3.1 Syntax 34.5.3.2 Description 34.5.4 end_protected 34.5.4.1 Syntax 34.5.4.2 Description 34.5.5 author 34.5.5.1 Syntax 34.5.5.2 Description |
956 | 34.5.6 author_info 34.5.6.1 Syntax 34.5.6.2 Description 34.5.7 encrypt_agent 34.5.7.1 Syntax 34.5.7.2 Description 34.5.8 encrypt_agent_info 34.5.8.1 Syntax 34.5.8.2 Description |
957 | 34.5.9 encoding 34.5.9.1 Syntax 34.5.9.2 Description |
958 | 34.5.10 data_keyowner 34.5.10.1 Syntax 34.5.10.2 Description 34.5.11 data_method 34.5.11.1 Syntax 34.5.11.2 Description |
959 | 34.5.12 data_keyname 34.5.12.1 Syntax 34.5.12.2 Description |
960 | 34.5.13 data_public_key 34.5.13.1 Syntax 34.5.13.2 Description 34.5.14 data_decrypt_key 34.5.14.1 Syntax 34.5.14.2 Description |
961 | 34.5.15 data_block 34.5.15.1 Syntax 34.5.15.2 Description 34.5.16 digest_keyowner 34.5.16.1 Syntax 34.5.16.2 Description 34.5.17 digest_key_method 34.5.17.1 Syntax |
962 | 34.5.17.2 Description 34.5.18 digest_keyname 34.5.18.1 Syntax 34.5.18.2 Description 34.5.19 digest_public_key 34.5.19.1 Syntax 34.5.19.2 Description |
963 | 34.5.20 digest_decrypt_key 34.5.20.1 Syntax 34.5.20.2 Description 34.5.21 digest_method 34.5.21.1 Syntax 34.5.21.2 Description |
964 | 34.5.22 digest_block 34.5.22.1 Syntax 34.5.22.2 Description |
965 | 34.5.23 key_keyowner 34.5.23.1 Syntax 34.5.23.2 Description 34.5.24 key_method 34.5.24.1 Syntax 34.5.24.2 Description 34.5.25 key_keyname 34.5.25.1 Syntax 34.5.25.2 Description |
966 | 34.5.26 key_public_key 34.5.26.1 Syntax 34.5.26.2 Description 34.5.27 key_block 34.5.27.1 Syntax 34.5.27.2 Description |
967 | 34.5.28 decrypt_license 34.5.28.1 Syntax 34.5.28.2 Description 34.5.29 runtime_license 34.5.29.1 Syntax 34.5.29.2 Description |
968 | 34.5.30 comment 34.5.30.1 Syntax 34.5.30.2 Description 34.5.31 reset 34.5.31.1 Syntax 34.5.31.2 Description |
969 | 34.5.32 viewport 34.5.32.1 Syntax 34.5.32.2 Description |
970 | Part Three: Application Programming Interfaces |
971 | 35. Direct programming interface 35.1 General 35.2 Overview 35.2.1 Tasks and functions |
972 | 35.2.2 Data types 35.2.2.1 Data representation 35.3 Two layers of DPI |
973 | 35.3.1 DPI SystemVerilog layer 35.3.2 DPI foreign language layer 35.4 Global name space of imported and exported functions |
974 | 35.5 Imported tasks and functions 35.5.1 Required properties of imported tasks and functions—semantic constraints 35.5.1.1 Instant completion of imported functions 35.5.1.2 input, output, and inout arguments 35.5.1.3 Special properties pure and context |
975 | 35.5.1.4 Memory management 35.5.1.5 Reentrancy of imported tasks 35.5.1.6 C++ exceptions 35.5.2 Pure functions |
976 | 35.5.3 Context tasks and functions |
978 | 35.5.4 Import declarations |
980 | 35.5.5 Function result 35.5.6 Types of formal arguments |
981 | 35.5.6.1 Open arrays |
982 | 35.6 Calling imported functions 35.6.1 Argument passing 35.6.1.1 WYSIWYG principle |
983 | 35.6.2 Value changes for output and inout arguments 35.7 Exported functions |
984 | 35.8 Exported tasks 35.9 Disabling DPI tasks and functions |
986 | 36. Programming language interface (PLI/VPI) overview 36.1 General 36.2 PLI purpose and history |
987 | 36.3 User-defined system task and system function names 36.3.1 Defining system task and system function names 36.3.2 Overriding built-in system task and system function names |
988 | 36.4 User-defined system task and system function arguments 36.5 User-defined system task and system function types 36.6 User-supplied PLI applications 36.7 PLI include files 36.8 VPI sizetf, compiletf, and calltf routines |
989 | 36.8.1 sizetf VPI application routine 36.8.2 compiletf VPI application routine 36.8.3 calltf VPI application routine 36.8.4 Arguments to sizetf, compiletf, and calltf application routines 36.9 PLI mechanism |
990 | 36.9.1 Registering user-defined system tasks and system functions 36.9.2 Registering simulation callbacks |
991 | 36.10 VPI access to SystemVerilog objects and simulation objects 36.10.1 Error handling 36.10.2 Function availability |
992 | 36.10.3 Traversing expressions 36.11 List of VPI routines by functional category |
994 | 36.12 VPI backwards compatibility features and limitations |
995 | 36.12.1 VPI Incompatibilities with other standard versions |
996 | 36.12.2 VPI Mechanisms to deal with incompatibilities |
997 | 36.12.2.1 Mechanism 1: Compile-based binding to a compatibility mode |
998 | 36.12.2.2 Mechanism 2: Selection of default VPI compatibility mode run by host simulator 36.12.3 Limitations of VPI compatibility mechanisms |
999 | 37. VPI object model diagrams 37.1 General 37.2 VPI handles 37.2.1 Handle creation 37.2.2 Handle release |
1000 | 37.2.3 Handle comparison 37.2.4 Validity of handles 37.3 VPI object classifications |
1001 | 37.3.1 Accessing object relationships and properties |
1002 | 37.3.2 Object type properties |
1003 | 37.3.3 Object file and line properties 37.3.4 Delays and values |
1004 | 37.3.5 Expressions with side effects |
1005 | 37.3.6 Object protection properties 37.3.7 Lifetimes of objects |
1006 | 37.3.8 Managing transient objects 37.4 Key to data model diagrams |
1007 | 37.4.1 Diagram key for objects and classes 37.4.2 Diagram key for accessing properties |
1008 | 37.4.3 Diagram key for traversing relationships |
1009 | 37.5 Module |
1010 | 37.6 Interface 37.7 Modport 37.8 Interface task or function declaration |
1011 | 37.9 Program |
1012 | 37.10 Instance |
1014 | 37.11 Instance arrays |
1015 | 37.12 Scope |
1016 | 37.13 IO declaration |
1017 | 37.14 Ports |
1018 | 37.15 Reference objects |
1020 | 37.16 Nets |
1026 | 37.17 Variables |
1030 | 37.18 Packed array variables |
1031 | 37.19 Variable select |
1032 | 37.20 Memory 37.21 Variable drivers and loads |
1033 | 37.22 Object range 37.23 Nettype declaration |
1034 | 37.24 Generic interconnect |
1035 | 37.25 Typespec |
1037 | 37.26 Structures and unions |
1038 | 37.27 Named events |
1039 | 37.28 Parameter, spec param, def param, param assign |
1040 | 37.29 Virtual interface |
1042 | 37.30 Interface typespec |
1043 | 37.31 Class definition |
1044 | 37.32 Class typespec |
1046 | 37.33 Class variables and class objects |
1048 | 37.34 Constraint, constraint ordering, distribution |
1049 | 37.35 Primitive, prim term |
1050 | 37.36 UDP 37.37 Intermodule path |
1051 | 37.38 Constraint expression |
1052 | 37.39 Module path, path term |
1053 | 37.40 Timing check |
1054 | 37.41 Task and function declaration |
1055 | 37.42 Task and function call |
1057 | 37.43 Frames |
1058 | 37.44 Threads 37.45 Delay terminals |
1059 | 37.46 Net drivers and loads |
1060 | 37.47 Continuous assignment |
1061 | 37.48 Clocking block |
1062 | 37.49 Assertion |
1063 | 37.50 Concurrent assertion |
1064 | 37.51 Property declaration |
1065 | 37.52 Property specification |
1066 | 37.53 Sequence declaration |
1067 | 37.54 Sequence expression |
1068 | 37.55 Immediate assertions |
1069 | 37.56 Multiclock sequence expression 37.57 Let |
1070 | 37.58 Simple expressions |
1071 | 37.59 Expressions |
1074 | 37.60 Atomic statement |
1075 | 37.61 Dynamic prefixing |
1076 | 37.62 Event statement 37.63 Process |
1077 | 37.64 Assignment 37.65 Event control |
1078 | 37.66 While, repeat 37.67 Waits 37.68 Delay control |
1079 | 37.69 Repeat control 37.70 Forever 37.71 If, if–else |
1080 | 37.72 Case, pattern |
1081 | 37.73 Expect 37.74 For 37.75 Do-while, foreach |
1082 | 37.76 Alias statement 37.77 Disables 37.78 Return statement |
1083 | 37.79 Assign statement, deassign, force, release 37.80 Callback |
1084 | 37.81 Time queue 37.82 Active time format |
1085 | 37.83 Attribute |
1086 | 37.84 Iterator |
1087 | 37.85 Generates |
1089 | 38. VPI routine definitions 38.1 General 38.2 vpi_chk_error() |
1090 | 38.3 vpi_compare_objects() |
1092 | 38.4 vpi_control() |
1093 | 38.5 vpi_flush() 38.6 vpi_get() |
1094 | 38.7 vpi_get64() 38.8 vpi_get_cb_info() |
1095 | 38.9 vpi_get_data() |
1096 | 38.10 vpi_get_delays() |
1098 | 38.11 vpi_get_str() |
1099 | 38.12 vpi_get_systf_info() |
1100 | 38.13 vpi_get_time() |
1101 | 38.14 vpi_get_userdata() 38.15 vpi_get_value() |
1107 | 38.16 vpi_get_value_array() |
1111 | 38.17 vpi_get_vlog_info() |
1112 | 38.18 vpi_handle() |
1113 | 38.19 vpi_handle_by_index() 38.20 vpi_handle_by_multi_index() |
1114 | 38.21 vpi_handle_by_name() |
1115 | 38.22 vpi_handle_multi() 38.23 vpi_iterate() |
1116 | 38.24 vpi_mcd_close() |
1117 | 38.25 vpi_mcd_flush() 38.26 vpi_mcd_name() |
1118 | 38.27 vpi_mcd_open() |
1119 | 38.28 vpi_mcd_printf() |
1120 | 38.29 vpi_mcd_vprintf() 38.30 vpi_printf() |
1121 | 38.31 vpi_put_data() |
1123 | 38.32 vpi_put_delays() |
1126 | 38.33 vpi_put_userdata() 38.34 vpi_put_value() |
1129 | 38.35 vpi_put_value_array() |
1133 | 38.36 vpi_register_cb() |
1134 | 38.36.1 Simulation event callbacks |
1137 | 38.36.1.1 Callbacks on individual statements 38.36.1.2 Behavior by statement type |
1138 | 38.36.1.3 Registering callbacks on module-wide basis 38.36.2 Simulation time callbacks |
1139 | 38.36.3 Simulator action or feature callbacks |
1141 | 38.37 vpi_register_systf() |
1142 | 38.37.1 System task and system function callbacks |
1143 | 38.37.2 Initializing VPI system task or system function callbacks |
1144 | 38.37.3 Registering multiple system tasks and system functions |
1145 | 38.38 vpi_release_handle() 38.39 vpi_remove_cb() |
1146 | 38.40 vpi_scan() |
1147 | 38.41 vpi_vprintf() |
1148 | 39. Assertion API 39.1 General 39.2 Overview 39.3 Static information 39.3.1 Obtaining assertion handles |
1149 | 39.3.2 Obtaining static assertion information 39.4 Dynamic information 39.4.1 Placing assertion system callbacks |
1150 | 39.4.2 Placing assertions callbacks |
1153 | 39.4.2.1 Placing callbacks for assertions with global clocking future sampled value functions 39.5 Control functions 39.5.1 Assertion system control |
1155 | 39.5.2 Assertion control |
1156 | 39.5.3 VPI functions on deferred assertions and procedural concurrent assertions |
1157 | 40. Code coverage control and API 40.1 General 40.2 Overview 40.2.1 SystemVerilog coverage API 40.2.2 Nomenclature |
1158 | 40.3 SystemVerilog real-time coverage access 40.3.1 Predefined coverage constants in SystemVerilog 40.3.2 Built-in coverage access system functions 40.3.2.1 $coverage_control |
1162 | 40.3.2.2 $coverage_get_max 40.3.2.3 $coverage_get 40.3.2.4 $coverage_merge |
1163 | 40.3.2.5 $coverage_save 40.4 FSM recognition 40.4.1 Specifying signal that holds current state |
1164 | 40.4.2 Specifying part-select that holds current state 40.4.3 Specifying concatenation that holds current state 40.4.4 Specifying signal that holds next state |
1165 | 40.4.5 Specifying current and next state signals in same declaration 40.4.6 Specifying possible states of FSM 40.4.7 Pragmas in one-line comments 40.4.8 Example |
1166 | 40.5 VPI coverage extensions 40.5.1 Extensions to VPI enumerations |
1167 | 40.5.2 Obtaining coverage information |
1169 | 40.5.3 Controlling coverage |
1171 | 41. Data read API |
1172 | Part Four: Annexes |
1173 | Annex A (normative) Formal syntax A.1 Source text A.1.1 Library source text A.1.2 SystemVerilog source text |
1175 | A.1.3 Module parameters and ports |
1176 | A.1.4 Module items |
1177 | A.1.5 Configuration source text |
1178 | A.1.6 Interface items A.1.7 Program items A.1.8 Checker items |
1179 | A.1.9 Class items |
1180 | A.1.10 Constraints |
1181 | A.1.11 Package items |
1182 | A.2 Declarations A.2.1 Declaration types A.2.1.1 Module parameter declarations A.2.1.2 Port declarations A.2.1.3 Type declarations |
1183 | A.2.2 Declaration data types A.2.2.1 Net and variable types |
1185 | A.2.2.2 Strengths A.2.2.3 Delays A.2.3 Declaration lists |
1186 | A.2.4 Declaration assignments A.2.5 Declaration ranges |
1187 | A.2.6 Function declarations A.2.7 Task declarations |
1188 | A.2.8 Block item declarations A.2.9 Interface declarations A.2.10 Assertion declarations |
1192 | A.2.11 Covergroup declarations |
1194 | A.2.12 Let declarations A.3 Primitive instances A.3.1 Primitive instantiation and instances |
1195 | A.3.2 Primitive strengths A.3.3 Primitive terminals A.3.4 Primitive gate and switch types A.4 Instantiations A.4.1 Instantiation A.4.1.1 Module instantiation |
1196 | A.4.1.2 Interface instantiation A.4.1.3 Program instantiation A.4.1.4 Checker instantiation A.4.2 Generated instantiation |
1197 | A.5 UDP declaration and instantiation A.5.1 UDP declaration A.5.2 UDP ports A.5.3 UDP body |
1198 | A.5.4 UDP instantiation A.6 Behavioral statements A.6.1 Continuous assignment and net alias statements A.6.2 Procedural blocks and assignments |
1199 | A.6.3 Parallel and sequential blocks A.6.4 Statements |
1200 | A.6.5 Timing control statements |
1201 | A.6.6 Conditional statements A.6.7 Case statements |
1202 | A.6.7.1 Patterns A.6.8 Looping statements |
1203 | A.6.9 Subroutine call statements A.6.10 Assertion statements |
1204 | A.6.11 Clocking block A.6.12 Randsequence |
1205 | A.7 Specify section A.7.1 Specify block declaration A.7.2 Specify path declarations |
1206 | A.7.3 Specify block terminals A.7.4 Specify path delays |
1207 | A.7.5 System timing checks A.7.5.1 System timing check commands |
1208 | A.7.5.2 System timing check command arguments A.7.5.3 System timing check event definitions |
1209 | A.8 Expressions A.8.1 Concatenations A.8.2 Subroutine calls |
1210 | A.8.3 Expressions |
1211 | A.8.4 Primaries |
1213 | A.8.5 Expression left-side values A.8.6 Operators A.8.7 Numbers |
1214 | A.8.8 Strings A.9 General A.9.1 Attributes A.9.2 Comments |
1215 | A.9.3 Identifiers |
1217 | A.9.4 White space A.10 BNF clarifications |
1220 | Annex B (normative) Keywords |
1222 | Annex C (normative) Deprecation C.1 General C.2 Constructs that have been deprecated C.2.1 PLI TF and ACC routine libraries C.2.2 $sampled with a clocking event argument C.2.3 ended sequence method C.2.4 vpi_free_object() C.2.5 Data read API |
1223 | C.2.6 Linked lists C.2.7 always statement in checkers C.2.8 Operator overloading C.3 Accellera SystemVerilog 3.1a-compatible access to packed data C.4 Constructs identified for deprecation C.4.1 Defparam statements |
1224 | C.4.2 Procedural assign and deassign statements |
1225 | C.4.3 VPI definitions |
1226 | Annex D (informative) Optional system tasks and system functions D.1 General D.2 $countdrivers |
1227 | D.3 $getpattern |
1228 | D.4 $input D.5 $key and $nokey D.6 $list D.7 $log and $nolog |
1229 | D.8 $reset, $reset_count, and $reset_value |
1230 | D.9 $save, $restart, and $incsave |
1231 | D.10 $scale D.11 $scope D.12 $showscopes D.13 $showvars D.14 $sreadmemb and $sreadmemh |
1233 | Annex E (informative) Optional compiler directives E.1 General E.2 `default_decay_time E.3 `default_trireg_strength |
1234 | E.4 `delay_mode_distributed E.5 `delay_mode_path E.6 `delay_mode_unit E.7 `delay_mode_zero |
1235 | Annex F (normative) Formal semantics of concurrent assertions F.1 General F.2 Overview |
1236 | F.3 Abstract syntax F.3.1 Clock control |
1237 | F.3.2 Abstract grammars |
1238 | F.3.3 Notations |
1239 | F.3.4 Derived forms F.3.4.1 Derived assertion statements F.3.4.2 Derived sequence operators F.3.4.2.1 Derived consecutive repetition operators F.3.4.2.2 Derived delay and concatenation operators F.3.4.2.3 Derived nonconsecutive repetition operators |
1240 | F.3.4.2.4 Other derived operators F.3.4.3 Derived property operators F.3.4.3.1 Derived sequential property F.3.4.3.2 Derived Boolean operators F.3.4.3.3 Derived nonoverlapping implication operator F.3.4.3.4 Derived conditional operators F.3.4.3.5 Derived case operators F.3.4.3.6 Derived followed_by operators F.3.4.3.7 Derived abort operators |
1241 | F.3.4.3.8 Derived unbounded temporal operators F.3.4.3.9 Derived bounded temporal operators F.3.4.4 Derived sampled value functions F.3.4.5 Other derived operators F.3.4.6 Free checker variable assignment |
1242 | F.4 Rewriting algorithms F.4.1 Rewriting sequence and property instances F.4.1.1 The rewriting algorithm |
1244 | F.4.2 Rewriting checkers F.4.2.1 The rewriting algorithm |
1245 | F.4.3 Rewriting local variable declaration assignments |
1246 | F.5 Semantics |
1247 | F.5.1 Rewrite rules for clocks F.5.1.1 Rewrite rules for sequences F.5.1.2 Rewrite rules for properties |
1248 | F.5.2 Tight satisfaction without local variables F.5.3 Satisfaction without local variables F.5.3.1 Neutral satisfaction |
1250 | F.5.3.2 Weak and strong satisfaction by finite words F.5.3.3 Vacuity |
1252 | F.5.4 Local variable flow |
1253 | F.5.5 Tight satisfaction with local variables |
1254 | F.5.6 Satisfaction with local variables F.5.6.1 Neutral satisfaction |
1255 | F.5.6.2 Weak and strong satisfaction by finite words F.5.6.3 Vacuity |
1256 | F.6 Extended expressions F.6.1 Extended Booleans F.6.2 Past F.6.3 Future F.7 Recursive properties |
1258 | Annex G (normative) Std package G.1 General G.2 Overview G.3 Semaphore G.4 Mailbox |
1259 | G.5 Randomize G.6 Process G.7 Weak reference |
1260 | Annex H (normative) DPI C layer H.1 General H.2 Overview |
1261 | H.3 Naming conventions H.4 Portability H.5 svdpi.h include file |
1262 | H.6 Semantic constraints |
1263 | H.6.1 Types of formal arguments H.6.2 Input arguments H.6.3 Output arguments H.6.4 Value changes for output and inout arguments H.6.5 Context and noncontext tasks and functions |
1264 | H.6.6 Memory management H.7 Data types H.7.1 Limitations |
1265 | H.7.2 Duality of types: SystemVerilog types versus C types H.7.3 Data representation H.7.4 Basic types |
1266 | H.7.5 Normalized and linearized ranges |
1267 | H.7.6 Mapping between SystemVerilog ranges and C ranges H.7.7 Canonical representation of packed arrays |
1268 | H.7.8 Unpacked aggregate arguments H.8 Argument passing modes H.8.1 Overview H.8.2 Calling SystemVerilog tasks and functions from C H.8.3 Argument passing by value |
1269 | H.8.4 Argument passing by reference H.8.5 Allocating actual arguments for SystemVerilog-specific types H.8.6 Argument passing by handle—open arrays H.8.7 Input arguments H.8.8 Inout and output arguments |
1270 | H.8.9 Function result H.8.10 String arguments |
1271 | H.8.10.1 String types in aggregate arguments H.9 Context tasks and functions H.9.1 Overview of DPI and VPI context |
1272 | H.9.2 Context of imported and exported tasks and functions H.9.3 Working with DPI context tasks and functions in C code |
1274 | H.9.4 Example 1—Using DPI context functions |
1275 | H.9.5 Relationship between DPI and VPI H.10 Include files H.10.1 Include file svdpi.h |
1276 | H.10.1.1 Scalars of type bit and logic H.10.1.2 Canonical representation of packed arrays |
1277 | H.10.1.3 Implementation-dependent representation H.10.2 Example 2—Simple packed array application H.10.3 Example 3—Application with complex mix of types |
1278 | H.11 Arrays |
1279 | H.11.1 Example 4—Using packed 2-state arguments H.11.2 Multidimensional arrays H.11.3 Example 5—Using packed struct and union arguments |
1280 | H.11.4 Direct access to unpacked arrays H.11.5 Utility functions for working with the canonical representation |
1281 | H.12 Open arrays H.12.1 Actual ranges |
1282 | H.12.2 Array querying functions H.12.3 Access functions |
1283 | H.12.4 Access to actual representation H.12.5 Access to elements via canonical representation |
1284 | H.12.6 Access to scalar elements (bit and logic) |
1285 | H.12.7 Access to array elements of other types H.12.8 Example 6—Two-dimensional open array |
1286 | H.12.9 Example 7—Open array |
1287 | H.12.10 Example 8—Access to packed arrays H.13 Time and timescale H.14 SV3.1a-compatible access to packed data (deprecated functionality) |
1288 | H.14.1 Determining the compatibility level of an implementation H.14.2 svdpi.h definitions for SV3.1a-style packed data processing |
1290 | H.14.3 Source-level compatibility include file svdpi_src.h H.14.4 Example 9—Deprecated SV3.1a binary-compatible application |
1291 | H.14.5 Example 10—Deprecated SV3.1a source-compatible application |
1292 | H.14.6 Example 11—Deprecated SV3.1a binary-compatible calls of export functions |
1293 | Annex I (normative) svdpi.h I.1 General I.2 Overview I.3 Source code |
1303 | Annex J (normative) Inclusion of foreign language code J.1 General J.2 Overview |
1304 | J.3 Location independence J.4 Object code inclusion |
1305 | J.4.1 Bootstrap file J.4.2 Examples |
1307 | Annex K (normative) vpi_user.h K.1 General K.2 Source code |
1324 | Annex L (normative) vpi_compatibility.h L.1 General L.2 Source code |
1327 | Annex M (normative) sv_vpi_user.h M.1 General M.2 Source code |
1338 | Annex N (normative) Algorithm for probabilistic distribution functions N.1 General N.2 Source code |
1346 | Annex O (informative) Encryption/decryption flow O.1 General O.2 Overview O.3 Tool vendor secret key encryption system O.3.1 Encryption input |
1347 | O.3.2 Encryption output O.4 IP author secret key encryption system O.4.1 Encryption input |
1348 | O.4.2 Encryption output O.5 Digital envelopes |
1349 | O.5.1 Encryption input O.5.2 Encryption output |
1350 | Annex P (informative) Glossary |
1353 | Annex Q (informative) Bibliography |
1354 | Back cover |