-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path0052-Xtensa-Implement-lowering-llvm-intrinsics.patch
110 lines (102 loc) · 4.03 KB
/
0052-Xtensa-Implement-lowering-llvm-intrinsics.patch
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
From d3a689a61dfaae4554ab259f8c2b91b84d04d484 Mon Sep 17 00:00:00 2001
From: Andrei Safronov <[email protected]>
Date: Wed, 5 Apr 2023 00:59:04 +0300
Subject: [PATCH 052/158] [Xtensa] Implement lowering llvm intrinsics
fshr/fshl.
---
llvm/lib/Target/Xtensa/XtensaISelLowering.cpp | 27 +++++++++++++++++++
llvm/lib/Target/Xtensa/XtensaISelLowering.h | 1 +
llvm/test/CodeGen/Xtensa/funnel-shift.ll | 24 +++++++++++++++++
3 files changed, 52 insertions(+)
create mode 100644 llvm/test/CodeGen/Xtensa/funnel-shift.ll
diff --git a/llvm/lib/Target/Xtensa/XtensaISelLowering.cpp b/llvm/lib/Target/Xtensa/XtensaISelLowering.cpp
index f057b49e7a6e..a45cb71ad11c 100644
--- a/llvm/lib/Target/Xtensa/XtensaISelLowering.cpp
+++ b/llvm/lib/Target/Xtensa/XtensaISelLowering.cpp
@@ -188,6 +188,10 @@ XtensaTargetLowering::XtensaTargetLowering(const TargetMachine &tm,
setOperationAction(ISD::SRA_PARTS, MVT::i32, Custom);
setOperationAction(ISD::SRL_PARTS, MVT::i32, Custom);
+ // Funnel shifts
+ setOperationAction(ISD::FSHR, MVT::i32, Custom);
+ setOperationAction(ISD::FSHL, MVT::i32, Custom);
+
// Bit Manipulation
setOperationAction(ISD::BSWAP, MVT::i32, Expand);
setOperationAction(ISD::BSWAP, MVT::i64, Expand);
@@ -1681,6 +1685,26 @@ SDValue XtensaTargetLowering::LowerShiftRightParts(SDValue Op,
return DAG.getMergeValues(Ops, DL);
}
+SDValue XtensaTargetLowering::LowerFunnelShift(SDValue Op,
+ SelectionDAG &DAG) const {
+ SDLoc DL(Op);
+ SDValue Op0 = Op.getOperand(0);
+ SDValue Op1 = Op.getOperand(1);
+ SDValue Shamt = Op.getOperand(2);
+ MVT VT = Op.getSimpleValueType();
+
+ bool IsFSHR = Op.getOpcode() == ISD::FSHR;
+ assert((VT == MVT::i32) && "Unexpected funnel shift type!");
+
+ if (!IsFSHR) {
+ Shamt = DAG.getNode(ISD::SUB, DL, MVT::i32,
+ DAG.getConstant(32, DL, MVT::i32), Shamt);
+ }
+ SDValue SetSAR = DAG.getNode(XtensaISD::SSR, DL,
+ MVT::Glue, Shamt);
+ return DAG.getNode(XtensaISD::SRC, DL, VT, Op0, Op1, SetSAR);
+}
+
SDValue XtensaTargetLowering::LowerATOMIC_FENCE(SDValue Op,
SelectionDAG &DAG) const {
SDLoc DL(Op);
@@ -1735,6 +1759,9 @@ SDValue XtensaTargetLowering::LowerOperation(SDValue Op,
return LowerShiftRightParts(Op, DAG, true);
case ISD::SRL_PARTS:
return LowerShiftRightParts(Op, DAG, false);
+ case ISD::FSHL:
+ case ISD::FSHR:
+ return LowerFunnelShift(Op, DAG);
default:
llvm_unreachable("Unexpected node to lower");
}
diff --git a/llvm/lib/Target/Xtensa/XtensaISelLowering.h b/llvm/lib/Target/Xtensa/XtensaISelLowering.h
index c1db77548308..d2b61cd4ed73 100644
--- a/llvm/lib/Target/Xtensa/XtensaISelLowering.h
+++ b/llvm/lib/Target/Xtensa/XtensaISelLowering.h
@@ -193,6 +193,7 @@ private:
SDValue LowerShiftLeftParts(SDValue Op, SelectionDAG &DAG) const;
SDValue LowerShiftRightParts(SDValue Op, SelectionDAG &DAG, bool IsSRA) const;
+ SDValue LowerFunnelShift(SDValue Op, SelectionDAG &DAG) const;
SDValue LowerATOMIC_FENCE(SDValue Op, SelectionDAG &DAG) const;
diff --git a/llvm/test/CodeGen/Xtensa/funnel-shift.ll b/llvm/test/CodeGen/Xtensa/funnel-shift.ll
new file mode 100644
index 000000000000..09bf081be373
--- /dev/null
+++ b/llvm/test/CodeGen/Xtensa/funnel-shift.ll
@@ -0,0 +1,24 @@
+; RUN: llc -O1 -mtriple=xtensa -mcpu=esp32 %s -o - | FileCheck %s
+
+define dso_local i32 @test_fshr(i32 %value1, i32 %value2, i32 %shift) nounwind {
+; CHECK-LABEL: @test_fshr
+; CHECK: ssr a4
+; CHECK: src a2, a2, a3
+entry:
+ %0 = tail call i32 @llvm.fshr.i32(i32 %value1, i32 %value2, i32 %shift)
+ ret i32 %0
+}
+
+define dso_local i32 @test_fshl(i32 %value1, i32 %value2, i32 %shift) nounwind {
+; CHECK-LABEL: @test_fshl
+; CHECK: movi.n a8, 32
+; CHECK: sub a8, a8, a4
+; CHECK: ssr a8
+; CHECK: src a2, a2, a3
+entry:
+ %0 = tail call i32 @llvm.fshl.i32(i32 %value1, i32 %value2, i32 %shift)
+ ret i32 %0
+}
+
+declare i32 @llvm.fshr.i32(i32, i32, i32) nounwind
+declare i32 @llvm.fshl.i32(i32, i32, i32) nounwind
--
2.40.1