blob: 897101d30430dbebe4688e5d59edcba2d2ce6e47 [file]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
; RUN: llc -mtriple=avr-unknown-unknown < %s | FileCheck -check-prefixes=CHECK,NONGNU %s
; RUN: llc -mtriple=avr-unknown-linux-gnu < %s | FileCheck -check-prefixes=CHECK,GNU %s
define { half, half } @test_sincos_f16(half %a) #0 {
; NONGNU-LABEL: test_sincos_f16:
; NONGNU: ; %bb.0:
; NONGNU-NEXT: push r12
; NONGNU-NEXT: push r13
; NONGNU-NEXT: push r14
; NONGNU-NEXT: push r15
; NONGNU-NEXT: push r16
; NONGNU-NEXT: push r17
; NONGNU-NEXT: mov r24, r22
; NONGNU-NEXT: mov r25, r23
; NONGNU-NEXT: rcall __extendhfsf2
; NONGNU-NEXT: mov r16, r22
; NONGNU-NEXT: mov r17, r23
; NONGNU-NEXT: mov r14, r24
; NONGNU-NEXT: mov r15, r25
; NONGNU-NEXT: rcall sin
; NONGNU-NEXT: rcall __truncsfhf2
; NONGNU-NEXT: mov r12, r24
; NONGNU-NEXT: mov r13, r25
; NONGNU-NEXT: mov r22, r16
; NONGNU-NEXT: mov r23, r17
; NONGNU-NEXT: mov r24, r14
; NONGNU-NEXT: mov r25, r15
; NONGNU-NEXT: rcall cos
; NONGNU-NEXT: rcall __truncsfhf2
; NONGNU-NEXT: mov r22, r24
; NONGNU-NEXT: mov r23, r25
; NONGNU-NEXT: mov r18, r12
; NONGNU-NEXT: mov r19, r13
; NONGNU-NEXT: pop r17
; NONGNU-NEXT: pop r16
; NONGNU-NEXT: pop r15
; NONGNU-NEXT: pop r14
; NONGNU-NEXT: pop r13
; NONGNU-NEXT: pop r12
; NONGNU-NEXT: ret
;
; GNU-LABEL: test_sincos_f16:
; GNU: ; %bb.0:
; GNU-NEXT: push r16
; GNU-NEXT: push r17
; GNU-NEXT: push r28
; GNU-NEXT: push r29
; GNU-NEXT: in r28, 61
; GNU-NEXT: in r29, 62
; GNU-NEXT: sbiw r28, 8
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: mov r24, r22
; GNU-NEXT: mov r25, r23
; GNU-NEXT: rcall __extendhfsf2
; GNU-NEXT: mov r20, r28
; GNU-NEXT: mov r21, r29
; GNU-NEXT: subi r20, 251
; GNU-NEXT: sbci r21, 255
; GNU-NEXT: mov r18, r28
; GNU-NEXT: mov r19, r29
; GNU-NEXT: subi r18, 255
; GNU-NEXT: sbci r19, 255
; GNU-NEXT: rcall sincosf
; GNU-NEXT: ldd r22, Y+5
; GNU-NEXT: ldd r23, Y+6
; GNU-NEXT: ldd r24, Y+7
; GNU-NEXT: ldd r25, Y+8
; GNU-NEXT: rcall __truncsfhf2
; GNU-NEXT: mov r16, r24
; GNU-NEXT: mov r17, r25
; GNU-NEXT: ldd r22, Y+1
; GNU-NEXT: ldd r23, Y+2
; GNU-NEXT: ldd r24, Y+3
; GNU-NEXT: ldd r25, Y+4
; GNU-NEXT: rcall __truncsfhf2
; GNU-NEXT: mov r22, r24
; GNU-NEXT: mov r23, r25
; GNU-NEXT: mov r18, r16
; GNU-NEXT: mov r19, r17
; GNU-NEXT: adiw r28, 8
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: pop r29
; GNU-NEXT: pop r28
; GNU-NEXT: pop r17
; GNU-NEXT: pop r16
; GNU-NEXT: ret
%result = call { half, half } @llvm.sincos.f16(half %a)
ret { half, half } %result
}
define half @test_sincos_f16_only_use_sin(half %a) #0 {
; NONGNU-LABEL: test_sincos_f16_only_use_sin:
; NONGNU: ; %bb.0:
; NONGNU-NEXT: mov r24, r22
; NONGNU-NEXT: mov r25, r23
; NONGNU-NEXT: rcall __extendhfsf2
; NONGNU-NEXT: rcall sin
; NONGNU-NEXT: rcall __truncsfhf2
; NONGNU-NEXT: mov r22, r24
; NONGNU-NEXT: mov r23, r25
; NONGNU-NEXT: ret
;
; GNU-LABEL: test_sincos_f16_only_use_sin:
; GNU: ; %bb.0:
; GNU-NEXT: push r28
; GNU-NEXT: push r29
; GNU-NEXT: in r28, 61
; GNU-NEXT: in r29, 62
; GNU-NEXT: sbiw r28, 8
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: mov r24, r22
; GNU-NEXT: mov r25, r23
; GNU-NEXT: rcall __extendhfsf2
; GNU-NEXT: mov r20, r28
; GNU-NEXT: mov r21, r29
; GNU-NEXT: subi r20, 251
; GNU-NEXT: sbci r21, 255
; GNU-NEXT: mov r18, r28
; GNU-NEXT: mov r19, r29
; GNU-NEXT: subi r18, 255
; GNU-NEXT: sbci r19, 255
; GNU-NEXT: rcall sincosf
; GNU-NEXT: ldd r22, Y+5
; GNU-NEXT: ldd r23, Y+6
; GNU-NEXT: ldd r24, Y+7
; GNU-NEXT: ldd r25, Y+8
; GNU-NEXT: rcall __truncsfhf2
; GNU-NEXT: mov r22, r24
; GNU-NEXT: mov r23, r25
; GNU-NEXT: adiw r28, 8
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: pop r29
; GNU-NEXT: pop r28
; GNU-NEXT: ret
%result = call { half, half } @llvm.sincos.f16(half %a)
%result.0 = extractvalue { half, half } %result, 0
ret half %result.0
}
define half @test_sincos_f16_only_use_cos(half %a) #0 {
; NONGNU-LABEL: test_sincos_f16_only_use_cos:
; NONGNU: ; %bb.0:
; NONGNU-NEXT: mov r24, r22
; NONGNU-NEXT: mov r25, r23
; NONGNU-NEXT: rcall __extendhfsf2
; NONGNU-NEXT: rcall cos
; NONGNU-NEXT: rcall __truncsfhf2
; NONGNU-NEXT: mov r22, r24
; NONGNU-NEXT: mov r23, r25
; NONGNU-NEXT: ret
;
; GNU-LABEL: test_sincos_f16_only_use_cos:
; GNU: ; %bb.0:
; GNU-NEXT: push r28
; GNU-NEXT: push r29
; GNU-NEXT: in r28, 61
; GNU-NEXT: in r29, 62
; GNU-NEXT: sbiw r28, 8
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: mov r24, r22
; GNU-NEXT: mov r25, r23
; GNU-NEXT: rcall __extendhfsf2
; GNU-NEXT: mov r20, r28
; GNU-NEXT: mov r21, r29
; GNU-NEXT: subi r20, 251
; GNU-NEXT: sbci r21, 255
; GNU-NEXT: mov r18, r28
; GNU-NEXT: mov r19, r29
; GNU-NEXT: subi r18, 255
; GNU-NEXT: sbci r19, 255
; GNU-NEXT: rcall sincosf
; GNU-NEXT: ldd r22, Y+1
; GNU-NEXT: ldd r23, Y+2
; GNU-NEXT: ldd r24, Y+3
; GNU-NEXT: ldd r25, Y+4
; GNU-NEXT: rcall __truncsfhf2
; GNU-NEXT: mov r22, r24
; GNU-NEXT: mov r23, r25
; GNU-NEXT: adiw r28, 8
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: pop r29
; GNU-NEXT: pop r28
; GNU-NEXT: ret
%result = call { half, half } @llvm.sincos.f16(half %a)
%result.1 = extractvalue { half, half } %result, 1
ret half %result.1
}
define { <2 x half>, <2 x half> } @test_sincos_v2f16(<2 x half> %a) #0 {
; NONGNU-LABEL: test_sincos_v2f16:
; NONGNU: ; %bb.0:
; NONGNU-NEXT: push r6
; NONGNU-NEXT: push r7
; NONGNU-NEXT: push r8
; NONGNU-NEXT: push r9
; NONGNU-NEXT: push r10
; NONGNU-NEXT: push r11
; NONGNU-NEXT: push r12
; NONGNU-NEXT: push r13
; NONGNU-NEXT: push r14
; NONGNU-NEXT: push r15
; NONGNU-NEXT: push r16
; NONGNU-NEXT: push r17
; NONGNU-NEXT: mov r10, r22
; NONGNU-NEXT: mov r11, r23
; NONGNU-NEXT: rcall __extendhfsf2
; NONGNU-NEXT: mov r16, r22
; NONGNU-NEXT: mov r17, r23
; NONGNU-NEXT: mov r14, r24
; NONGNU-NEXT: mov r15, r25
; NONGNU-NEXT: rcall sin
; NONGNU-NEXT: rcall __truncsfhf2
; NONGNU-NEXT: mov r12, r24
; NONGNU-NEXT: mov r13, r25
; NONGNU-NEXT: mov r24, r10
; NONGNU-NEXT: mov r25, r11
; NONGNU-NEXT: rcall __extendhfsf2
; NONGNU-NEXT: mov r10, r22
; NONGNU-NEXT: mov r11, r23
; NONGNU-NEXT: mov r8, r24
; NONGNU-NEXT: mov r9, r25
; NONGNU-NEXT: rcall cos
; NONGNU-NEXT: rcall __truncsfhf2
; NONGNU-NEXT: mov r6, r24
; NONGNU-NEXT: mov r7, r25
; NONGNU-NEXT: mov r22, r10
; NONGNU-NEXT: mov r23, r11
; NONGNU-NEXT: mov r24, r8
; NONGNU-NEXT: mov r25, r9
; NONGNU-NEXT: rcall sin
; NONGNU-NEXT: rcall __truncsfhf2
; NONGNU-NEXT: mov r10, r24
; NONGNU-NEXT: mov r11, r25
; NONGNU-NEXT: mov r22, r16
; NONGNU-NEXT: mov r23, r17
; NONGNU-NEXT: mov r24, r14
; NONGNU-NEXT: mov r25, r15
; NONGNU-NEXT: rcall cos
; NONGNU-NEXT: rcall __truncsfhf2
; NONGNU-NEXT: mov r18, r10
; NONGNU-NEXT: mov r19, r11
; NONGNU-NEXT: mov r20, r12
; NONGNU-NEXT: mov r21, r13
; NONGNU-NEXT: mov r22, r6
; NONGNU-NEXT: mov r23, r7
; NONGNU-NEXT: pop r17
; NONGNU-NEXT: pop r16
; NONGNU-NEXT: pop r15
; NONGNU-NEXT: pop r14
; NONGNU-NEXT: pop r13
; NONGNU-NEXT: pop r12
; NONGNU-NEXT: pop r11
; NONGNU-NEXT: pop r10
; NONGNU-NEXT: pop r9
; NONGNU-NEXT: pop r8
; NONGNU-NEXT: pop r7
; NONGNU-NEXT: pop r6
; NONGNU-NEXT: ret
;
; GNU-LABEL: test_sincos_v2f16:
; GNU: ; %bb.0:
; GNU-NEXT: push r12
; GNU-NEXT: push r13
; GNU-NEXT: push r14
; GNU-NEXT: push r15
; GNU-NEXT: push r16
; GNU-NEXT: push r17
; GNU-NEXT: push r28
; GNU-NEXT: push r29
; GNU-NEXT: in r28, 61
; GNU-NEXT: in r29, 62
; GNU-NEXT: sbiw r28, 16
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: mov r16, r24
; GNU-NEXT: mov r17, r25
; GNU-NEXT: mov r24, r22
; GNU-NEXT: mov r25, r23
; GNU-NEXT: rcall __extendhfsf2
; GNU-NEXT: mov r20, r28
; GNU-NEXT: mov r21, r29
; GNU-NEXT: subi r20, 243
; GNU-NEXT: sbci r21, 255
; GNU-NEXT: mov r18, r28
; GNU-NEXT: mov r19, r29
; GNU-NEXT: subi r18, 247
; GNU-NEXT: sbci r19, 255
; GNU-NEXT: rcall sincosf
; GNU-NEXT: mov r24, r16
; GNU-NEXT: mov r25, r17
; GNU-NEXT: rcall __extendhfsf2
; GNU-NEXT: mov r20, r28
; GNU-NEXT: mov r21, r29
; GNU-NEXT: subi r20, 251
; GNU-NEXT: sbci r21, 255
; GNU-NEXT: mov r18, r28
; GNU-NEXT: mov r19, r29
; GNU-NEXT: subi r18, 255
; GNU-NEXT: sbci r19, 255
; GNU-NEXT: rcall sincosf
; GNU-NEXT: ldd r22, Y+13
; GNU-NEXT: ldd r23, Y+14
; GNU-NEXT: ldd r24, Y+15
; GNU-NEXT: ldd r25, Y+16
; GNU-NEXT: rcall __truncsfhf2
; GNU-NEXT: mov r16, r24
; GNU-NEXT: mov r17, r25
; GNU-NEXT: ldd r22, Y+5
; GNU-NEXT: ldd r23, Y+6
; GNU-NEXT: ldd r24, Y+7
; GNU-NEXT: ldd r25, Y+8
; GNU-NEXT: rcall __truncsfhf2
; GNU-NEXT: mov r14, r24
; GNU-NEXT: mov r15, r25
; GNU-NEXT: ldd r22, Y+9
; GNU-NEXT: ldd r23, Y+10
; GNU-NEXT: ldd r24, Y+11
; GNU-NEXT: ldd r25, Y+12
; GNU-NEXT: rcall __truncsfhf2
; GNU-NEXT: mov r12, r24
; GNU-NEXT: mov r13, r25
; GNU-NEXT: ldd r22, Y+1
; GNU-NEXT: ldd r23, Y+2
; GNU-NEXT: ldd r24, Y+3
; GNU-NEXT: ldd r25, Y+4
; GNU-NEXT: rcall __truncsfhf2
; GNU-NEXT: mov r18, r16
; GNU-NEXT: mov r19, r17
; GNU-NEXT: mov r20, r14
; GNU-NEXT: mov r21, r15
; GNU-NEXT: mov r22, r12
; GNU-NEXT: mov r23, r13
; GNU-NEXT: adiw r28, 16
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: pop r29
; GNU-NEXT: pop r28
; GNU-NEXT: pop r17
; GNU-NEXT: pop r16
; GNU-NEXT: pop r15
; GNU-NEXT: pop r14
; GNU-NEXT: pop r13
; GNU-NEXT: pop r12
; GNU-NEXT: ret
%result = call { <2 x half>, <2 x half> } @llvm.sincos.v2f16(<2 x half> %a)
ret { <2 x half>, <2 x half> } %result
}
define { float, float } @test_sincos_f32(float %a) #0 {
; NONGNU-LABEL: test_sincos_f32:
; NONGNU: ; %bb.0:
; NONGNU-NEXT: push r10
; NONGNU-NEXT: push r11
; NONGNU-NEXT: push r12
; NONGNU-NEXT: push r13
; NONGNU-NEXT: push r14
; NONGNU-NEXT: push r15
; NONGNU-NEXT: push r16
; NONGNU-NEXT: push r17
; NONGNU-NEXT: mov r16, r24
; NONGNU-NEXT: mov r17, r25
; NONGNU-NEXT: mov r14, r22
; NONGNU-NEXT: mov r15, r23
; NONGNU-NEXT: rcall sin
; NONGNU-NEXT: mov r12, r22
; NONGNU-NEXT: mov r13, r23
; NONGNU-NEXT: mov r10, r24
; NONGNU-NEXT: mov r11, r25
; NONGNU-NEXT: mov r22, r14
; NONGNU-NEXT: mov r23, r15
; NONGNU-NEXT: mov r24, r16
; NONGNU-NEXT: mov r25, r17
; NONGNU-NEXT: rcall cos
; NONGNU-NEXT: mov r18, r12
; NONGNU-NEXT: mov r19, r13
; NONGNU-NEXT: mov r20, r10
; NONGNU-NEXT: mov r21, r11
; NONGNU-NEXT: pop r17
; NONGNU-NEXT: pop r16
; NONGNU-NEXT: pop r15
; NONGNU-NEXT: pop r14
; NONGNU-NEXT: pop r13
; NONGNU-NEXT: pop r12
; NONGNU-NEXT: pop r11
; NONGNU-NEXT: pop r10
; NONGNU-NEXT: ret
;
; GNU-LABEL: test_sincos_f32:
; GNU: ; %bb.0:
; GNU-NEXT: push r28
; GNU-NEXT: push r29
; GNU-NEXT: in r28, 61
; GNU-NEXT: in r29, 62
; GNU-NEXT: sbiw r28, 8
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: mov r20, r28
; GNU-NEXT: mov r21, r29
; GNU-NEXT: subi r20, 251
; GNU-NEXT: sbci r21, 255
; GNU-NEXT: mov r18, r28
; GNU-NEXT: mov r19, r29
; GNU-NEXT: subi r18, 255
; GNU-NEXT: sbci r19, 255
; GNU-NEXT: rcall sincosf
; GNU-NEXT: ldd r18, Y+5
; GNU-NEXT: ldd r19, Y+6
; GNU-NEXT: ldd r20, Y+7
; GNU-NEXT: ldd r21, Y+8
; GNU-NEXT: ldd r22, Y+1
; GNU-NEXT: ldd r23, Y+2
; GNU-NEXT: ldd r24, Y+3
; GNU-NEXT: ldd r25, Y+4
; GNU-NEXT: adiw r28, 8
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: pop r29
; GNU-NEXT: pop r28
; GNU-NEXT: ret
%result = call { float, float } @llvm.sincos.f32(float %a)
ret { float, float } %result
}
define { <2 x float>, <2 x float> } @test_sincos_v2f32(<2 x float> %a) #0 {
; NONGNU-LABEL: test_sincos_v2f32:
; NONGNU: ; %bb.0:
; NONGNU-NEXT: push r8
; NONGNU-NEXT: push r9
; NONGNU-NEXT: push r10
; NONGNU-NEXT: push r11
; NONGNU-NEXT: push r12
; NONGNU-NEXT: push r13
; NONGNU-NEXT: push r14
; NONGNU-NEXT: push r15
; NONGNU-NEXT: mov r14, r22
; NONGNU-NEXT: mov r15, r23
; NONGNU-NEXT: mov r12, r20
; NONGNU-NEXT: mov r13, r21
; NONGNU-NEXT: mov r10, r18
; NONGNU-NEXT: mov r11, r19
; NONGNU-NEXT: mov r8, r24
; NONGNU-NEXT: mov r9, r25
; NONGNU-NEXT: mov r22, r12
; NONGNU-NEXT: mov r23, r13
; NONGNU-NEXT: mov r24, r14
; NONGNU-NEXT: mov r25, r15
; NONGNU-NEXT: rcall cos
; NONGNU-NEXT: mov r30, r8
; NONGNU-NEXT: mov r31, r9
; NONGNU-NEXT: std Z+15, r25
; NONGNU-NEXT: std Z+14, r24
; NONGNU-NEXT: std Z+13, r23
; NONGNU-NEXT: std Z+12, r22
; NONGNU-NEXT: mov r22, r16
; NONGNU-NEXT: mov r23, r17
; NONGNU-NEXT: mov r24, r10
; NONGNU-NEXT: mov r25, r11
; NONGNU-NEXT: rcall cos
; NONGNU-NEXT: mov r30, r8
; NONGNU-NEXT: mov r31, r9
; NONGNU-NEXT: std Z+11, r25
; NONGNU-NEXT: std Z+10, r24
; NONGNU-NEXT: std Z+9, r23
; NONGNU-NEXT: std Z+8, r22
; NONGNU-NEXT: mov r22, r12
; NONGNU-NEXT: mov r23, r13
; NONGNU-NEXT: mov r24, r14
; NONGNU-NEXT: mov r25, r15
; NONGNU-NEXT: rcall sin
; NONGNU-NEXT: mov r30, r8
; NONGNU-NEXT: mov r31, r9
; NONGNU-NEXT: std Z+7, r25
; NONGNU-NEXT: std Z+6, r24
; NONGNU-NEXT: std Z+5, r23
; NONGNU-NEXT: std Z+4, r22
; NONGNU-NEXT: mov r22, r16
; NONGNU-NEXT: mov r23, r17
; NONGNU-NEXT: mov r24, r10
; NONGNU-NEXT: mov r25, r11
; NONGNU-NEXT: rcall sin
; NONGNU-NEXT: mov r30, r8
; NONGNU-NEXT: mov r31, r9
; NONGNU-NEXT: std Z+3, r25
; NONGNU-NEXT: std Z+2, r24
; NONGNU-NEXT: std Z+1, r23
; NONGNU-NEXT: st Z, r22
; NONGNU-NEXT: pop r15
; NONGNU-NEXT: pop r14
; NONGNU-NEXT: pop r13
; NONGNU-NEXT: pop r12
; NONGNU-NEXT: pop r11
; NONGNU-NEXT: pop r10
; NONGNU-NEXT: pop r9
; NONGNU-NEXT: pop r8
; NONGNU-NEXT: ret
;
; GNU-LABEL: test_sincos_v2f32:
; GNU: ; %bb.0:
; GNU-NEXT: push r12
; GNU-NEXT: push r13
; GNU-NEXT: push r14
; GNU-NEXT: push r15
; GNU-NEXT: push r28
; GNU-NEXT: push r29
; GNU-NEXT: in r28, 61
; GNU-NEXT: in r29, 62
; GNU-NEXT: sbiw r28, 16
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: mov r30, r22
; GNU-NEXT: mov r31, r23
; GNU-NEXT: mov r14, r18
; GNU-NEXT: mov r15, r19
; GNU-NEXT: mov r12, r24
; GNU-NEXT: mov r13, r25
; GNU-NEXT: mov r26, r28
; GNU-NEXT: mov r27, r29
; GNU-NEXT: adiw r26, 13
; GNU-NEXT: mov r18, r28
; GNU-NEXT: mov r19, r29
; GNU-NEXT: subi r18, 247
; GNU-NEXT: sbci r19, 255
; GNU-NEXT: mov r22, r20
; GNU-NEXT: mov r23, r21
; GNU-NEXT: mov r24, r30
; GNU-NEXT: mov r25, r31
; GNU-NEXT: mov r20, r26
; GNU-NEXT: mov r21, r27
; GNU-NEXT: rcall sincosf
; GNU-NEXT: mov r20, r28
; GNU-NEXT: mov r21, r29
; GNU-NEXT: subi r20, 251
; GNU-NEXT: sbci r21, 255
; GNU-NEXT: mov r18, r28
; GNU-NEXT: mov r19, r29
; GNU-NEXT: subi r18, 255
; GNU-NEXT: sbci r19, 255
; GNU-NEXT: mov r22, r16
; GNU-NEXT: mov r23, r17
; GNU-NEXT: mov r24, r14
; GNU-NEXT: mov r25, r15
; GNU-NEXT: rcall sincosf
; GNU-NEXT: ldd r24, Y+11
; GNU-NEXT: ldd r25, Y+12
; GNU-NEXT: mov r30, r12
; GNU-NEXT: mov r31, r13
; GNU-NEXT: std Z+15, r25
; GNU-NEXT: std Z+14, r24
; GNU-NEXT: ldd r24, Y+9
; GNU-NEXT: ldd r25, Y+10
; GNU-NEXT: std Z+13, r25
; GNU-NEXT: std Z+12, r24
; GNU-NEXT: ldd r24, Y+3
; GNU-NEXT: ldd r25, Y+4
; GNU-NEXT: std Z+11, r25
; GNU-NEXT: std Z+10, r24
; GNU-NEXT: ldd r24, Y+1
; GNU-NEXT: ldd r25, Y+2
; GNU-NEXT: std Z+9, r25
; GNU-NEXT: std Z+8, r24
; GNU-NEXT: ldd r24, Y+15
; GNU-NEXT: ldd r25, Y+16
; GNU-NEXT: std Z+7, r25
; GNU-NEXT: std Z+6, r24
; GNU-NEXT: ldd r24, Y+13
; GNU-NEXT: ldd r25, Y+14
; GNU-NEXT: std Z+5, r25
; GNU-NEXT: std Z+4, r24
; GNU-NEXT: ldd r24, Y+7
; GNU-NEXT: ldd r25, Y+8
; GNU-NEXT: std Z+3, r25
; GNU-NEXT: std Z+2, r24
; GNU-NEXT: ldd r24, Y+5
; GNU-NEXT: ldd r25, Y+6
; GNU-NEXT: std Z+1, r25
; GNU-NEXT: st Z, r24
; GNU-NEXT: adiw r28, 16
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: pop r29
; GNU-NEXT: pop r28
; GNU-NEXT: pop r15
; GNU-NEXT: pop r14
; GNU-NEXT: pop r13
; GNU-NEXT: pop r12
; GNU-NEXT: ret
%result = call { <2 x float>, <2 x float> } @llvm.sincos.v2f32(<2 x float> %a)
ret { <2 x float>, <2 x float> } %result
}
; FIXME: Broken
; define { double, double } @test_sincos_f64(double %a) #0 {
; %result = call { double, double } @llvm.sincos.f64(double %a)
; ret { double, double } %result
; }
; FIXME: Broken
; define { <2 x double>, <2 x double> } @test_sincos_v2f64(<2 x double> %a) #0 {
; %result = call { <2 x double>, <2 x double> } @llvm.sincos.v2f64(<2 x double> %a)
; ret { <2 x double>, <2 x double> } %result
; }
define { fp128, fp128 } @test_sincos_f128(fp128 %a) #0 {
; NONGNU-LABEL: test_sincos_f128:
; NONGNU: ; %bb.0:
; NONGNU-NEXT: push r2
; NONGNU-NEXT: push r3
; NONGNU-NEXT: push r4
; NONGNU-NEXT: push r5
; NONGNU-NEXT: push r6
; NONGNU-NEXT: push r7
; NONGNU-NEXT: push r28
; NONGNU-NEXT: push r29
; NONGNU-NEXT: in r28, 61
; NONGNU-NEXT: in r29, 62
; NONGNU-NEXT: sbiw r28, 34
; NONGNU-NEXT: in r0, 63
; NONGNU-NEXT: cli
; NONGNU-NEXT: out 62, r29
; NONGNU-NEXT: out 63, r0
; NONGNU-NEXT: out 61, r28
; NONGNU-NEXT: std Y+2, r23 ; 2-byte Folded Spill
; NONGNU-NEXT: std Y+1, r22 ; 2-byte Folded Spill
; NONGNU-NEXT: mov r2, r20
; NONGNU-NEXT: mov r3, r21
; NONGNU-NEXT: mov r4, r18
; NONGNU-NEXT: mov r5, r19
; NONGNU-NEXT: mov r6, r24
; NONGNU-NEXT: mov r7, r25
; NONGNU-NEXT: mov r24, r28
; NONGNU-NEXT: mov r25, r29
; NONGNU-NEXT: adiw r24, 3
; NONGNU-NEXT: rcall cosl
; NONGNU-NEXT: mov r24, r28
; NONGNU-NEXT: mov r25, r29
; NONGNU-NEXT: adiw r24, 19
; NONGNU-NEXT: mov r18, r4
; NONGNU-NEXT: mov r19, r5
; NONGNU-NEXT: mov r20, r2
; NONGNU-NEXT: mov r21, r3
; NONGNU-NEXT: ldd r22, Y+1 ; 2-byte Folded Reload
; NONGNU-NEXT: ldd r23, Y+2 ; 2-byte Folded Reload
; NONGNU-NEXT: rcall sinl
; NONGNU-NEXT: ldd r24, Y+17
; NONGNU-NEXT: ldd r25, Y+18
; NONGNU-NEXT: mov r30, r6
; NONGNU-NEXT: mov r31, r7
; NONGNU-NEXT: std Z+31, r25
; NONGNU-NEXT: std Z+30, r24
; NONGNU-NEXT: ldd r24, Y+15
; NONGNU-NEXT: ldd r25, Y+16
; NONGNU-NEXT: std Z+29, r25
; NONGNU-NEXT: std Z+28, r24
; NONGNU-NEXT: ldd r24, Y+13
; NONGNU-NEXT: ldd r25, Y+14
; NONGNU-NEXT: std Z+27, r25
; NONGNU-NEXT: std Z+26, r24
; NONGNU-NEXT: ldd r24, Y+11
; NONGNU-NEXT: ldd r25, Y+12
; NONGNU-NEXT: std Z+25, r25
; NONGNU-NEXT: std Z+24, r24
; NONGNU-NEXT: ldd r24, Y+9
; NONGNU-NEXT: ldd r25, Y+10
; NONGNU-NEXT: std Z+23, r25
; NONGNU-NEXT: std Z+22, r24
; NONGNU-NEXT: ldd r24, Y+7
; NONGNU-NEXT: ldd r25, Y+8
; NONGNU-NEXT: std Z+21, r25
; NONGNU-NEXT: std Z+20, r24
; NONGNU-NEXT: ldd r24, Y+5
; NONGNU-NEXT: ldd r25, Y+6
; NONGNU-NEXT: std Z+19, r25
; NONGNU-NEXT: std Z+18, r24
; NONGNU-NEXT: ldd r24, Y+3
; NONGNU-NEXT: ldd r25, Y+4
; NONGNU-NEXT: std Z+17, r25
; NONGNU-NEXT: std Z+16, r24
; NONGNU-NEXT: ldd r24, Y+33
; NONGNU-NEXT: ldd r25, Y+34
; NONGNU-NEXT: std Z+15, r25
; NONGNU-NEXT: std Z+14, r24
; NONGNU-NEXT: ldd r24, Y+31
; NONGNU-NEXT: ldd r25, Y+32
; NONGNU-NEXT: std Z+13, r25
; NONGNU-NEXT: std Z+12, r24
; NONGNU-NEXT: ldd r24, Y+29
; NONGNU-NEXT: ldd r25, Y+30
; NONGNU-NEXT: std Z+11, r25
; NONGNU-NEXT: std Z+10, r24
; NONGNU-NEXT: ldd r24, Y+27
; NONGNU-NEXT: ldd r25, Y+28
; NONGNU-NEXT: std Z+9, r25
; NONGNU-NEXT: std Z+8, r24
; NONGNU-NEXT: ldd r24, Y+25
; NONGNU-NEXT: ldd r25, Y+26
; NONGNU-NEXT: std Z+7, r25
; NONGNU-NEXT: std Z+6, r24
; NONGNU-NEXT: ldd r24, Y+23
; NONGNU-NEXT: ldd r25, Y+24
; NONGNU-NEXT: std Z+5, r25
; NONGNU-NEXT: std Z+4, r24
; NONGNU-NEXT: ldd r24, Y+21
; NONGNU-NEXT: ldd r25, Y+22
; NONGNU-NEXT: std Z+3, r25
; NONGNU-NEXT: std Z+2, r24
; NONGNU-NEXT: ldd r24, Y+19
; NONGNU-NEXT: ldd r25, Y+20
; NONGNU-NEXT: std Z+1, r25
; NONGNU-NEXT: st Z, r24
; NONGNU-NEXT: adiw r28, 34
; NONGNU-NEXT: in r0, 63
; NONGNU-NEXT: cli
; NONGNU-NEXT: out 62, r29
; NONGNU-NEXT: out 63, r0
; NONGNU-NEXT: out 61, r28
; NONGNU-NEXT: pop r29
; NONGNU-NEXT: pop r28
; NONGNU-NEXT: pop r7
; NONGNU-NEXT: pop r6
; NONGNU-NEXT: pop r5
; NONGNU-NEXT: pop r4
; NONGNU-NEXT: pop r3
; NONGNU-NEXT: pop r2
; NONGNU-NEXT: ret
;
; GNU-LABEL: test_sincos_f128:
; GNU: ; %bb.0:
; GNU-NEXT: push r6
; GNU-NEXT: push r7
; GNU-NEXT: push r28
; GNU-NEXT: push r29
; GNU-NEXT: in r28, 61
; GNU-NEXT: in r29, 62
; GNU-NEXT: sbiw r28, 52
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: mov r6, r24
; GNU-NEXT: mov r7, r25
; GNU-NEXT: mov r24, r28
; GNU-NEXT: mov r25, r29
; GNU-NEXT: adiw r24, 21
; GNU-NEXT: std Y+4, r25
; GNU-NEXT: std Y+3, r24
; GNU-NEXT: mov r24, r28
; GNU-NEXT: mov r25, r29
; GNU-NEXT: adiw r24, 37
; GNU-NEXT: std Y+2, r25
; GNU-NEXT: std Y+1, r24
; GNU-NEXT: mov r24, r28
; GNU-NEXT: mov r25, r29
; GNU-NEXT: adiw r24, 5
; GNU-NEXT: rcall sincosl
; GNU-NEXT: ldd r24, Y+35
; GNU-NEXT: ldd r25, Y+36
; GNU-NEXT: mov r30, r6
; GNU-NEXT: mov r31, r7
; GNU-NEXT: std Z+31, r25
; GNU-NEXT: std Z+30, r24
; GNU-NEXT: ldd r24, Y+33
; GNU-NEXT: ldd r25, Y+34
; GNU-NEXT: std Z+29, r25
; GNU-NEXT: std Z+28, r24
; GNU-NEXT: ldd r24, Y+31
; GNU-NEXT: ldd r25, Y+32
; GNU-NEXT: std Z+27, r25
; GNU-NEXT: std Z+26, r24
; GNU-NEXT: ldd r24, Y+29
; GNU-NEXT: ldd r25, Y+30
; GNU-NEXT: std Z+25, r25
; GNU-NEXT: std Z+24, r24
; GNU-NEXT: ldd r24, Y+27
; GNU-NEXT: ldd r25, Y+28
; GNU-NEXT: std Z+23, r25
; GNU-NEXT: std Z+22, r24
; GNU-NEXT: ldd r24, Y+25
; GNU-NEXT: ldd r25, Y+26
; GNU-NEXT: std Z+21, r25
; GNU-NEXT: std Z+20, r24
; GNU-NEXT: ldd r24, Y+23
; GNU-NEXT: ldd r25, Y+24
; GNU-NEXT: std Z+19, r25
; GNU-NEXT: std Z+18, r24
; GNU-NEXT: ldd r24, Y+21
; GNU-NEXT: ldd r25, Y+22
; GNU-NEXT: std Z+17, r25
; GNU-NEXT: std Z+16, r24
; GNU-NEXT: ldd r24, Y+51
; GNU-NEXT: ldd r25, Y+52
; GNU-NEXT: std Z+15, r25
; GNU-NEXT: std Z+14, r24
; GNU-NEXT: ldd r24, Y+49
; GNU-NEXT: ldd r25, Y+50
; GNU-NEXT: std Z+13, r25
; GNU-NEXT: std Z+12, r24
; GNU-NEXT: ldd r24, Y+47
; GNU-NEXT: ldd r25, Y+48
; GNU-NEXT: std Z+11, r25
; GNU-NEXT: std Z+10, r24
; GNU-NEXT: ldd r24, Y+45
; GNU-NEXT: ldd r25, Y+46
; GNU-NEXT: std Z+9, r25
; GNU-NEXT: std Z+8, r24
; GNU-NEXT: ldd r24, Y+43
; GNU-NEXT: ldd r25, Y+44
; GNU-NEXT: std Z+7, r25
; GNU-NEXT: std Z+6, r24
; GNU-NEXT: ldd r24, Y+41
; GNU-NEXT: ldd r25, Y+42
; GNU-NEXT: std Z+5, r25
; GNU-NEXT: std Z+4, r24
; GNU-NEXT: ldd r24, Y+39
; GNU-NEXT: ldd r25, Y+40
; GNU-NEXT: std Z+3, r25
; GNU-NEXT: std Z+2, r24
; GNU-NEXT: ldd r24, Y+37
; GNU-NEXT: ldd r25, Y+38
; GNU-NEXT: std Z+1, r25
; GNU-NEXT: st Z, r24
; GNU-NEXT: adiw r28, 52
; GNU-NEXT: in r0, 63
; GNU-NEXT: cli
; GNU-NEXT: out 62, r29
; GNU-NEXT: out 63, r0
; GNU-NEXT: out 61, r28
; GNU-NEXT: pop r29
; GNU-NEXT: pop r28
; GNU-NEXT: pop r7
; GNU-NEXT: pop r6
; GNU-NEXT: ret
%result = call { fp128, fp128 } @llvm.sincos.f128(fp128 %a)
ret { fp128, fp128 } %result
}
attributes #0 = { nounwind }
;; NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line:
; CHECK: {{.*}}