CIRCT

Circuit IR Compilers and Tools

'moore' Dialect

This dialect provides operations and types to capture a SystemVerilog design after parsing, type checking, and elaboration.

Rationale 

The main goal of the moore dialect is to provide a set of operations and types for the ImportVerilog conversion to translate a fully parsed, type-checked, and elaborated Slang AST into MLIR operations. See IEEE 1800-2017 for more details about SystemVerilog. The dialect aims to faithfully capture the full SystemVerilog types and semantics, and provide a platform for transformation passes to resolve language quirks, analyze the design at a high level, and lower it to the core dialects.

In contrast, the sv dialect is geared towards emission of SystemVerilog text, and is focused on providing a good lowering target to allow for emission. The moore and sv dialect may eventually converge into a single dialect. As we are building out the Verilog frontend capabilities of CIRCT it is valuable to have a separate ingestion dialect, such that we do not have to make disruptive changes to the load-bearing sv dialect used in production.

LRM Rules 

Unconnection rules 

The SystemVerilog LRM defines unconnected behavior while leaving ports unconnected.

Port TypeUnconnected Behavior
Input (Net)High-impedance value (‘Z)
Input (Variable)Default initial value
OutputNo effect on Simulation
Inout (Net)High-impedance value (‘Z)
Inout (Variable)Default initial value
RefCannot be left unconnected
InterconnectCannot be left unconnected
InterfaceCannot be left unconnected

For variables that do not have a specified initializer. It has a default rule to initialize data value according to its type:

TypeDefault initial value
4-state integral‘X
2-state integral‘0
real, shortreal0.0
EnumerationBase type default initial value
string"" (empty string)
eventNew event
classnull
interface classnull
chandle (Opaque handle)null
virtual interfacenull

Types 

Simple Bit Vector Type 

The moore.iN and moore.lN types represent a two-valued or four-valued simple bit vector of width N.

VerilogMoore Dialect
bit!moore.i1
logic!moore.l1
reg!moore.l1
byte!moore.i8
shortint!moore.i16
int!moore.i32
integer!moore.l32
longint!moore.i64
time!moore.l64

ArrayType 

a packed array type

Syntax:

!moore.array<
  unsigned,   # size
  PackedType   # elementType
>

A packed array with a fixed number of elements. This type represents packed range dimensions ([a:b]) in SystemVerilog.

VerilogMoore Dialect
T [3:0]!moore.array<4 x T>
T [2:4]!moore.array<3 x T>

Parameters: 

ParameterC++ typeDescription
sizeunsigned
elementTypePackedType

AssocArrayType 

an associative array type

Syntax:

!moore.assoc_array<
  UnpackedType,   # elementType
  UnpackedType   # indexType
>

An associative array. This type represents associative arrays ([T]) in SystemVerilog.

VerilogMoore Dialect
T foo [K]!moore.assoc_array<T, K>

Parameters: 

ParameterC++ typeDescription
elementTypeUnpackedType
indexTypeUnpackedType

ChandleType 

the SystemVerilog chandle type

Syntax: !moore.chandle

EventType 

the SystemVerilog event type

Syntax: !moore.event

IntType 

a simple bit vector type

The !moore.iN and !moore.lN types represent a two-valued or four-valued simple bit vector of width N. The predefined SystemVerilog integer types map to this as follows:

VerilogMoore Dialect
bit!moore.i1
logic!moore.l1
reg!moore.l1
byte!moore.i8
shortint!moore.i16
int!moore.i32
integer!moore.l32
longint!moore.i64
time!moore.l64

Parameters: 

ParameterC++ typeDescription
widthunsigned
domainDomain

OpenArrayType 

an open packed array type

Syntax:

!moore.open_array<
  PackedType   # elementType
>

A packed array with an unspecified number of elements. This type represents unsized/open packed arrays ([]) in SystemVerilog.

VerilogMoore Dialect
T []!moore.open_array<T>

Parameters: 

ParameterC++ typeDescription
elementTypePackedType

OpenUnpackedArrayType 

an open unpacked array type

Syntax:

!moore.open_uarray<
  UnpackedType   # elementType
>

An unpacked array with an unspecified number of elements. This type represents unsized/open unpacked arrays ([]) in SystemVerilog.

VerilogMoore Dialect
T foo []!moore.open_uarray<T>

Parameters: 

ParameterC++ typeDescription
elementTypeUnpackedType

QueueType 

a queue type

Syntax:

!moore.queue<
  UnpackedType,   # elementType
  unsigned   # bound
>

A queue with an optional upper bound on the number of elements that it can hold. This type represents queues ([$] and [$:a]) in SystemVerilog. A bound of 0 indicates an unbounded queue.

VerilogMoore Dialect
T foo [$]!moore.queue<T>
T foo [$:42]!moore.queue<T, 42>

Parameters: 

ParameterC++ typeDescription
elementTypeUnpackedType
boundunsigned

RealType 

a SystemVerilog real type

Syntax: !moore.real

This type represents the SystemVerilog real type. Since the Moore dialect does not fully handle real-valued expressions properly yet, we coalesce the shortreal, real, and realtime types in the SystemVerilgo standard to this common !moore.real type. The standard specifies these types to be of at least 32, 64, and 64 bits, respectively. The !moore.real type is 64 bits wide.

VerilogMoore Dialect
shortreal!moore.real
real!moore.real
realtime!moore.real

RefType 

Syntax:

!moore.ref<
  UnpackedType   # nestedType
>

A wrapper is used to wrap any SystemVerilog type. It’s aimed to work for ‘moore.variable’, ‘moore.blocking_assign’, and ‘moore.read’, which are related to memory, like alloca/write/read.

Parameters: 

ParameterC++ typeDescription
nestedTypeUnpackedType

StringType 

the SystemVerilog string type

Syntax: !moore.string

StructType 

a packed struct type

Syntax:

!moore.struct<
  ::llvm::ArrayRef<StructLikeMember>   # members
>

A packed struct. All members are guaranteed to be packed as well.

Parameters: 

ParameterC++ typeDescription
members::llvm::ArrayRef<StructLikeMember>

UnionType 

a packed union type

Syntax:

!moore.union<
  ::llvm::ArrayRef<StructLikeMember>   # members
>

A packed union. All members are guaranteed to be packed as well.

Parameters: 

ParameterC++ typeDescription
members::llvm::ArrayRef<StructLikeMember>

UnpackedArrayType 

an unpacked array type

Syntax:

!moore.uarray<
  unsigned,   # size
  UnpackedType   # elementType
>

An unpacked array with a fixed number of elements. This type represents unpacked range dimensions ([a:b]) and unpacked array dimensions ([a]) in SystemVerilog.

VerilogMoore Dialect
T foo [3:0]!moore.uarray<4 x T>
T foo [2:4]!moore.uarray<3 x T>
T foo [2]!moore.uarray<2 x T>

Parameters: 

ParameterC++ typeDescription
sizeunsigned
elementTypeUnpackedType

UnpackedStructType 

an unpacked struct type

Syntax:

!moore.ustruct<
  ::llvm::ArrayRef<StructLikeMember>   # members
>

An unpacked struct.

Parameters: 

ParameterC++ typeDescription
members::llvm::ArrayRef<StructLikeMember>

UnpackedUnionType 

an unpacked union type

Syntax:

!moore.uunion<
  ::llvm::ArrayRef<StructLikeMember>   # members
>

An unpacked union.

Parameters: 

ParameterC++ typeDescription
members::llvm::ArrayRef<StructLikeMember>

VoidType 

the SystemVerilog void type

Syntax: !moore.void

Operations 

moore.ashr (::circt::moore::AShrOp) 

Arithmetic right shift

Syntax:

operation ::= `moore.ashr` $value `,` $amount attr-dict `:` type($value) `,` type($amount)

Shifts the value to the left or right by amount number of bits. The result has the same type as the input value. The amount is always treated as an unsigned number and has no effect on the signedness of the result. X or Z bits in the input value are simply shifted left or right the same way 0 or 1 bits are. If the amount contains X or Z bits, all result bits are X.

shl shifts bits to the left, filling in 0 for the vacated least significant bits. shr and ashr shift bits to the right; shr fills in 0 for the vacated most significant bits, and ashr copies the input’s sign bit into the vacated most significant bits. Note that in contrast to the SV spec, the ashr always fills in the sign bit regardless of the signedness of the input.

shl corresponds to the << and <<< operators. shr corresponds to the >> operator, and the >>> operator applied to an unsigned value. ashr corresponds to the >>> operator applied to a signed value.

See IEEE 1800-2017 § 11.4.10 “Shift operators”.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
valuesimple bit vector type
amountsimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.add (::circt::moore::AddOp) 

Addition

Syntax:

operation ::= `moore.add` $lhs `,` $rhs attr-dict `:` type($result)

Add the operands. If any bit in the two operands is Z or X, all bits in the result are X.

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Traits: AlwaysSpeculatableImplTrait, Commutative, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.and (::circt::moore::AndOp) 

Bitwise AND operation

Syntax:

operation ::= `moore.and` $lhs `,` $rhs attr-dict `:` type($result)

Applies the boolean AND operation to each pair of corresponding bits in the left- and right-hand side operand. Corresponds to the & operator.

See IEEE 1800-2017 § 11.4.8 “Bitwise operators”.

01XZ
00000
101XX
X0XXX
Z0XXX

Traits: AlwaysSpeculatableImplTrait, Commutative, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.array_create (::circt::moore::ArrayCreateOp) 

Create an array value from individual elements

Syntax:

operation ::= `moore.array_create` $elements attr-dict `:` type($elements) `->` type($result)

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
elementsvariadic of unpacked type

Results: 

ResultDescription
resultpacked or unpacked static array type

moore.assigned_variable (::circt::moore::AssignedVariableOp) 

A variable with a unique continuously assigned value

Syntax:

operation ::= `moore.assigned_variable` `` custom<ImplicitSSAName>($name) $input attr-dict `:` type($input)

Traits: SameOperandsAndResultType

Interfaces: InferTypeOpInterface, OpAsmOpInterface

Attributes: 

AttributeMLIR TypeDescription
name::mlir::StringAttrstring attribute

Operands: 

OperandDescription
inputunpacked type

Results: 

ResultDescription
resultunpacked type

moore.blocking_assign (::circt::moore::BlockingAssignOp) 

Blocking procedural assignment

Syntax:

operation ::= `moore.blocking_assign` $dst `,` $src attr-dict `:` type($src)

A blocking procedural assignment in a sequential block, such as x = y. The effects of the assignment are visible to any subsequent operations in the block.

See IEEE 1800-2017 § 10.4.1 “Blocking procedural assignments”.

Interfaces: PromotableMemOpInterface

Operands: 

OperandDescription
dst
srcunpacked type

moore.bool_cast (::circt::moore::BoolCastOp) 

Cast a value to a single bit boolean

Syntax:

operation ::= `moore.bool_cast` $input attr-dict `:` type($input) `->` type($result)

Convert a nonzero or true value into 1, a zero or false value into 0, and any value containing Z or X bits into a X. This conversion is useful in combination with the logical and, or, implication, equivalence, and negation operators.

See IEEE 1800-2017 § 11.4.7 “Logical operators”.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
inputunpacked type

Results: 

ResultDescription
resultsingle bit type

moore.case_eq (::circt::moore::CaseEqOp) 

Case equality

Syntax:

operation ::= `moore.case_eq` $lhs `,` $rhs attr-dict `:` type($lhs)

Compares the bits in the left- and right-hand side operand and returns a single bit 0 or 1 result. If all corresponding bits in the left- and right-hand side are equal (both 0, 1, X, or Z), the two operands are considered equal (case_eq returns 1, case_ne returns 0). If any bits are not equal, the two operands are considered not equal (case_eq returns 0, case_ne returns 1). case_eq corresponds to the === operator and case_ne to the !== operator.

casez_eq treats Z bits in either operand as wildcards and skips them during the comparison. casexz_eq treats X and Z bits as wildcards. These are different from the wildcard_eq operation, which only considers X/Z in the right-hand operand as wildcards.

Case statements use this operation to perform case comparisons:

  • case statements use case_eq
  • casez statements use casez_eq
  • casex statements use casexz_eq

See IEEE 1800-2017 § 11.4.5 “Equality operators”.

Traits: AlwaysSpeculatableImplTrait, Commutative, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultbit type

moore.case_ne (::circt::moore::CaseNeOp) 

Case inequality

Syntax:

operation ::= `moore.case_ne` $lhs `,` $rhs attr-dict `:` type($lhs)

Compares the bits in the left- and right-hand side operand and returns a single bit 0 or 1 result. If all corresponding bits in the left- and right-hand side are equal (both 0, 1, X, or Z), the two operands are considered equal (case_eq returns 1, case_ne returns 0). If any bits are not equal, the two operands are considered not equal (case_eq returns 0, case_ne returns 1). case_eq corresponds to the === operator and case_ne to the !== operator.

casez_eq treats Z bits in either operand as wildcards and skips them during the comparison. casexz_eq treats X and Z bits as wildcards. These are different from the wildcard_eq operation, which only considers X/Z in the right-hand operand as wildcards.

Case statements use this operation to perform case comparisons:

  • case statements use case_eq
  • casez statements use casez_eq
  • casex statements use casexz_eq

See IEEE 1800-2017 § 11.4.5 “Equality operators”.

Traits: AlwaysSpeculatableImplTrait, Commutative, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultbit type

moore.casexz_eq (::circt::moore::CaseXZEqOp) 

Case equality with X and Z as wildcard

Syntax:

operation ::= `moore.casexz_eq` $lhs `,` $rhs attr-dict `:` type($lhs)

Compares the bits in the left- and right-hand side operand and returns a single bit 0 or 1 result. If all corresponding bits in the left- and right-hand side are equal (both 0, 1, X, or Z), the two operands are considered equal (case_eq returns 1, case_ne returns 0). If any bits are not equal, the two operands are considered not equal (case_eq returns 0, case_ne returns 1). case_eq corresponds to the === operator and case_ne to the !== operator.

casez_eq treats Z bits in either operand as wildcards and skips them during the comparison. casexz_eq treats X and Z bits as wildcards. These are different from the wildcard_eq operation, which only considers X/Z in the right-hand operand as wildcards.

Case statements use this operation to perform case comparisons:

  • case statements use case_eq
  • casez statements use casez_eq
  • casex statements use casexz_eq

See IEEE 1800-2017 § 11.4.5 “Equality operators”.

Traits: AlwaysSpeculatableImplTrait, Commutative, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultbit type

moore.casez_eq (::circt::moore::CaseZEqOp) 

Case equality with Z as wildcard

Syntax:

operation ::= `moore.casez_eq` $lhs `,` $rhs attr-dict `:` type($lhs)

Compares the bits in the left- and right-hand side operand and returns a single bit 0 or 1 result. If all corresponding bits in the left- and right-hand side are equal (both 0, 1, X, or Z), the two operands are considered equal (case_eq returns 1, case_ne returns 0). If any bits are not equal, the two operands are considered not equal (case_eq returns 0, case_ne returns 1). case_eq corresponds to the === operator and case_ne to the !== operator.

casez_eq treats Z bits in either operand as wildcards and skips them during the comparison. casexz_eq treats X and Z bits as wildcards. These are different from the wildcard_eq operation, which only considers X/Z in the right-hand operand as wildcards.

Case statements use this operation to perform case comparisons:

  • case statements use case_eq
  • casez statements use casez_eq
  • casex statements use casexz_eq

See IEEE 1800-2017 § 11.4.5 “Equality operators”.

Traits: AlwaysSpeculatableImplTrait, Commutative, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultbit type

moore.concat (::circt::moore::ConcatOp) 

A concatenation of expressions

Syntax:

operation ::= `moore.concat` $values attr-dict `:` `(` type($values) `)` `->` type($result)

This operation represents the SystemVerilog concatenation expression {x, y, z}. See IEEE 1800-2017 §11.4.12 “Concatenation operators”.

All operands must be simple bit vector types.

The concatenation result is a simple bit vector type. The result is unsigned regardless of the sign of the operands (see concatenation-specific rules in IEEE 1800-2017 §11.8.1 “Rules for expression types”). The size of the result is the sum of the sizes of all operands. If any of the operands is four-valued, the result is four-valued; otherwise it is two-valued.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
valuesvariadic of a simple bit vector type

Results: 

ResultDescription
resulta simple bit vector type

moore.concat_ref (::circt::moore::ConcatRefOp) 

The copy of concat that explicitly works on the ref type.

Syntax:

operation ::= `moore.concat_ref` $values attr-dict `:` `(` type($values) `)` `->` type($result)

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
valuesvariadic of

Results: 

ResultDescription
result

moore.conditional (::circt::moore::ConditionalOp) 

Conditional operation

Syntax:

operation ::= `moore.conditional` $condition attr-dict `:` type($condition) `->` type($result)
              $trueRegion $falseRegion

If the condition is true, this op evaluates the first region and returns its result without evaluating the second region. If the the condition is false, this op evaluates the second region and returns its result without evaluating the first region.

If the condition is unknown (X or Z), both regions are evaluated. If both results are equal as per case_eq, one of the results is returned. If the results are not equal, this op returns a value based on the data types of the results.

In case the results of the first and second region are of an integral type, they are merged by applying the following bit-wise truth table:

?:01XZ
00XXX
1X1XX
XXXXX
ZXXXX

Non-integral data types define other rules which are not yet implemented. See IEEE 1800-2017 § 11.4.11 “Conditional operator”.

Traits: NoRegionArguments, RecursiveMemoryEffects

Operands: 

OperandDescription
conditionsingle bit type

Results: 

ResultDescription
resultunpacked type

moore.constant (::circt::moore::ConstantOp) 

A constant integer value

Traits: AlwaysSpeculatableImplTrait, ConstantLike

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Attributes: 

AttributeMLIR TypeDescription
value::circt::moore::FVIntegerAttrAn attribute containing a four-valued integer

Results: 

ResultDescription
resulta simple bit vector type

moore.assign (::circt::moore::ContinuousAssignOp) 

Continuous assignment within a module

Syntax:

operation ::= `moore.assign` $dst `,` $src attr-dict `:` type($src)

A continuous assignment in module scope, such as assign x = y;, which continuously drives the value on the right-hand side onto the left-hand side.

See IEEE 1800-2017 § 10.3 “Continuous assignments”.

Traits: HasParent<SVModuleOp>

Operands: 

OperandDescription
dst
srcunpacked type

moore.conversion (::circt::moore::ConversionOp) 

A type conversion

Syntax:

operation ::= `moore.conversion` $input attr-dict `:` type($input) `->` type($result)

An explicit or implicit type conversion. These are either generated automatically in order to make assignments compatible:

int a;
shortint b;
a = b;  // generates an implicit cast from shortint to int

Or explicitly by the user through a type, sign, or const cast expression:

byte'(a)
unsigned'(a)
signed'(a)
42'(a)

See IEEE 1800-2017 § 6.24 “Casting”.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
inputany type

Results: 

ResultDescription
resultany type

moore.detect_event (::circt::moore::DetectEventOp) 

Check if an event occured within a wait_event op

Syntax:

operation ::= `moore.detect_event` $edge $input (`if` $condition^)? attr-dict `:` type($input)

The moore.detect_event op is used inside the body of a moore.wait_event to check if an interesting value change has occurred on its operand. The moore.detect_event op implicitly stores the previous value of its operand and compares it against the current value to detect an interesting edge:

  • posedge checks for a low-to-high transition
  • negedge checks for a high-to-low transition
  • edge checks for either a posedge or a negedge
  • any checks for any value change (including e.g. X to Z)

The edges are detected as follows:

  • 0 to 1 X Z: posedge
  • 1 to 0 X Z: negedge
  • X Z to 1: posedge
  • X Z to 0: negedge
FromTo 0To 1To XTo Z
0-posedgeposedgeposedge
1negedge-negedgenegedge
Xnegedgeposedge--
Znegedgeposedge--

See IEEE 1800-2017 § 9.4.2 “Event control”.

Traits: HasParent<WaitEventOp>

Attributes: 

AttributeMLIR TypeDescription
edgecirct::moore::EdgeAttrEdge kind

Operands: 

OperandDescription
inputunpacked type
conditionbit type

moore.divs (::circt::moore::DivSOp) 

Division

Syntax:

operation ::= `moore.divs` $lhs `,` $rhs attr-dict `:` type($result)

Divide the left-hand side by the right-hand side operand. Any fractional part is truncated toward zero. If the right-hand side is zero, all bits of the result are X. If any bit in the two operands is Z or X, all bits in the result are X.

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Traits: AlwaysSpeculatableImplTrait, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.divu (::circt::moore::DivUOp) 

Division

Syntax:

operation ::= `moore.divu` $lhs `,` $rhs attr-dict `:` type($result)

Divide the left-hand side by the right-hand side operand. Any fractional part is truncated toward zero. If the right-hand side is zero, all bits of the result are X. If any bit in the two operands is Z or X, all bits in the result are X.

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Traits: AlwaysSpeculatableImplTrait, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.dyn_extract (::circt::moore::DynExtractOp) 

Syntax:

operation ::= `moore.dyn_extract` $input `from` $lowBit attr-dict `:`
              type($input) `,` type($lowBit) `->` type($result)

It’s similar with extract, but it’s used to select from a value with a dynamic low bit.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
inputunpacked type
lowBitunpacked type

Results: 

ResultDescription
resultunpacked type

moore.dyn_extract_ref (::circt::moore::DynExtractRefOp) 

Syntax:

operation ::= `moore.dyn_extract_ref` $input `from` $lowBit attr-dict `:`
              type($input) `,` type($lowBit) `->` type($result)

The copy of dyn_extract that explicitly works on the ref type.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
input
lowBitunpacked type

Results: 

ResultDescription
result

moore.eq (::circt::moore::EqOp) 

Logical equality

Syntax:

operation ::= `moore.eq` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the bits in the left- and right-hand side operand and returns a single bit 0, 1, or X result. If all corresponding bits in the left- and right-hand side are equal, and all are 0 or 1 (not X or Z), the two operands are considered equal (eq returns 1, ne returns 0). If any bits are not equal, but all are 0 or 1, the two operands are considered not equal (eq returns 0, ne returns 1). If any bit in the two operands is Z or X, returns X. eq corresponds to the == operator and ne to the != operator.

See IEEE 1800-2017 § 11.4.5 “Equality operators”.

Traits: AlwaysSpeculatableImplTrait, Commutative, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.extract (::circt::moore::ExtractOp) 

Extract a range or single bits from a value

Syntax:

operation ::= `moore.extract` $input `from` $lowBit attr-dict `:` type($input) `->` type($result)

It’s used to select from a value with a constant low bit. This operation includes the vector bit/part-select, array, and memory addressing.If the address is invalid–out of bounds or has x or z bit– then it will produce x for 4-state or 0 for 2-state. Bit-select results are unsigned, regardless of the operands. Part-select results are unsigned, regardless of the operands even if the part-select specifies the entire vector. See IEEE 1800-2017 § 11.8.1 “Rules for expression types”

Example:

logic v [7:0];
v[1];                      // the bit-select addressing
v[3:0];                    // the part-select addressing
v[3-:4];  v[0+:4];         // They are equivalent to v[3:0]

See IEEE 1800-2017 § 11.5.1 “Vector bit-select and part-select addressing”.

Example:

// an array of 256-by-256 8-bit elements
logic [7:0] twod_array [0:255][0:255];
logic [7:0] mem_name [0:1023];      // a memory of 1024 8-bit words

See IEEE 1800-2017 § 11.5.2 “Array and memory addressing”.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Attributes: 

AttributeMLIR TypeDescription
lowBit::mlir::IntegerAttr32-bit signless integer attribute

Operands: 

OperandDescription
inputunpacked type

Results: 

ResultDescription
resultunpacked type

moore.extract_ref (::circt::moore::ExtractRefOp) 

Syntax:

operation ::= `moore.extract_ref` $input `from` $lowBit attr-dict `:` type($input) `->` type($result)

The copy of extract that explicitly works on the ref type.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Attributes: 

AttributeMLIR TypeDescription
lowBit::mlir::IntegerAttr32-bit signless integer attribute

Operands: 

OperandDescription
input

Results: 

ResultDescription
result

moore.instance (::circt::moore::InstanceOp) 

Create an instance of a module

The moore.instance operation instantiates a moore.module operation.

See IEEE 1800-2017 § 23.3 “Module instances”.

Interfaces: OpAsmOpInterface, SymbolUserOpInterface

Attributes: 

AttributeMLIR TypeDescription
instanceName::mlir::StringAttrstring attribute
moduleName::mlir::FlatSymbolRefAttrflat symbol reference attribute
inputNames::mlir::ArrayAttrstring array attribute
outputNames::mlir::ArrayAttrstring array attribute

Operands: 

OperandDescription
inputsvariadic of any type

Results: 

ResultDescription
outputsvariadic of any type

moore.mods (::circt::moore::ModSOp) 

Remainder

Syntax:

operation ::= `moore.mods` $lhs `,` $rhs attr-dict `:` type($result)

Compute the remainder of the left-hand side divided by the right-hand side operand. If the right-hand side is zero, all bits of the result are X. The sign of the result is the sign of the left-hand side. If any bit in the two operands is Z or X, all bits in the result are X.

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Consider the following examples:

LHSRHSResult
1132
-113-2
11-32
-11-3-2

Traits: AlwaysSpeculatableImplTrait, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.modu (::circt::moore::ModUOp) 

Remainder

Syntax:

operation ::= `moore.modu` $lhs `,` $rhs attr-dict `:` type($result)

Compute the remainder of the left-hand side divided by the right-hand side operand. If the right-hand side is zero, all bits of the result are X. The sign of the result is the sign of the left-hand side. If any bit in the two operands is Z or X, all bits in the result are X.

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Consider the following examples:

LHSRHSResult
1132
-113-2
11-32
-11-3-2

Traits: AlwaysSpeculatableImplTrait, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.mul (::circt::moore::MulOp) 

Multiplication

Syntax:

operation ::= `moore.mul` $lhs `,` $rhs attr-dict `:` type($result)

Multiply the operands. If any bit in the two operands is Z or X, all bits in the result are X.

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Traits: AlwaysSpeculatableImplTrait, Commutative, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.named_constant (::circt::moore::NamedConstantOp) 

An elaboration time constant expression

Syntax:

operation ::= `moore.named_constant` $kind
              ``custom<ImplicitSSAName>($name)
              $value `:` type($result) attr-dict

Constants are named data objects that never change. SystemVerilog provides three elaboration-time constants: parameter, localparam, and specparam.

See IEEE 1800-2017 § 6.20 “Constants”.

Traits: SameOperandsAndResultType

Interfaces: InferTypeOpInterface, OpAsmOpInterface

Attributes: 

AttributeMLIR TypeDescription
name::mlir::StringAttrstring attribute
kindcirct::moore::NamedConstAttrelaboration-time constants

Operands: 

OperandDescription
valuea simple bit vector type

Results: 

ResultDescription
resulta simple bit vector type

moore.ne (::circt::moore::NeOp) 

Logical inequality

Syntax:

operation ::= `moore.ne` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the bits in the left- and right-hand side operand and returns a single bit 0, 1, or X result. If all corresponding bits in the left- and right-hand side are equal, and all are 0 or 1 (not X or Z), the two operands are considered equal (eq returns 1, ne returns 0). If any bits are not equal, but all are 0 or 1, the two operands are considered not equal (eq returns 0, ne returns 1). If any bit in the two operands is Z or X, returns X. eq corresponds to the == operator and ne to the != operator.

See IEEE 1800-2017 § 11.4.5 “Equality operators”.

Traits: AlwaysSpeculatableImplTrait, Commutative, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.neg (::circt::moore::NegOp) 

Arithmetic negation

Syntax:

operation ::= `moore.neg` $input attr-dict `:` type($input)

Negate a value to its two’s complement form. If any bit in the input is Z or X, all bits in the result are X.

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Traits: AlwaysSpeculatableImplTrait, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
inputsimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.net (::circt::moore::NetOp) 

A net declaration

Syntax:

operation ::= `moore.net` `` custom<ImplicitSSAName>($name) $kind ($assignment^)? attr-dict
              `:` type($result)

The moore.net operation is a net declaration. Net types defines different types of net connection in SV. There are twelve built-in net types defined in the official standard construct of the operation: supply0, supply1, tri, triand, trior, trireg, tri0, tri1, uwire, wire, wand, wor. Optional assignment argument allows net operation to be initialized with specific values as soon as it is created. Only one net declaration assignment can be made for a particular net. See IEEE 1800-2017 § 10.3.1 “The net declaration assignment” for the differences between net declaration assignments and continuous assign statements. It has some features that are not supported: declaring an interconnect net and using user-defined types in the net operation.

See IEEE 1800-2017 § 6.7 “Net declarations”.

Interfaces: OpAsmOpInterface

Attributes: 

AttributeMLIR TypeDescription
name::mlir::StringAttrstring attribute
kind::circt::moore::NetKindAttrNet type kind

Operands: 

OperandDescription
assignmentunpacked type

Results: 

ResultDescription
result

moore.nonblocking_assign (::circt::moore::NonBlockingAssignOp) 

Nonblocking procedural assignment

Syntax:

operation ::= `moore.nonblocking_assign` $dst `,` $src attr-dict `:` type($src)

A nonblocking procedural assignment in a sequential block, such as x <= y; or x <= @(posedge y) z or x <= #1ns y. The assignment does not take effect immediately. Subsequent operations in the block do not see the effects of this assignment. Instead, the assignment is scheduled to happen in a subsequent time step as dictated by the delay or event control.

See IEEE 1800-2017 § 10.4.2 “Nonblocking procedural assignments”.

Operands: 

OperandDescription
dst
srcunpacked type

moore.not (::circt::moore::NotOp) 

Bitwise unary negation

Syntax:

operation ::= `moore.not` $input attr-dict `:` type($input)

Applies the boolean NOT operation to each bit in the input. Corresponds to the ~ operator, as well as the negation in the ~&, ~|, ^~, and ~^ reduction operators.

See IEEE 1800-2017 § 11.4.8 “Bitwise operators”.

InputResult
01
10
XX
ZX

Traits: AlwaysSpeculatableImplTrait, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
inputsimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.or (::circt::moore::OrOp) 

Bitwise OR operation

Syntax:

operation ::= `moore.or` $lhs `,` $rhs attr-dict `:` type($result)

Applies the boolean OR operation to each pair of corresponding bits in the left- and right-hand side operand. Corresponds to the | operator.

See IEEE 1800-2017 § 11.4.8 “Bitwise operators”.

01XZ
001XX
11111
XX1XX
ZX1XX

Traits: AlwaysSpeculatableImplTrait, Commutative, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.output (::circt::moore::OutputOp) 

Assign module outputs

Syntax:

operation ::= `moore.output` attr-dict ($outputs^ `:` type($outputs))?

The moore.output operation marks the end of a moore.module body region and specifies the values to present for the module’s output ports.

Traits: AlwaysSpeculatableImplTrait, HasParent<SVModuleOp>, ReturnLike, Terminator

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface), RegionBranchTerminatorOpInterface

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
outputsvariadic of any type

moore.pows (::circt::moore::PowSOp) 

Power

Syntax:

operation ::= `moore.pows` $lhs `,` $rhs attr-dict `:` type($result)

Raise the left-hand side to the power of the right-hand side. powu treats its operands as unsigned numbers, while pows treats them as signed numbers.

Evaluation rules for a ** b:

a < -1a = -1a = 0a = 1a > 1
b > 0a ** bb odd ? -1 : 101a ** b
b = 011111
b < 00b odd ? -1 : 1X10

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Traits: AlwaysSpeculatableImplTrait, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.powu (::circt::moore::PowUOp) 

Power

Syntax:

operation ::= `moore.powu` $lhs `,` $rhs attr-dict `:` type($result)

Raise the left-hand side to the power of the right-hand side. powu treats its operands as unsigned numbers, while pows treats them as signed numbers.

Evaluation rules for a ** b:

a < -1a = -1a = 0a = 1a > 1
b > 0a ** bb odd ? -1 : 101a ** b
b = 011111
b < 00b odd ? -1 : 1X10

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Traits: AlwaysSpeculatableImplTrait, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.procedure (::circt::moore::ProcedureOp) 

A procedure executed at different points in time

Syntax:

operation ::= `moore.procedure` $kind attr-dict-with-keyword $body

The moore.procedure operation represents the SystemVerilog initial, final, always, always_comb, always_latch, and always_ff procedures.

Execution times of the various procedures:

  • An initial procedure is executed once at the start of a design’s lifetime, before any other procedures are executed.

  • A final procedure is executed once at the end of a design’s lifetime, after all other procedures have stopped execution.

  • An always or always_ff procedure is repeatedly executed during a design’s lifetime. Timing and event control inside the procedure can suspend its execution, for example to wait for a signal to change. If no such timing or event control is present, the procedure repeats infinitely at the current timestep, effectively deadlocking the design.

  • An always_comb or always_latch procedure is executed once at the start of a design’s lifetime, after any initial procedures, and throughout the lifetime of the design whenever any of the variables read by the body of the procedure changes. Since the procedure is only executed when its change, and not repeatedly, the body generally does not contain any timing or event control. This behavior mitigates a shortcoming of always procedures, which commonly have an event control like @* that blocks and waits for a change of any input signals. This prevents the body from executing when the design is initialized and properly reacting to the initial values of signals. In contrast, always_comb and always_latch procedures have an implicit unconditional execution at design start-up.

See IEEE 1800-2017 § 9.2 “Structured procedures”.

Traits: NoRegionArguments, RecursiveMemoryEffects, RecursivelySpeculatableImplTrait

Interfaces: ConditionallySpeculatable

Attributes: 

AttributeMLIR TypeDescription
kindcirct::moore::ProcedureKindAttrProcedure kind

moore.read (::circt::moore::ReadOp) 

Read the current value of a declaration

Syntax:

operation ::= `moore.read` $input attr-dict `:` type($input)

Samples the current value of a declaration. This is a helper to capture the exact point at which declarations that can be targeted by all possible expressions are read. It’s similar to llvm.load.

Interfaces: InferTypeOpInterface, PromotableMemOpInterface

Operands: 

OperandDescription
input

Results: 

ResultDescription
resultunpacked type

moore.reduce_and (::circt::moore::ReduceAndOp) 

Reduction AND operator

Syntax:

operation ::= `moore.reduce_and` $input attr-dict `:` type($input) `->` type($result)

Reduces all bits in the input to a single result bit by iteratively applying the boolean AND operator. If the input has only a single bit, that bit is returned.

See IEEE 1800-2017 § 11.4.9 “Reduction operators”. See the corresponding and, or, and xor operations for the truth table.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
inputsimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.reduce_or (::circt::moore::ReduceOrOp) 

Reduction OR operator

Syntax:

operation ::= `moore.reduce_or` $input attr-dict `:` type($input) `->` type($result)

Reduces all bits in the input to a single result bit by iteratively applying the boolean OR operator. If the input has only a single bit, that bit is returned.

See IEEE 1800-2017 § 11.4.9 “Reduction operators”. See the corresponding and, or, and xor operations for the truth table.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
inputsimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.reduce_xor (::circt::moore::ReduceXorOp) 

Reduction XOR operator

Syntax:

operation ::= `moore.reduce_xor` $input attr-dict `:` type($input) `->` type($result)

Reduces all bits in the input to a single result bit by iteratively applying the boolean XOR operator. If the input has only a single bit, that bit is returned.

See IEEE 1800-2017 § 11.4.9 “Reduction operators”. See the corresponding and, or, and xor operations for the truth table.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
inputsimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.replicate (::circt::moore::ReplicateOp) 

Multiple concatenation of expressions

Syntax:

operation ::= `moore.replicate` $value attr-dict `:` type($value) `->` type($result)

This operation indicates a joining together of that many copies of the concatenation {constant{w}}. Which enclosed together within brace. The ‘constant’ must a non-negative, non-x, and non-z constant expression. The ‘constant’ may be a value of zero, but it only exists in parameterized code, and it will be ignored(type is changed to the void).

Example:

  {0{w}}   // empty! ignore it.
  {4{w}}   // the same as {w, w, w, w}

See IEEE 1800-2017 §11.4.12 “Concatenation operators”.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
valuea simple bit vector type

Results: 

ResultDescription
resulta simple bit vector type

moore.return (::circt::moore::ReturnOp) 

Return from a procedure

Syntax:

operation ::= `moore.return` attr-dict

Traits: AlwaysSpeculatableImplTrait, HasParent<ProcedureOp>, Terminator

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

moore.module (::circt::moore::SVModuleOp) 

A module definition

The moore.module operation represents a SystemVerilog module, including its name, port list, and the constituent parts that make up its body. The module’s body is a graph region.

See IEEE 1800-2017 § 3.3 “Modules” and § 23.2 “Module definitions”.

Traits: IsolatedFromAbove, SingleBlockImplicitTerminator<OutputOp>, SingleBlock

Interfaces: OpAsmOpInterface, RegionKindInterface, Symbol

Attributes: 

AttributeMLIR TypeDescription
sym_name::mlir::StringAttrstring attribute
module_type::mlir::TypeAttrtype attribute of module type
sym_visibility::mlir::StringAttrstring attribute

moore.sge (::circt::moore::SgeOp) 

Signed greater than or equal comparison

Syntax:

operation ::= `moore.sge` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the two operands is Z or X, returns X. Otherwise, if all bits are 0 or 1, ult/slt, ule/sle, ugt/sgt, and uge/sge return whether the left-hand side is less than, less than or equal to, greater than, or greater than or equal to the right-hand side, respectively. ult/slt corresponds to the < operator, ule/sle to <=, ugt/sgt to >, and uge/sge to >=.

See IEEE 1800-2017 § 11.4.4 “Relational operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.sgt (::circt::moore::SgtOp) 

Signed greater than comparison

Syntax:

operation ::= `moore.sgt` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the two operands is Z or X, returns X. Otherwise, if all bits are 0 or 1, ult/slt, ule/sle, ugt/sgt, and uge/sge return whether the left-hand side is less than, less than or equal to, greater than, or greater than or equal to the right-hand side, respectively. ult/slt corresponds to the < operator, ule/sle to <=, ugt/sgt to >, and uge/sge to >=.

See IEEE 1800-2017 § 11.4.4 “Relational operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.shl (::circt::moore::ShlOp) 

Logical left shift

Syntax:

operation ::= `moore.shl` $value `,` $amount attr-dict `:` type($value) `,` type($amount)

Shifts the value to the left or right by amount number of bits. The result has the same type as the input value. The amount is always treated as an unsigned number and has no effect on the signedness of the result. X or Z bits in the input value are simply shifted left or right the same way 0 or 1 bits are. If the amount contains X or Z bits, all result bits are X.

shl shifts bits to the left, filling in 0 for the vacated least significant bits. shr and ashr shift bits to the right; shr fills in 0 for the vacated most significant bits, and ashr copies the input’s sign bit into the vacated most significant bits. Note that in contrast to the SV spec, the ashr always fills in the sign bit regardless of the signedness of the input.

shl corresponds to the << and <<< operators. shr corresponds to the >> operator, and the >>> operator applied to an unsigned value. ashr corresponds to the >>> operator applied to a signed value.

See IEEE 1800-2017 § 11.4.10 “Shift operators”.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
valuesimple bit vector type
amountsimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.shr (::circt::moore::ShrOp) 

Logical right shift

Syntax:

operation ::= `moore.shr` $value `,` $amount attr-dict `:` type($value) `,` type($amount)

Shifts the value to the left or right by amount number of bits. The result has the same type as the input value. The amount is always treated as an unsigned number and has no effect on the signedness of the result. X or Z bits in the input value are simply shifted left or right the same way 0 or 1 bits are. If the amount contains X or Z bits, all result bits are X.

shl shifts bits to the left, filling in 0 for the vacated least significant bits. shr and ashr shift bits to the right; shr fills in 0 for the vacated most significant bits, and ashr copies the input’s sign bit into the vacated most significant bits. Note that in contrast to the SV spec, the ashr always fills in the sign bit regardless of the signedness of the input.

shl corresponds to the << and <<< operators. shr corresponds to the >> operator, and the >>> operator applied to an unsigned value. ashr corresponds to the >>> operator applied to a signed value.

See IEEE 1800-2017 § 11.4.10 “Shift operators”.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
valuesimple bit vector type
amountsimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.sle (::circt::moore::SleOp) 

Signed less than or equal comparison

Syntax:

operation ::= `moore.sle` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the two operands is Z or X, returns X. Otherwise, if all bits are 0 or 1, ult/slt, ule/sle, ugt/sgt, and uge/sge return whether the left-hand side is less than, less than or equal to, greater than, or greater than or equal to the right-hand side, respectively. ult/slt corresponds to the < operator, ule/sle to <=, ugt/sgt to >, and uge/sge to >=.

See IEEE 1800-2017 § 11.4.4 “Relational operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.slt (::circt::moore::SltOp) 

Signed less than comparison

Syntax:

operation ::= `moore.slt` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the two operands is Z or X, returns X. Otherwise, if all bits are 0 or 1, ult/slt, ule/sle, ugt/sgt, and uge/sge return whether the left-hand side is less than, less than or equal to, greater than, or greater than or equal to the right-hand side, respectively. ult/slt corresponds to the < operator, ule/sle to <=, ugt/sgt to >, and uge/sge to >=.

See IEEE 1800-2017 § 11.4.4 “Relational operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.string_constant (::circt::moore::StringConstantOp) 

Produce a constant string value

Syntax:

operation ::= `moore.string_constant` $value attr-dict `:` type($result)

Produces a constant value of string type.

Example:

%0 = moore.string "hello world"

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Attributes: 

AttributeMLIR TypeDescription
value::mlir::StringAttrstring attribute

Results: 

ResultDescription
resulta simple bit vector type

moore.struct_create (::circt::moore::StructCreateOp) 

Create a struct value from individual fields

Syntax:

operation ::= `moore.struct_create` $fields attr-dict `:` type($fields) `->` type($result)

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
fieldsvariadic of unpacked type

Results: 

ResultDescription
resultpacked or unpacked struct type

moore.struct_extract (::circt::moore::StructExtractOp) 

Obtain the value of a struct field

Syntax:

operation ::= `moore.struct_extract` $input `,` $fieldName attr-dict `:` type($input) `->` type($result)

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Attributes: 

AttributeMLIR TypeDescription
fieldName::mlir::StringAttrstring attribute

Operands: 

OperandDescription
inputpacked or unpacked struct type

Results: 

ResultDescription
resultunpacked type

moore.struct_extract_ref (::circt::moore::StructExtractRefOp) 

Create a reference to a struct field

Syntax:

operation ::= `moore.struct_extract_ref` $input `,` $fieldName attr-dict `:` type($input) `->` type($result)

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, DestructurableAccessorOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Attributes: 

AttributeMLIR TypeDescription
fieldName::mlir::StringAttrstring attribute

Operands: 

OperandDescription
inputref of packed or unpacked struct type

Results: 

ResultDescription
result

moore.struct_inject (::circt::moore::StructInjectOp) 

Update the value of a struct field

Syntax:

operation ::= `moore.struct_inject` $input `,` $fieldName `,` $newValue attr-dict
              `:` type($input) `,` type($newValue)

Takes an existing struct value, sets one of its fields to a new value, and returns the resulting struct value.

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Attributes: 

AttributeMLIR TypeDescription
fieldName::mlir::StringAttrstring attribute

Operands: 

OperandDescription
inputpacked or unpacked struct type
newValueunpacked type

Results: 

ResultDescription
resultpacked or unpacked struct type

moore.sub (::circt::moore::SubOp) 

Subtraction

Syntax:

operation ::= `moore.sub` $lhs `,` $rhs attr-dict `:` type($result)

Subtract the right-hand side from the left-hand side operand. If any bit in the two operands is Z or X, all bits in the result are X.

See IEEE 1800-2017 § 11.4.3 “Arithmetic operators”.

Traits: AlwaysSpeculatableImplTrait, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.uge (::circt::moore::UgeOp) 

Unsigned greater than or equal comparison

Syntax:

operation ::= `moore.uge` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the two operands is Z or X, returns X. Otherwise, if all bits are 0 or 1, ult/slt, ule/sle, ugt/sgt, and uge/sge return whether the left-hand side is less than, less than or equal to, greater than, or greater than or equal to the right-hand side, respectively. ult/slt corresponds to the < operator, ule/sle to <=, ugt/sgt to >, and uge/sge to >=.

See IEEE 1800-2017 § 11.4.4 “Relational operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.ugt (::circt::moore::UgtOp) 

Unsigned greater than comparison

Syntax:

operation ::= `moore.ugt` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the two operands is Z or X, returns X. Otherwise, if all bits are 0 or 1, ult/slt, ule/sle, ugt/sgt, and uge/sge return whether the left-hand side is less than, less than or equal to, greater than, or greater than or equal to the right-hand side, respectively. ult/slt corresponds to the < operator, ule/sle to <=, ugt/sgt to >, and uge/sge to >=.

See IEEE 1800-2017 § 11.4.4 “Relational operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.ule (::circt::moore::UleOp) 

Unsigned less than or equal comparison

Syntax:

operation ::= `moore.ule` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the two operands is Z or X, returns X. Otherwise, if all bits are 0 or 1, ult/slt, ule/sle, ugt/sgt, and uge/sge return whether the left-hand side is less than, less than or equal to, greater than, or greater than or equal to the right-hand side, respectively. ult/slt corresponds to the < operator, ule/sle to <=, ugt/sgt to >, and uge/sge to >=.

See IEEE 1800-2017 § 11.4.4 “Relational operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.ult (::circt::moore::UltOp) 

Unsigned less than comparison

Syntax:

operation ::= `moore.ult` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the two operands is Z or X, returns X. Otherwise, if all bits are 0 or 1, ult/slt, ule/sle, ugt/sgt, and uge/sge return whether the left-hand side is less than, less than or equal to, greater than, or greater than or equal to the right-hand side, respectively. ult/slt corresponds to the < operator, ule/sle to <=, ugt/sgt to >, and uge/sge to >=.

See IEEE 1800-2017 § 11.4.4 “Relational operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.union_create (::circt::moore::UnionCreateOp) 

Union Create operation

Syntax:

operation ::= `moore.union_create` $input attr-dict `:` type($input) `->` type($result)

A union is a data type that represents a single piece of storage that can be accessed using one of the named member data types. Only one of the data types in the union can be used at a time. By default, a union is unpacked, meaning there is no required representation for how members of the union are stored. Dynamic types and chandle types can only be used in tagged unions. See IEEE 1800-2017 § 7.3 “Unions”

Example:

typedef union { int i; shortreal f; } num; // named union type
num n;
n.f = 0.0; // set n in floating point format
typedef struct {
bit isfloat;
union { int i; shortreal f; } n;           // anonymous union type
} tagged_st;                               // named structure

See IEEE 1800-2017 § 7.3 “Unions”

Traits: AlwaysSpeculatableImplTrait

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Attributes: 

AttributeMLIR TypeDescription
fieldName::mlir::StringAttrstring attribute

Operands: 

OperandDescription
inputunpacked type

Results: 

ResultDescription
resultunpacked type

moore.union_extract (::circt::moore::UnionExtractOp) 

Union Extract operation

Syntax:

operation ::= `moore.union_extract` $input `,`   $fieldName  attr-dict `:`
              type($input) `->` type($result)

With packed unions, writing one member and reading another is independent of the byte ordering of the machine, unlike an unpacked union of unpacked structures, which are C-compatible and have members in ascending address order. See IEEE 1800-2017 § 7.3.1 “Packed unions”

Example:

typedef union packed { // default unsigned
s_atmcell acell;
bit [423:0] bit_slice;
bit [52:0][7:0] byte_slice;
} u_atmcell;
u_atmcell u1;
byte b; bit [3:0] nib;
b = u1.bit_slice[415:408]; // same as b = u1.byte_slice[51];
nib = u1.bit_slice [423:420];

See IEEE 1800-2017 § 7.3.1 “Packed unions”

Attributes: 

AttributeMLIR TypeDescription
fieldName::mlir::StringAttrstring attribute

Operands: 

OperandDescription
inputunpacked type

Results: 

ResultDescription
resultunpacked type

moore.union_extract_ref (::circt::moore::UnionExtractRefOp) 

Union Extract operation

Syntax:

operation ::= `moore.union_extract_ref` $input `,`   $fieldName  attr-dict `:`
              type($input) `->` type($result)

Attributes: 

AttributeMLIR TypeDescription
fieldName::mlir::StringAttrstring attribute

Operands: 

OperandDescription
input

Results: 

ResultDescription
result

moore.variable (::circt::moore::VariableOp) 

A variable declaration

Syntax:

operation ::= `moore.variable` `` custom<ImplicitSSAName>($name) ($initial^)? attr-dict
              `:` type($result)

See IEEE 1800-2017 § 6.8 “Variable declarations”.

Interfaces: DestructurableAllocationOpInterface, OpAsmOpInterface, PromotableAllocationOpInterface

Attributes: 

AttributeMLIR TypeDescription
name::mlir::StringAttrstring attribute

Operands: 

OperandDescription
initialunpacked type

Results: 

ResultDescription
result

moore.wait_event (::circt::moore::WaitEventOp) 

Suspend execution until an event occurs

Syntax:

operation ::= `moore.wait_event` attr-dict-with-keyword $body

The moore.wait_event op suspends execution of the current process until its body signals that an event has been the detected. Conceptually, the body of this op is executed whenever any potentially relevant signal has changed. If one of the contained moore.detect_event ops detect an event, execution resumes after the moore.wait_event operation. If no event is detected, the current process remains suspended.

Example corresponding to the SystemVerilog @(posedge x, negedge y iff z):

moore.wait_event {
  %0 = moore.read %x : <i1>
  %1 = moore.read %y : <i1>
  %2 = moore.read %z : <i1>
  moore.detect_event posedge %0 : i1
  moore.detect_event negedge %1 if %2 : i1
}

The body may also contain any operations necessary to evaluate the event conditions. For example, the SV @(posedge ~x iff i == 42):

moore.wait_event {
  %0 = moore.read %x : <i1>
  %1 = moore.not %0 : i1
  %2 = moore.read %i : <i19>
  %3 = moore.constant 42 : i19
  %4 = moore.eq %2, %3 : i19
  moore.detect_event posedge %0 if %4 : i1
}

See IEEE 1800-2017 § 9.4.2 “Event control”.

Traits: NoRegionArguments, NoTerminator, RecursiveMemoryEffects, SingleBlock

moore.wildcard_eq (::circt::moore::WildcardEqOp) 

Wildcard equality

Syntax:

operation ::= `moore.wildcard_eq` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the bits in the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the left-hand side is Z or X, returns X. Performs the same comparison as the eq and ne operations, but all right-hand side bits that are X or Z are skipped. Therefore, X and Z in the right-hand side act as wildcards or “don’t care” values. wildcard_eq corresponds to the ==? operator and wildcard_ne to the !=? operator.

See IEEE 1800-2017 § 11.4.6 “Wildcard equality operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.wildcard_ne (::circt::moore::WildcardNeOp) 

Wildcard inequality

Syntax:

operation ::= `moore.wildcard_ne` $lhs `,` $rhs attr-dict `:` type($lhs) `->` type($result)

Compares the bits in the left- and right-hand side operand and returns a single bit 0, 1, or X result. If any bit in the left-hand side is Z or X, returns X. Performs the same comparison as the eq and ne operations, but all right-hand side bits that are X or Z are skipped. Therefore, X and Z in the right-hand side act as wildcards or “don’t care” values. wildcard_eq corresponds to the ==? operator and wildcard_ne to the !=? operator.

See IEEE 1800-2017 § 11.4.6 “Wildcard equality operators”.

Traits: AlwaysSpeculatableImplTrait, SameTypeOperands

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsingle bit type

moore.xor (::circt::moore::XorOp) 

Bitwise XOR operation

Syntax:

operation ::= `moore.xor` $lhs `,` $rhs attr-dict `:` type($result)

Applies the boolean XOR operation to each pair of corresponding bits in the left- and right-hand side operand. Corresponds to the ^ operator.

See IEEE 1800-2017 § 11.4.8 “Bitwise operators”.

01XZ
001XX
110XX
XXXXX
ZXXXX

Traits: AlwaysSpeculatableImplTrait, Commutative, SameOperandsAndResultType

Interfaces: ConditionallySpeculatable, InferTypeOpInterface, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
lhssimple bit vector type
rhssimple bit vector type

Results: 

ResultDescription
resultsimple bit vector type

moore.yield (::circt::moore::YieldOp) 

Conditional yield and termination operation

Syntax:

operation ::= `moore.yield` attr-dict $result `:` type($result)

“moore.yield” yields an SSA value from the Moore dialect op region and terminates the regions. The semantics of how the values are yielded is defined by the parent operation. If “moore.yield” has any operands, the operands must match the parent operation’s results. If the parent operation defines no values, then the “moore.yield” may be left out in the custom syntax and the builders will insert one implicitly. Otherwise, it has to be present in the syntax to indicate which values are yielded.

Traits: AlwaysSpeculatableImplTrait, HasParent<ConditionalOp>, Terminator

Interfaces: ConditionallySpeculatable, NoMemoryEffect (MemoryEffectOpInterface)

Effects: MemoryEffects::Effect{}

Operands: 

OperandDescription
resultunpacked type