-
Notifications
You must be signed in to change notification settings - Fork 12.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[PowerPC] Add the SCV instruction. #68063
Conversation
@llvm/pr-subscribers-mc ChangesThe SCV instruciton was added on PowerPC on Power 9. This patch adds the SCV so that it may be used as part of inline asm but does not provide patterns for it or scheduling information. Full diff: https://github.com/llvm/llvm-project/pull/68063.diff 5 Files Affected:
diff --git a/llvm/lib/Target/PowerPC/PPCInstrFormats.td b/llvm/lib/Target/PowerPC/PPCInstrFormats.td
index 224c7b281ac4468..6501c17dd810e64 100644
--- a/llvm/lib/Target/PowerPC/PPCInstrFormats.td
+++ b/llvm/lib/Target/PowerPC/PPCInstrFormats.td
@@ -220,7 +220,7 @@ BForm_4<bits<6> opcode, bits<5> bo, bit aa, bit lk,
}
// 1.7.3 SC-Form
-class SCForm<bits<6> opcode, bits<1> xo,
+class SCForm<bits<6> opcode, bits<1> xo1, bits<1> xo2,
dag OOL, dag IOL, string asmstr, InstrItinClass itin,
list<dag> pattern>
: I<opcode, OOL, IOL, asmstr, itin> {
@@ -229,7 +229,8 @@ class SCForm<bits<6> opcode, bits<1> xo,
let Pattern = pattern;
let Inst{20-26} = LEV;
- let Inst{30} = xo;
+ let Inst{30} = xo1;
+ let Inst{31} = xo2;
}
// 1.7.4 D-Form
diff --git a/llvm/lib/Target/PowerPC/PPCInstrInfo.td b/llvm/lib/Target/PowerPC/PPCInstrInfo.td
index 0567665fbc7349f..a97062e0c643fb2 100644
--- a/llvm/lib/Target/PowerPC/PPCInstrInfo.td
+++ b/llvm/lib/Target/PowerPC/PPCInstrInfo.td
@@ -1641,10 +1641,18 @@ let isBranch = 1, isTerminator = 1, Size = 0 in {
// System call.
let PPC970_Unit = 7 in {
- def SC : SCForm<17, 1, (outs), (ins i32imm:$LEV),
+ def SC : SCForm<17, 1, 0, (outs), (ins i32imm:$LEV),
"sc $LEV", IIC_BrB, [(PPCsc (i32 imm:$LEV))]>;
}
+// We mark SCV as having no scheduling model since it is only meant to be used
+// as inline assembly. If we implement a builtin pattern for it we will need to
+// add it to the P9 and P10 scheduling models.
+let Predicates = [IsISA3_0], hasNoSchedulingInfo = 1 in {
+ def SCV : SCForm<17, 0, 1, (outs), (ins i32imm:$LEV),
+ "scv $LEV", IIC_BrB, []>;
+}
+
// Branch history rolling buffer.
def CLRBHRB : XForm_0<31, 430, (outs), (ins), "clrbhrb", IIC_BrB,
[(PPCclrbhrb)]>,
diff --git a/llvm/test/MC/Disassembler/PowerPC/ppc64-encoding.txt b/llvm/test/MC/Disassembler/PowerPC/ppc64-encoding.txt
index 1050a324767e072..567c4fa5bd5ab51 100644
--- a/llvm/test/MC/Disassembler/PowerPC/ppc64-encoding.txt
+++ b/llvm/test/MC/Disassembler/PowerPC/ppc64-encoding.txt
@@ -73,6 +73,12 @@
# CHECK: sc
0x44 0x00 0x00 0x02
+# CHECK: scv 1
+0x44 0x00 0x00 0x21
+
+# CHECK: scv 2
+0x44 0x00 0x00 0x41
+
# CHECK: clrbhrb
0x7c 0x00 0x03 0x5c
diff --git a/llvm/test/MC/Disassembler/PowerPC/ppc64le-encoding.txt b/llvm/test/MC/Disassembler/PowerPC/ppc64le-encoding.txt
index bdade9867ed6fbe..15427e91a5b2aac 100644
--- a/llvm/test/MC/Disassembler/PowerPC/ppc64le-encoding.txt
+++ b/llvm/test/MC/Disassembler/PowerPC/ppc64le-encoding.txt
@@ -73,6 +73,12 @@
# CHECK: sc
0x02 0x00 0x00 0x44
+# CHECK: scv 1
+0x21 0x00 0x00 0x44
+
+# CHECK: scv 2
+0x41 0x00 0x00 0x44
+
# CHECK: clrbhrb
0x5c 0x03 0x00 0x7c
diff --git a/llvm/test/MC/PowerPC/ppc64-encoding.s b/llvm/test/MC/PowerPC/ppc64-encoding.s
index 149ee005b4c301c..36bef5e39bd94e4 100644
--- a/llvm/test/MC/PowerPC/ppc64-encoding.s
+++ b/llvm/test/MC/PowerPC/ppc64-encoding.s
@@ -144,7 +144,7 @@
# CHECK-LE: mcrf 2, 3 # encoding: [0x00,0x00,0x0c,0x4d]
mcrf 2, 3
-# System call instruction
+# System call instructions
# CHECK-BE: sc 1 # encoding: [0x44,0x00,0x00,0x22]
# CHECK-LE: sc 1 # encoding: [0x22,0x00,0x00,0x44]
@@ -153,6 +153,13 @@
# CHECK-LE: sc # encoding: [0x02,0x00,0x00,0x44]
sc
+# CHECK-BE: scv 1 # encoding: [0x44,0x00,0x00,0x21]
+# CHECK-LE: scv 1 # encoding: [0x21,0x00,0x00,0x44]
+ scv 1
+# CHECK-BE: scv 2 # encoding: [0x44,0x00,0x00,0x41]
+# CHECK-LE: scv 2 # encoding: [0x41,0x00,0x00,0x44]
+ scv 2
+
# Branch history rolling buffer
# CHECK-BE: clrbhrb # encoding: [0x7c,0x00,0x03,0x5c]
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM.
The SCV instruciton was added on PowerPC on Power 9. This patch adds the SCV so that it may be used as part of inline asm but does not provide patterns for it or scheduling information.
d4d28b1
to
cf76a92
Compare
The SCV instruciton was added on PowerPC on Power 9. This patch adds the SCV so that it may be used as part of inline asm but does not provide patterns for it or scheduling information.