summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/AVR/frame.ll
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/test/CodeGen/AVR/frame.ll')
-rw-r--r--llvm/test/CodeGen/AVR/frame.ll65
1 files changed, 65 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/AVR/frame.ll b/llvm/test/CodeGen/AVR/frame.ll
new file mode 100644
index 00000000000..cd997a454db
--- /dev/null
+++ b/llvm/test/CodeGen/AVR/frame.ll
@@ -0,0 +1,65 @@
+; RUN: llc -mattr=mul < %s -march=avr | FileCheck %s
+
+declare float @dsin(float)
+declare float @dcos(float)
+declare float @dasin(float)
+
+; Test prologue and epilogue insertion
+define float @f3(float %days) {
+entry:
+; CHECK-LABEL: f3:
+; prologue code:
+; CHECK: push r28
+; CHECK: push r29
+; CHECK: in r28, 61
+; CHECK-NEXT: in r29, 62
+; CHECK-NEXT: sbiw r28, [[SIZE:[0-9]+]]
+; CHECK-NEXT: in r0, 63
+; CHECK-NEXT: cli
+; CHECK-NEXT: out 62, r29
+; CHECK-NEXT: out 63, r0
+; CHECK-NEXT: out 61, r28
+; epilogue code:
+; CHECK: adiw r28, [[SIZE]]
+; CHECK-NEXT: in r0, 63
+; CHECK-NEXT: cli
+; CHECK-NEXT: out 62, r29
+; CHECK-NEXT: out 63, r0
+; CHECK-NEXT: out 61, r28
+; CHECK: pop r29
+; CHECK: pop r28
+ %mul = fmul float %days, 0x3FEF8A6C60000000
+ %add = fadd float %mul, 0x40718776A0000000
+ %mul1 = fmul float %days, 0x3FEF8A09A0000000
+ %add2 = fadd float %mul1, 0x4076587740000000
+ %mul3 = fmul float %days, 0x3E81B35CC0000000
+ %sub = fsub float 0x3FFEA235C0000000, %mul3
+ %call = call float @dsin(float %add2)
+ %mul4 = fmul float %sub, %call
+ %mul5 = fmul float %days, 0x3E27C04CA0000000
+ %sub6 = fsub float 0x3F94790B80000000, %mul5
+ %mul7 = fmul float %add2, 2.000000e+00
+ %call8 = call float @dsin(float %mul7)
+ %mul9 = fmul float %sub6, %call8
+ %add10 = fadd float %mul4, %mul9
+ %add11 = fadd float %add, %add10
+ %mul12 = fmul float %days, 0x3E13C5B640000000
+ %sub13 = fsub float 0x3F911C1180000000, %mul12
+ %mul14 = fmul float %add, 2.000000e+00
+ %call15 = call float @dsin(float %mul14)
+ %mul16 = fmul float %call15, 0x3FF1F736C0000000
+ %mul17 = fmul float %sub13, 2.000000e+00
+ %mul19 = fmul float %mul17, %call
+ %sub20 = fsub float %mul16, %mul19
+ %mul21 = fmul float %sub13, 4.000000e+00
+ %mul22 = fmul float %mul21, 0x3FF1F736C0000000
+ %mul24 = fmul float %mul22, %call
+ %call26 = call float @dcos(float %mul14)
+ %mul27 = fmul float %mul24, %call26
+ %add28 = fadd float %sub20, %mul27
+ %call29 = call float @dsin(float %add11)
+ %mul30 = fmul float %call29, 0x3FF0AB6960000000
+ %call31 = call float @dasin(float %mul30)
+ %add32 = fadd float %call31, %add28
+ ret float %add32
+}
OpenPOWER on IntegriCloud