| ; RUN: sed -e "s/RETTYPE/void/;s/RETVAL//" %s | llc -mtriple=aarch64-apple-darwin | FileCheck --check-prefixes=ALL %s |
| ; RUN: sed -e "s/RETTYPE/i32/;s/RETVAL/undef/" %s | llc -mtriple=aarch64-apple-darwin | FileCheck --check-prefixes=ALL %s |
| ; RUN: sed -e "s/RETTYPE/\{i64\,i64\}/;s/RETVAL/undef/" %s | llc -mtriple=aarch64-apple-darwin | FileCheck --check-prefixes=ALL %s |
| ; RUN: sed -e "s/RETTYPE/double/;s/RETVAL/0./" %s | llc -mtriple=aarch64-apple-darwin | FileCheck --check-prefixes=ALL,DOUBLE %s |
| |
| ; We don't need to save registers before using them inside preserve_none function. |
| define preserve_nonecc RETTYPE @preserve_nonecc1(i64, i64, double, double) nounwind { |
| entry: |
| ;ALL-LABEL: preserve_nonecc1 |
| ;ALL: ; %bb.0: |
| ;ALL-NEXT: InlineAsm Start |
| ;ALL-NEXT: InlineAsm End |
| ;DOUBLE-NEXT: movi d0, #0000000000000000 |
| ;ALL-NEXT: ret |
| call void asm sideeffect "", "~{x0},~{x1},~{x2},~{x3},~{x4},~{x5},~{x6},~{x7},~{x8},~{x9},~{x10},~{x11},~{x12},~{x13},~{x14},~{x15},~{x16},~{x17},~{x19},~{x20},~{x21},~{x22},~{x23},~{x24},~{x25},~{x26},~{x27},~{x28},~{d0},~{d1},~{d2},~{d3},~{d4},~{d5},~{d6},~{d7},~{d8},~{d9},~{d10},~{d11},~{d12},~{d13},~{d14},~{d15},~{d16}"() |
| ret RETTYPE RETVAL |
| } |
| |
| ; When calling a preserve_none function, all live registers must be saved and |
| ; restored around the function call. |
| declare preserve_nonecc RETTYPE @preserve_nonecc2(i64, i64, double, double) |
| define void @bar() nounwind { |
| entry: |
| ;ALL-LABEL: bar |
| ;ALL: InlineAsm Start |
| ;ALL: stp x9, x8 |
| ;ALL: stp x11, x10 |
| ;ALL: stp x13, x12 |
| ;ALL: stp x15, x14 |
| ;ALL: stp x17, x16 |
| ;ALL: stp x20, x19 |
| ;ALL: stp x22, x21 |
| ;ALL: stp x24, x23 |
| ;ALL: stp x26, x25 |
| ;ALL: stp x28, x27 |
| ;ALL: stp d8, d7 |
| ;ALL: stp d10, d9 |
| ;ALL: stp d12, d11 |
| ;ALL: stp d14, d13 |
| ;ALL: stp d16, d15 |
| ;ALL: ldp x20, x19 |
| ;ALL: ldp x22, x21 |
| ;ALL: ldp x24, x23 |
| ;ALL: ldp x26, x25 |
| ;ALL: ldp x28, x27 |
| ;ALL: ldp d8, d7 |
| ;ALL: ldp d10, d9 |
| ;ALL: ldp d12, d11 |
| ;ALL: ldp d14, d13 |
| ;ALL: ldp d16, d15 |
| ;ALL: ldp x9, x8 |
| ;ALL: ldp x11, x10 |
| ;ALL: ldp x13, x12 |
| ;ALL: ldp x15, x14 |
| ;ALL: ldp x17, x16 |
| ;ALL: InlineAsm Start |
| %a0 = call i64 asm sideeffect "", "={x8}"() nounwind |
| %a1 = call i64 asm sideeffect "", "={x9}"() nounwind |
| %a2 = call i64 asm sideeffect "", "={x10}"() nounwind |
| %a3 = call i64 asm sideeffect "", "={x11}"() nounwind |
| %a4 = call i64 asm sideeffect "", "={x12}"() nounwind |
| %a5 = call i64 asm sideeffect "", "={x13}"() nounwind |
| %a6 = call i64 asm sideeffect "", "={x14}"() nounwind |
| %a7 = call i64 asm sideeffect "", "={x15}"() nounwind |
| %a8 = call i64 asm sideeffect "", "={x16}"() nounwind |
| %a9 = call i64 asm sideeffect "", "={x17}"() nounwind |
| %a10 = call i64 asm sideeffect "", "={x19}"() nounwind |
| %a11 = call i64 asm sideeffect "", "={x20}"() nounwind |
| %a12 = call i64 asm sideeffect "", "={x21}"() nounwind |
| %a13 = call i64 asm sideeffect "", "={x22}"() nounwind |
| %a14 = call i64 asm sideeffect "", "={x23}"() nounwind |
| %a15 = call i64 asm sideeffect "", "={x24}"() nounwind |
| %a16 = call i64 asm sideeffect "", "={x25}"() nounwind |
| %a17 = call i64 asm sideeffect "", "={x26}"() nounwind |
| %a18 = call i64 asm sideeffect "", "={x27}"() nounwind |
| %a19 = call i64 asm sideeffect "", "={x28}"() nounwind |
| |
| %f0 = call <1 x double> asm sideeffect "", "={d7}"() nounwind |
| %f1 = call <1 x double> asm sideeffect "", "={d8}"() nounwind |
| %f2 = call <1 x double> asm sideeffect "", "={d9}"() nounwind |
| %f3 = call <1 x double> asm sideeffect "", "={d10}"() nounwind |
| %f4 = call <1 x double> asm sideeffect "", "={d11}"() nounwind |
| %f5 = call <1 x double> asm sideeffect "", "={d12}"() nounwind |
| %f6 = call <1 x double> asm sideeffect "", "={d13}"() nounwind |
| %f7 = call <1 x double> asm sideeffect "", "={d14}"() nounwind |
| %f8 = call <1 x double> asm sideeffect "", "={d15}"() nounwind |
| %f9 = call <1 x double> asm sideeffect "", "={d16}"() nounwind |
| |
| call preserve_nonecc RETTYPE @preserve_nonecc2(i64 1, i64 2, double 3.0, double 4.0) |
| call void asm sideeffect "", "{x8},{x9},{x10},{x11},{x12},{x13},{x14},{x15},{x16},{x17},{x19},{x20},{x21},{x22},{x23},{x24},{x25},{x26},{x27},{x28},{d7},{d8},{d9},{d10},{d11},{d12},{d13},{d14},{d15},{d16}"(i64 %a0, i64 %a1, i64 %a2, i64 %a3, i64 %a4, i64 %a5, i64 %a6, i64 %a7, i64 %a8, i64 %a9, i64 %a10, i64 %a11, i64 %a12, i64 %a13, i64 %a14, i64 %a15, i64 %a16, i64 %a17, i64 %a18, i64 %a19, <1 x double> %f0, <1 x double> %f1, <1 x double> %f2, <1 x double> %f3, <1 x double> %f4, <1 x double> %f5, <1 x double> %f6, <1 x double> %f7, <1 x double> %f8, <1 x double> %f9) |
| ret void |
| } |