'om' Dialect
The Object Model dialect captures design intent from various domains in an object model.
For more information about the Object Model dialect, see the Object Model Dialect Rationale.
Operations
om.any_cast
(::circt::om::AnyCastOp)
Cast any value to any type.
Syntax:
operation ::= `om.any_cast` $input attr-dict `:` functional-type($input, $result)
Casts any value to AnyType. This is useful for situations where a value of AnyType is needed, but a value of some concrete type is known.
In the evaluator, this is a noop, and the value of concrete type is used.
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Operands:
Operand | Description |
---|---|
input | any type |
Results:
Result | Description |
---|---|
result | A type that represents any valid OM type. |
om.basepath_create
(::circt::om::BasePathCreateOp)
Produce a base path value
Syntax:
operation ::= `om.basepath_create` $basePath $target attr-dict
Produces a value which represents a fragment of a hierarchical path to a target. Given a base path, extend it with the name of a module instance, to produce a new base path. The instance is identified via an NLA. Once the final verilog name of the instance is known, this op can be converted into a FrozenBasePathOp.
Example:
hw.module @Foo() -> () {
hw.inst "bar" sym @bar @Bar() -> ()
}
hw.hierpath @Path [@Foo::@bar]
om.class @OM(%basepath: !om.basepath) {
%0 = om.basepath_create %base @Path
}
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
, SymbolUserOpInterface
Effects: MemoryEffects::Effect{}
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
target | ::mlir::FlatSymbolRefAttr | flat symbol reference attribute |
Operands:
Operand | Description |
---|---|
basePath | A fragment of a path to a hardware component |
Results:
Result | Description |
---|---|
result | A fragment of a path to a hardware component |
om.class
(::circt::om::ClassOp)
Traits: IsolatedFromAbove
, NoTerminator
, SingleBlock
Interfaces: ClassLike
, OpAsmOpInterface
, RegionKindInterface
, Symbol
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
sym_name | ::mlir::StringAttr | string attribute |
formalParamNames | ::mlir::ArrayAttr | string array attribute |
om.class.extern
(::circt::om::ClassExternOp)
Traits: IsolatedFromAbove
, NoTerminator
, SingleBlock
Interfaces: ClassLike
, OpAsmOpInterface
, RegionKindInterface
, Symbol
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
sym_name | ::mlir::StringAttr | string attribute |
formalParamNames | ::mlir::ArrayAttr | string array attribute |
om.class.extern.field
(::circt::om::ClassExternFieldOp)
Syntax:
operation ::= `om.class.extern.field` $name attr-dict `:` $type
Traits: HasParent<ClassExternOp>
Interfaces: ClassFieldLike
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
name | ::mlir::StringAttr | string attribute |
type | ::mlir::TypeAttr | any type attribute |
om.class.field
(::circt::om::ClassFieldOp)
Syntax:
operation ::= `om.class.field` $name `,` $value attr-dict `:` type($value)
Traits: HasParent<ClassOp>
Interfaces: ClassFieldLike
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
name | ::mlir::StringAttr | string attribute |
Operands:
Operand | Description |
---|---|
value | any type |
om.constant
(::circt::om::ConstantOp)
Syntax:
operation ::= `om.constant` $value attr-dict
Traits: AlwaysSpeculatableImplTrait
, ConstantLike
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
value | ::mlir::TypedAttr | TypedAttr instance |
Results:
Result | Description |
---|---|
result | any type |
om.frozenbasepath_create
(::circt::om::FrozenBasePathCreateOp)
Produce a frozen base path value
Syntax:
operation ::= `om.frozenbasepath_create` $basePath custom<BasePathString>($path) attr-dict
Produces a value which represents a fragment of a hierarchical path to a target.
Example:
om.class @OM(%basepath: !om.basepath)
%0 = om.frozenbasepath_create %basepath "Foo/bar:Bar/baz"
}
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
path | ::circt::om::PathAttr | An attribute that represents an instance path |
Operands:
Operand | Description |
---|---|
basePath | A frozen fragment of a path to a hardware component |
Results:
Result | Description |
---|---|
result | A frozen fragment of a path to a hardware component |
om.frozenpath_create
(::circt::om::FrozenPathCreateOp)
Produce a frozen path value
Syntax:
operation ::= `om.frozenpath_create` $targetKind $basePath custom<PathString>($path, $module, $ref, $field)
attr-dict
Produces a value which represents a hierarchical path to a hardware component from a base path to a target.
Example:
om.class @OM(%basepath: !om.basepath)
%0 = om.frozenpath_create reference %base "Foo/bar:Bar>w.a"
}
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
targetKind | ::circt::om::TargetKindAttr | object model target kind |
path | ::circt::om::PathAttr | An attribute that represents an instance path |
module | ::mlir::StringAttr | string attribute |
ref | ::mlir::StringAttr | string attribute |
field | ::mlir::StringAttr | string attribute |
Operands:
Operand | Description |
---|---|
basePath | A frozen fragment of a path to a hardware component |
Results:
Result | Description |
---|---|
result | A frozen path to a hardware component |
om.frozenpath_empty
(::circt::om::FrozenEmptyPathOp)
Produce a frozen path value to nothing
Syntax:
operation ::= `om.frozenpath_empty` attr-dict
Produces a value which represents a hierarchical path to nothing.
Example:
om.class @OM()
%0 = om.frozenpath_empty
}
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Results:
Result | Description |
---|---|
result | A frozen path to a hardware component |
om.integer.add
(::circt::om::IntegerAddOp)
Add two OMIntegerType values
Syntax:
operation ::= `om.integer.add` $lhs `,` $rhs attr-dict `:` type($result)
Perform arbitrary precision signed integer addition of two OMIntegerType values.
Example:
%2 = om.integer.add %0, %1 : !om.integer
Traits: AlwaysSpeculatableImplTrait
, Commutative
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, IntegerBinaryArithmeticOp
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Operands:
Operand | Description |
---|---|
lhs | A type that represents an arbitrary width integer. |
rhs | A type that represents an arbitrary width integer. |
Results:
Result | Description |
---|---|
result | A type that represents an arbitrary width integer. |
om.integer.mul
(::circt::om::IntegerMulOp)
Multiply two OMIntegerType values
Syntax:
operation ::= `om.integer.mul` $lhs `,` $rhs attr-dict `:` type($result)
Perform arbitrary prevision signed integer multiplication of two OMIntegerType values.
Example:
%2 = om.integer.mul %0, %1 : !om.integer
Traits: AlwaysSpeculatableImplTrait
, Commutative
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, IntegerBinaryArithmeticOp
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Operands:
Operand | Description |
---|---|
lhs | A type that represents an arbitrary width integer. |
rhs | A type that represents an arbitrary width integer. |
Results:
Result | Description |
---|---|
result | A type that represents an arbitrary width integer. |
om.integer.shr
(::circt::om::IntegerShrOp)
Shift an OMIntegerType value right by an OMIntegerType value
Syntax:
operation ::= `om.integer.shr` $lhs `,` $rhs attr-dict `:` type($result)
Perform arbitrary precision signed integer arithmetic shift right of the lhs OMIntegerType value by the rhs OMIntegerType value. The rhs value must be non-negative.
Example:
%2 = om.integer.shr %0, %1 : !om.integer
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, IntegerBinaryArithmeticOp
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Operands:
Operand | Description |
---|---|
lhs | A type that represents an arbitrary width integer. |
rhs | A type that represents an arbitrary width integer. |
Results:
Result | Description |
---|---|
result | A type that represents an arbitrary width integer. |
om.list_concat
(::circt::om::ListConcatOp)
Concatenate multiple lists to produce a new list
Syntax:
operation ::= `om.list_concat` $subLists attr-dict `:` type($result)
Produces a value of list type by concatenating the provided lists.
Example:
%3 = om.list_concat %0, %1, %2 : !om.list<string>
Traits: AlwaysSpeculatableImplTrait
, SameOperandsAndResultType
Interfaces: ConditionallySpeculatable
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Operands:
Operand | Description |
---|---|
subLists | variadic of A type that represents a list. |
Results:
Result | Description |
---|---|
result | A type that represents a list. |
om.list_create
(::circt::om::ListCreateOp)
Create a list of values
Creates a list from a sequence of inputs.
%list = om.list_create %a, %b, %c : !om.ref
Traits: AlwaysSpeculatableImplTrait
, SameTypeOperands
Interfaces: ConditionallySpeculatable
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Operands:
Operand | Description |
---|---|
inputs | variadic of any type |
Results:
Result | Description |
---|---|
result | A type that represents a list. |
om.map_create
(::circt::om::MapCreateOp)
Create a map
Creates a map from a sequence of inputs.
%map = om.map_create %e1, %e2 : !om.string, i8
where %e1
and e2
have !om.tuple<!om.string, i8> and
%map
has !om.map<!om.string, i8>
type.
Traits: AlwaysSpeculatableImplTrait
, SameTypeOperands
Interfaces: ConditionallySpeculatable
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Operands:
Operand | Description |
---|---|
inputs | variadic of a pair whose first element is an attribute |
Results:
Result | Description |
---|---|
result | A type that represents a map. A key type must be either |
an integer or string type |
om.object
(::circt::om::ObjectOp)
Syntax:
operation ::= `om.object` $className `(` $actualParams `)` attr-dict `:`
functional-type($actualParams, $result)
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, NoMemoryEffect (MemoryEffectOpInterface)
, SymbolUserOpInterface
Effects: MemoryEffects::Effect{}
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
className | ::mlir::StringAttr | string attribute |
Operands:
Operand | Description |
---|---|
actualParams | variadic of any type |
Results:
Result | Description |
---|---|
result | A type that represents a reference to a Class. |
om.object.field
(::circt::om::ObjectFieldOp)
Syntax:
operation ::= `om.object.field` $object `,` $fieldPath attr-dict `:` functional-type($object, $result)
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
fieldPath | ::mlir::ArrayAttr | flat symbol ref array attribute |
Operands:
Operand | Description |
---|---|
object | A type that represents a reference to a Class. |
Results:
Result | Description |
---|---|
result | any type |
om.path_create
(::circt::om::PathCreateOp)
Produce a path value
Syntax:
operation ::= `om.path_create` $targetKind $basePath $target attr-dict
Produces a value which represents a hierarchical path to a hardware target. from a base path to a target.
Example:
hw.module @Foo() -> () {
%wire = hw.wire sym @w: !i1
}
hw.hierpath @Path [@Foo::@w]
om.class @OM(%basepath: !om.basepath)
%0 = om.path_create reference %basepath @Path
}
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
, SymbolUserOpInterface
Effects: MemoryEffects::Effect{}
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
targetKind | ::circt::om::TargetKindAttr | object model target kind |
target | ::mlir::FlatSymbolRefAttr | flat symbol reference attribute |
Operands:
Operand | Description |
---|---|
basePath | A fragment of a path to a hardware component |
Results:
Result | Description |
---|---|
result | A path to a hardware component |
om.path_empty
(::circt::om::EmptyPathOp)
Produce a path value to nothing
Syntax:
operation ::= `om.path_empty` attr-dict
Produces a value which represents a hierarchical path to nothing.
Example:
om.class @OM()
%0 = om.path_empty
}
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Results:
Result | Description |
---|---|
result | A path to a hardware component |
om.tuple_create
(::circt::om::TupleCreateOp)
Create a tuple of values
Syntax:
operation ::= `om.tuple_create` $inputs attr-dict `:` type($inputs)
Create a tuple from a sequence of inputs.
%tuple = om.tuple_create %a, %b, %c : !om.ref, !om.string, !om.list<i32>
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Operands:
Operand | Description |
---|---|
inputs | variadic of any type |
Results:
Result | Description |
---|---|
result | tuple with any combination of any type values |
om.tuple_get
(::circt::om::TupleGetOp)
Extract a value from a tuple
Syntax:
operation ::= `om.tuple_get` $input `[` $index `]` attr-dict `:` type($input)
Extract a value from a tuple.
%value = om.tuple_get %a[0] : tuple<!om.ref, !om.string, !om.list<i32>>
Traits: AlwaysSpeculatableImplTrait
Interfaces: ConditionallySpeculatable
, InferTypeOpInterface
, NoMemoryEffect (MemoryEffectOpInterface)
Effects: MemoryEffects::Effect{}
Attributes:
Attribute | MLIR Type | Description |
---|---|---|
index | ::mlir::IntegerAttr | 32-bit signless integer attribute |
Operands:
Operand | Description |
---|---|
input | tuple with any combination of any type values |
Results:
Result | Description |
---|---|
result | any type |
Attributes
MapAttr
An attribute that represents a string map
Syntax:
#om.map<
mlir::Type, # valueType
mlir::DictionaryAttr # elements
>
Parameters:
Parameter | C++ type | Description |
---|---|---|
valueType | mlir::Type | |
elements | mlir::DictionaryAttr |
IntegerAttr
An attribute that represents an arbitrary integer
Syntax:
#om.integer<
mlir::IntegerAttr # value
>
Parameters:
Parameter | C++ type | Description |
---|---|---|
value | mlir::IntegerAttr |
ListAttr
An attribute that represents a list
Syntax:
#om.list<
mlir::Type, # elementType
mlir::ArrayAttr # elements
>
Parameters:
Parameter | C++ type | Description |
---|---|---|
elementType | mlir::Type | |
elements | mlir::ArrayAttr |
PathAttr
An attribute that represents an instance path
Parameters:
Parameter | C++ type | Description |
---|---|---|
path | ::llvm::ArrayRef<::circt::om::PathElement> |
SymbolRefAttr
An attribute that wraps a FlatSymbolRefAttr type
Syntax:
#om.sym_ref<
mlir::FlatSymbolRefAttr # ref
>
Parameters:
Parameter | C++ type | Description |
---|---|---|
ref | mlir::FlatSymbolRefAttr |
ReferenceAttr
An attribute that wraps a #hw.innerNameRef with !om.ref type
Syntax:
#om.ref<
circt::hw::InnerRefAttr # innerRef
>
Parameters:
Parameter | C++ type | Description |
---|---|---|
innerRef | circt::hw::InnerRefAttr |
Types
BasePathType
A fragment of a path to a hardware component
Syntax: !om.basepath
ClassType
A type that represents a reference to a Class.
Syntax:
!om.class.type<
mlir::FlatSymbolRefAttr # className
>
Parameters:
Parameter | C++ type | Description |
---|---|---|
className | mlir::FlatSymbolRefAttr |
FrozenBasePathType
A frozen fragment of a path to a hardware component
Syntax: !om.frozenbasepath
FrozenPathType
A frozen path to a hardware component
Syntax: !om.frozenpath
ListType
A type that represents a list.
Syntax:
!om.list<
mlir::Type # elementType
>
Parameters:
Parameter | C++ type | Description |
---|---|---|
elementType | mlir::Type |
MapType
A type that represents a map. A key type must be either an integer or string type
Syntax:
!om.map<
mlir::Type, # keyType
mlir::Type # valueType
>
Parameters:
Parameter | C++ type | Description |
---|---|---|
keyType | mlir::Type | |
valueType | mlir::Type |
AnyType
A type that represents any valid OM type.
Syntax: !om.any
OMIntegerType
A type that represents an arbitrary width integer.
Syntax: !om.integer
PathType
A path to a hardware component
Syntax: !om.path
ReferenceType
A type that represents a reference to a hardware entity.
Syntax: !om.ref
StringType
A type that represents a string.
Syntax: !om.string
SymbolRefType
A type that represents a reference to a flat symbol reference.
Syntax: !om.sym_ref
Enums
TargetKind
object model target kind
Cases:
Symbol | Value | String |
---|---|---|
DontTouch | 0 | dont_touch |
Instance | 1 | instance |
MemberInstance | 2 | member_instance |
MemberReference | 3 | member_reference |
Reference | 4 | reference |