Skip to content

Commit

Permalink
dialects (arm): add mul instruction with 2 source registers (#3515)
Browse files Browse the repository at this point in the history
Add mul instruction
(https://developer.arm.com/documentation/ddi0597/2024-06/Base-Instructions/MUL--MULS--Multiply-?lang=en).

The mul instruction supports either 2 or 3 operands (in the case of 2,
the destination is also treated as the 2nd source). This PR only handles
the case where 3 operands are provided, 2 source registers and 1
destination.
  • Loading branch information
emmau678 authored Nov 26, 2024
1 parent 6118e11 commit 20902a3
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 1 deletion.
8 changes: 8 additions & 0 deletions tests/filecheck/dialects/arm/test_ops.mlir
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,17 @@
// CHECK: %x1 = arm.get_register : !arm.reg<x1>
%x1 = arm.get_register : !arm.reg<x1>

// CHECK: %x2 = arm.get_register : !arm.reg<x2>
%x2 = arm.get_register : !arm.reg<x2>

// CHECK: %ds_mov = arm.ds.mov %x1 {"comment" = "move contents of s to d"} : (!arm.reg<x1>) -> !arm.reg<x2>
// CHECK-ASM: mov x2, x1 # move contents of s to d
%ds_mov = arm.ds.mov %x1 {"comment" = "move contents of s to d"} : (!arm.reg<x1>) -> !arm.reg<x2>

// CHECK: %dss_mul = arm.dss.mul %x1, %x2 {"comment" = "multiply s1 by s2"} : (!arm.reg<x1>, !arm.reg<x2>) -> !arm.reg<x3>
// CHECK-ASM: mul x3, x1, x2 # multiply s1 by s2
%dss_mul = arm.dss.mul %x1, %x2 {"comment" = "multiply s1 by s2"} : (!arm.reg<x1>, !arm.reg<x2>) -> !arm.reg<x3>

// CHECK-GENERIC: %x1 = "arm.get_register"() : () -> !arm.reg<x1>
// CHECK-GENERIC: %ds_mov = "arm.ds.mov"(%x1) {"comment" = "move contents of s to d"} : (!arm.reg<x1>) -> !arm.reg<x2>
// CHECK-GENERIC: %dss_mul = "arm.dss.mul"(%x1, %x2) {"comment" = "multiply s1 by s2"} : (!arm.reg<x1>, !arm.reg<x2>) -> !arm.reg<x3>
3 changes: 2 additions & 1 deletion xdsl/dialects/arm/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
from xdsl.dialects.builtin import ModuleOp
from xdsl.ir import Dialect

from .ops import ARMOperation, DSMovOp, GetRegisterOp
from .ops import ARMOperation, DSMovOp, DSSMulOp, GetRegisterOp
from .register import IntRegisterType


Expand All @@ -25,6 +25,7 @@ def print_assembly(module: ModuleOp, output: IO[str]) -> None:
[
GetRegisterOp,
DSMovOp,
DSSMulOp,
],
[
IntRegisterType,
Expand Down
40 changes: 40 additions & 0 deletions xdsl/dialects/arm/ops.py
Original file line number Diff line number Diff line change
Expand Up @@ -114,3 +114,43 @@ def __init__(self, register_type: IntRegisterType):

def assembly_line(self):
return None


@irdl_op_definition
class DSSMulOp(ARMInstruction):
"""
Multiplies the values in s1 and s2 and stores the result in d.
https://developer.arm.com/documentation/ddi0597/2024-06/Base-Instructions/MUL--MULS--Multiply-?lang=en
"""

name = "arm.dss.mul"

d = result_def(IntRegisterType)
s1 = operand_def(IntRegisterType)
s2 = operand_def(IntRegisterType)
assembly_format = (
"$s1 `,` $s2 attr-dict `:` `(` type($s1) `,` type($s2) `)` `->` type($d)"
)

def __init__(
self,
s1: Operation | SSAValue,
s2: Operation | SSAValue,
*,
d: IntRegisterType,
comment: str | StringAttr | None = None,
):
if isinstance(comment, str):
comment = StringAttr(comment)

super().__init__(
operands=(s1, s2),
attributes={
"comment": comment,
},
result_types=(d,),
)

def assembly_line_args(self):
return (self.d, self.s1, self.s2)

0 comments on commit 20902a3

Please sign in to comment.