2013-11-26 22:17:37 +00:00
|
|
|
; RUN: llc -mtriple=aarch64-none-linux-gnu -mattr=+neon < %s | FileCheck %s
|
|
|
|
|
|
|
|
;; Scalar Floating-point Convert
|
|
|
|
|
|
|
|
define float @test_vcvtxn(double %a) {
|
|
|
|
; CHECK: test_vcvtxn
|
|
|
|
; CHECK: fcvtxn {{s[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtf = call float @llvm.aarch64.neon.fcvtxn(double %a)
|
|
|
|
ret float %vcvtf
|
2013-11-26 22:17:37 +00:00
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare float @llvm.aarch64.neon.fcvtxn(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtass(float %a) {
|
|
|
|
; CHECK: test_vcvtass
|
|
|
|
; CHECK: fcvtas {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtas1.i = call <1 x i32> @llvm.aarch64.neon.fcvtas.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtas1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtas.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_test_vcvtasd(double %a) {
|
|
|
|
; CHECK: test_test_vcvtasd
|
|
|
|
; CHECK: fcvtas {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtas1.i = call <1 x i64> @llvm.aarch64.neon.fcvtas.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvtas1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtas.v1i64.f64(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtaus(float %a) {
|
|
|
|
; CHECK: test_vcvtaus
|
|
|
|
; CHECK: fcvtau {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtau1.i = call <1 x i32> @llvm.aarch64.neon.fcvtau.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtau1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtau.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_vcvtaud(double %a) {
|
|
|
|
; CHECK: test_vcvtaud
|
|
|
|
; CHECK: fcvtau {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtau1.i = call <1 x i64> @llvm.aarch64.neon.fcvtau.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvtau1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtau.v1i64.f64(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtmss(float %a) {
|
|
|
|
; CHECK: test_vcvtmss
|
|
|
|
; CHECK: fcvtms {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtms1.i = call <1 x i32> @llvm.aarch64.neon.fcvtms.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtms1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtms.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_vcvtmd_s64_f64(double %a) {
|
|
|
|
; CHECK: test_vcvtmd_s64_f64
|
|
|
|
; CHECK: fcvtms {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtms1.i = call <1 x i64> @llvm.aarch64.neon.fcvtms.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvtms1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtms.v1i64.f64(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtmus(float %a) {
|
|
|
|
; CHECK: test_vcvtmus
|
|
|
|
; CHECK: fcvtmu {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtmu1.i = call <1 x i32> @llvm.aarch64.neon.fcvtmu.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtmu1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtmu.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_vcvtmud(double %a) {
|
|
|
|
; CHECK: test_vcvtmud
|
|
|
|
; CHECK: fcvtmu {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtmu1.i = call <1 x i64> @llvm.aarch64.neon.fcvtmu.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvtmu1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtmu.v1i64.f64(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtnss(float %a) {
|
|
|
|
; CHECK: test_vcvtnss
|
|
|
|
; CHECK: fcvtns {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtns1.i = call <1 x i32> @llvm.aarch64.neon.fcvtns.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtns1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtns.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_vcvtnd_s64_f64(double %a) {
|
|
|
|
; CHECK: test_vcvtnd_s64_f64
|
|
|
|
; CHECK: fcvtns {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtns1.i = call <1 x i64> @llvm.aarch64.neon.fcvtns.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvtns1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtns.v1i64.f64(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtnus(float %a) {
|
|
|
|
; CHECK: test_vcvtnus
|
|
|
|
; CHECK: fcvtnu {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtnu1.i = call <1 x i32> @llvm.aarch64.neon.fcvtnu.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtnu1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtnu.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_vcvtnud(double %a) {
|
|
|
|
; CHECK: test_vcvtnud
|
|
|
|
; CHECK: fcvtnu {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtnu1.i = call <1 x i64> @llvm.aarch64.neon.fcvtnu.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvtnu1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtnu.v1i64.f64(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtpss(float %a) {
|
|
|
|
; CHECK: test_vcvtpss
|
|
|
|
; CHECK: fcvtps {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtps1.i = call <1 x i32> @llvm.aarch64.neon.fcvtps.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtps1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtps.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_vcvtpd_s64_f64(double %a) {
|
|
|
|
; CHECK: test_vcvtpd_s64_f64
|
|
|
|
; CHECK: fcvtps {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtps1.i = call <1 x i64> @llvm.aarch64.neon.fcvtps.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvtps1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtps.v1i64.f64(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtpus(float %a) {
|
|
|
|
; CHECK: test_vcvtpus
|
|
|
|
; CHECK: fcvtpu {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtpu1.i = call <1 x i32> @llvm.aarch64.neon.fcvtpu.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtpu1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtpu.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_vcvtpud(double %a) {
|
|
|
|
; CHECK: test_vcvtpud
|
|
|
|
; CHECK: fcvtpu {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtpu1.i = call <1 x i64> @llvm.aarch64.neon.fcvtpu.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvtpu1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtpu.v1i64.f64(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtss(float %a) {
|
|
|
|
; CHECK: test_vcvtss
|
|
|
|
; CHECK: fcvtzs {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtzs1.i = call <1 x i32> @llvm.aarch64.neon.fcvtzs.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtzs1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtzs.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_vcvtd_s64_f64(double %a) {
|
|
|
|
; CHECK: test_vcvtd_s64_f64
|
|
|
|
; CHECK: fcvtzs {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvzs1.i = call <1 x i64> @llvm.aarch64.neon.fcvtzs.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvzs1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtzs.v1i64.f64(double)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i32 @test_vcvtus(float %a) {
|
|
|
|
; CHECK: test_vcvtus
|
|
|
|
; CHECK: fcvtzu {{s[0-9]}}, {{s[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtzu1.i = call <1 x i32> @llvm.aarch64.neon.fcvtzu.v1i32.f32(float %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i32> %vcvtzu1.i, i32 0
|
|
|
|
ret i32 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i32> @llvm.aarch64.neon.fcvtzu.v1i32.f32(float)
|
2013-11-26 22:17:37 +00:00
|
|
|
|
|
|
|
define i64 @test_vcvtud(double %a) {
|
|
|
|
; CHECK: test_vcvtud
|
|
|
|
; CHECK: fcvtzu {{d[0-9]}}, {{d[0-9]}}
|
|
|
|
entry:
|
2013-12-10 16:11:39 +00:00
|
|
|
%vcvtzu1.i = call <1 x i64> @llvm.aarch64.neon.fcvtzu.v1i64.f64(double %a)
|
2013-11-26 22:17:37 +00:00
|
|
|
%0 = extractelement <1 x i64> %vcvtzu1.i, i32 0
|
|
|
|
ret i64 %0
|
|
|
|
}
|
|
|
|
|
2013-12-10 16:11:39 +00:00
|
|
|
declare <1 x i64> @llvm.aarch64.neon.fcvtzu.v1i64.f64(double)
|