aboutsummaryrefslogtreecommitdiffstats
path: root/test/CodeGen/PowerPC/addc.ll
diff options
context:
space:
mode:
Diffstat (limited to 'test/CodeGen/PowerPC/addc.ll')
-rw-r--r--test/CodeGen/PowerPC/addc.ll26
1 files changed, 26 insertions, 0 deletions
diff --git a/test/CodeGen/PowerPC/addc.ll b/test/CodeGen/PowerPC/addc.ll
new file mode 100644
index 0000000..fb4b89f
--- /dev/null
+++ b/test/CodeGen/PowerPC/addc.ll
@@ -0,0 +1,26 @@
+; All of these ands and shifts should be folded into rlwimi's
+; RUN: llvm-as < %s | llc -march=ppc32 | grep addc | wc -l | grep 1 &&
+; RUN: llvm-as < %s | llc -march=ppc32 | grep adde | wc -l | grep 1 &&
+; RUN: llvm-as < %s | llc -march=ppc32 | grep addze | wc -l | grep 1 &&
+; RUN: llvm-as < %s | llc -march=ppc32 | grep addme | wc -l | grep 1 &&
+; RUN: llvm-as < %s | llc -march=ppc32 | grep addic | wc -l | grep 2
+
+implementation ; Functions:
+
+long %add_ll(long %a, long %b) {
+entry:
+ %tmp.2 = add long %b, %a ; <long> [#uses=1]
+ ret long %tmp.2
+}
+
+long %add_l_5(long %a) {
+entry:
+ %tmp.1 = add long %a, 5 ; <long> [#uses=1]
+ ret long %tmp.1
+}
+
+long %add_l_m5(long %a) {
+entry:
+ %tmp.1 = add long %a, -5 ; <long> [#uses=1]
+ ret long %tmp.1
+}