mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-01 00:11:00 +00:00
Disable AArch64 fast-isel on big-endian call vector returns.
A big-endian vector return needs a byte-swap which we aren't doing right now. For now just bail on these cases to get correctness back. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@235133 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5ff5907996
commit
8dd904ce60
@ -3035,6 +3035,11 @@ bool AArch64FastISel::finishCall(CallLoweringInfo &CLI, MVT RetVT,
|
||||
|
||||
// Copy all of the result registers out of their specified physreg.
|
||||
MVT CopyVT = RVLocs[0].getValVT();
|
||||
|
||||
// TODO: Handle big-endian results
|
||||
if (CopyVT.isVector() && !Subtarget->isLittleEndian())
|
||||
return false;
|
||||
|
||||
unsigned ResultReg = createResultReg(TLI.getRegClassFor(CopyVT));
|
||||
BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DbgLoc,
|
||||
TII.get(TargetOpcode::COPY), ResultReg)
|
||||
|
@ -1,6 +1,10 @@
|
||||
; RUN: llc -mtriple aarch64_be < %s -aarch64-load-store-opt=false -o - | FileCheck %s
|
||||
; RUN: llc -mtriple aarch64_be < %s -aarch64-load-store-opt=false -fast-isel=true -O0 -o - | FileCheck %s
|
||||
|
||||
; Note, we split the functions in to multiple BBs below to isolate the call
|
||||
; instruction we want to test, from fast-isel failing to select instructions
|
||||
; after it.
|
||||
|
||||
; CHECK-LABEL: test_i64_f64:
|
||||
declare i64 @test_i64_f64_helper(double %p)
|
||||
define void @test_i64_f64(double* %p, i64* %q) {
|
||||
@ -8,6 +12,8 @@ define void @test_i64_f64(double* %p, i64* %q) {
|
||||
%1 = load double, double* %p
|
||||
%2 = fadd double %1, %1
|
||||
%3 = call i64 @test_i64_f64_helper(double %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add i64 %3, %3
|
||||
store i64 %4, i64* %q
|
||||
ret void
|
||||
@ -20,6 +26,8 @@ define void @test_i64_v1i64(<1 x i64>* %p, i64* %q) {
|
||||
%1 = load <1 x i64>, <1 x i64>* %p
|
||||
%2 = add <1 x i64> %1, %1
|
||||
%3 = call i64 @test_i64_v1i64_helper(<1 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add i64 %3, %3
|
||||
store i64 %4, i64* %q
|
||||
ret void
|
||||
@ -32,6 +40,8 @@ define void @test_i64_v2f32(<2 x float>* %p, i64* %q) {
|
||||
%1 = load <2 x float>, <2 x float>* %p
|
||||
%2 = fadd <2 x float> %1, %1
|
||||
%3 = call i64 @test_i64_v2f32_helper(<2 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add i64 %3, %3
|
||||
store i64 %4, i64* %q
|
||||
ret void
|
||||
@ -44,6 +54,8 @@ define void @test_i64_v2i32(<2 x i32>* %p, i64* %q) {
|
||||
%1 = load <2 x i32>, <2 x i32>* %p
|
||||
%2 = add <2 x i32> %1, %1
|
||||
%3 = call i64 @test_i64_v2i32_helper(<2 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add i64 %3, %3
|
||||
store i64 %4, i64* %q
|
||||
ret void
|
||||
@ -56,6 +68,8 @@ define void @test_i64_v4i16(<4 x i16>* %p, i64* %q) {
|
||||
%1 = load <4 x i16>, <4 x i16>* %p
|
||||
%2 = add <4 x i16> %1, %1
|
||||
%3 = call i64 @test_i64_v4i16_helper(<4 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add i64 %3, %3
|
||||
store i64 %4, i64* %q
|
||||
ret void
|
||||
@ -68,6 +82,8 @@ define void @test_i64_v8i8(<8 x i8>* %p, i64* %q) {
|
||||
%1 = load <8 x i8>, <8 x i8>* %p
|
||||
%2 = add <8 x i8> %1, %1
|
||||
%3 = call i64 @test_i64_v8i8_helper(<8 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add i64 %3, %3
|
||||
store i64 %4, i64* %q
|
||||
ret void
|
||||
@ -80,6 +96,8 @@ define void @test_f64_i64(i64* %p, double* %q) {
|
||||
%1 = load i64, i64* %p
|
||||
%2 = add i64 %1, %1
|
||||
%3 = call double @test_f64_i64_helper(i64 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd double %3, %3
|
||||
store double %4, double* %q
|
||||
ret void
|
||||
@ -92,6 +110,8 @@ define void @test_f64_v1i64(<1 x i64>* %p, double* %q) {
|
||||
%1 = load <1 x i64>, <1 x i64>* %p
|
||||
%2 = add <1 x i64> %1, %1
|
||||
%3 = call double @test_f64_v1i64_helper(<1 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd double %3, %3
|
||||
store double %4, double* %q
|
||||
ret void
|
||||
@ -104,6 +124,8 @@ define void @test_f64_v2f32(<2 x float>* %p, double* %q) {
|
||||
%1 = load <2 x float>, <2 x float>* %p
|
||||
%2 = fadd <2 x float> %1, %1
|
||||
%3 = call double @test_f64_v2f32_helper(<2 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd double %3, %3
|
||||
store double %4, double* %q
|
||||
ret void
|
||||
@ -116,6 +138,8 @@ define void @test_f64_v2i32(<2 x i32>* %p, double* %q) {
|
||||
%1 = load <2 x i32>, <2 x i32>* %p
|
||||
%2 = add <2 x i32> %1, %1
|
||||
%3 = call double @test_f64_v2i32_helper(<2 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd double %3, %3
|
||||
store double %4, double* %q
|
||||
ret void
|
||||
@ -128,6 +152,8 @@ define void @test_f64_v4i16(<4 x i16>* %p, double* %q) {
|
||||
%1 = load <4 x i16>, <4 x i16>* %p
|
||||
%2 = add <4 x i16> %1, %1
|
||||
%3 = call double @test_f64_v4i16_helper(<4 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd double %3, %3
|
||||
store double %4, double* %q
|
||||
ret void
|
||||
@ -140,6 +166,8 @@ define void @test_f64_v8i8(<8 x i8>* %p, double* %q) {
|
||||
%1 = load <8 x i8>, <8 x i8>* %p
|
||||
%2 = add <8 x i8> %1, %1
|
||||
%3 = call double @test_f64_v8i8_helper(<8 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd double %3, %3
|
||||
store double %4, double* %q
|
||||
ret void
|
||||
@ -152,6 +180,8 @@ define void @test_v1i64_i64(i64* %p, <1 x i64>* %q) {
|
||||
%1 = load i64, i64* %p
|
||||
%2 = add i64 %1, %1
|
||||
%3 = call <1 x i64> @test_v1i64_i64_helper(i64 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <1 x i64> %3, %3
|
||||
store <1 x i64> %4, <1 x i64>* %q
|
||||
ret void
|
||||
@ -164,6 +194,8 @@ define void @test_v1i64_f64(double* %p, <1 x i64>* %q) {
|
||||
%1 = load double, double* %p
|
||||
%2 = fadd double %1, %1
|
||||
%3 = call <1 x i64> @test_v1i64_f64_helper(double %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <1 x i64> %3, %3
|
||||
store <1 x i64> %4, <1 x i64>* %q
|
||||
ret void
|
||||
@ -176,6 +208,8 @@ define void @test_v1i64_v2f32(<2 x float>* %p, <1 x i64>* %q) {
|
||||
%1 = load <2 x float>, <2 x float>* %p
|
||||
%2 = fadd <2 x float> %1, %1
|
||||
%3 = call <1 x i64> @test_v1i64_v2f32_helper(<2 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <1 x i64> %3, %3
|
||||
store <1 x i64> %4, <1 x i64>* %q
|
||||
ret void
|
||||
@ -188,6 +222,8 @@ define void @test_v1i64_v2i32(<2 x i32>* %p, <1 x i64>* %q) {
|
||||
%1 = load <2 x i32>, <2 x i32>* %p
|
||||
%2 = add <2 x i32> %1, %1
|
||||
%3 = call <1 x i64> @test_v1i64_v2i32_helper(<2 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <1 x i64> %3, %3
|
||||
store <1 x i64> %4, <1 x i64>* %q
|
||||
ret void
|
||||
@ -200,6 +236,8 @@ define void @test_v1i64_v4i16(<4 x i16>* %p, <1 x i64>* %q) {
|
||||
%1 = load <4 x i16>, <4 x i16>* %p
|
||||
%2 = add <4 x i16> %1, %1
|
||||
%3 = call <1 x i64> @test_v1i64_v4i16_helper(<4 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <1 x i64> %3, %3
|
||||
store <1 x i64> %4, <1 x i64>* %q
|
||||
ret void
|
||||
@ -212,6 +250,8 @@ define void @test_v1i64_v8i8(<8 x i8>* %p, <1 x i64>* %q) {
|
||||
%1 = load <8 x i8>, <8 x i8>* %p
|
||||
%2 = add <8 x i8> %1, %1
|
||||
%3 = call <1 x i64> @test_v1i64_v8i8_helper(<8 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <1 x i64> %3, %3
|
||||
store <1 x i64> %4, <1 x i64>* %q
|
||||
ret void
|
||||
@ -224,6 +264,8 @@ define void @test_v2f32_i64(i64* %p, <2 x float>* %q) {
|
||||
%1 = load i64, i64* %p
|
||||
%2 = add i64 %1, %1
|
||||
%3 = call <2 x float> @test_v2f32_i64_helper(i64 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x float> %3, %3
|
||||
store <2 x float> %4, <2 x float>* %q
|
||||
ret void
|
||||
@ -236,6 +278,8 @@ define void @test_v2f32_f64(double* %p, <2 x float>* %q) {
|
||||
%1 = load double, double* %p
|
||||
%2 = fadd double %1, %1
|
||||
%3 = call <2 x float> @test_v2f32_f64_helper(double %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x float> %3, %3
|
||||
store <2 x float> %4, <2 x float>* %q
|
||||
ret void
|
||||
@ -248,6 +292,8 @@ define void @test_v2f32_v1i64(<1 x i64>* %p, <2 x float>* %q) {
|
||||
%1 = load <1 x i64>, <1 x i64>* %p
|
||||
%2 = add <1 x i64> %1, %1
|
||||
%3 = call <2 x float> @test_v2f32_v1i64_helper(<1 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x float> %3, %3
|
||||
store <2 x float> %4, <2 x float>* %q
|
||||
ret void
|
||||
@ -261,6 +307,8 @@ define void @test_v2f32_v2i32(<2 x i32>* %p, <2 x float>* %q) {
|
||||
%1 = load <2 x i32>, <2 x i32>* %p
|
||||
%2 = add <2 x i32> %1, %1
|
||||
%3 = call <2 x float> @test_v2f32_v2i32_helper(<2 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x float> %3, %3
|
||||
store <2 x float> %4, <2 x float>* %q
|
||||
ret void
|
||||
@ -274,6 +322,8 @@ define void @test_v2f32_v4i16(<4 x i16>* %p, <2 x float>* %q) {
|
||||
%1 = load <4 x i16>, <4 x i16>* %p
|
||||
%2 = add <4 x i16> %1, %1
|
||||
%3 = call <2 x float> @test_v2f32_v4i16_helper(<4 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x float> %3, %3
|
||||
store <2 x float> %4, <2 x float>* %q
|
||||
ret void
|
||||
@ -287,6 +337,8 @@ define void @test_v2f32_v8i8(<8 x i8>* %p, <2 x float>* %q) {
|
||||
%1 = load <8 x i8>, <8 x i8>* %p
|
||||
%2 = add <8 x i8> %1, %1
|
||||
%3 = call <2 x float> @test_v2f32_v8i8_helper(<8 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x float> %3, %3
|
||||
store <2 x float> %4, <2 x float>* %q
|
||||
ret void
|
||||
@ -299,6 +351,8 @@ define void @test_v2i32_i64(i64* %p, <2 x i32>* %q) {
|
||||
%1 = load i64, i64* %p
|
||||
%2 = add i64 %1, %1
|
||||
%3 = call <2 x i32> @test_v2i32_i64_helper(i64 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i32> %3, %3
|
||||
store <2 x i32> %4, <2 x i32>* %q
|
||||
ret void
|
||||
@ -311,6 +365,8 @@ define void @test_v2i32_f64(double* %p, <2 x i32>* %q) {
|
||||
%1 = load double, double* %p
|
||||
%2 = fadd double %1, %1
|
||||
%3 = call <2 x i32> @test_v2i32_f64_helper(double %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i32> %3, %3
|
||||
store <2 x i32> %4, <2 x i32>* %q
|
||||
ret void
|
||||
@ -323,6 +379,8 @@ define void @test_v2i32_v1i64(<1 x i64>* %p, <2 x i32>* %q) {
|
||||
%1 = load <1 x i64>, <1 x i64>* %p
|
||||
%2 = add <1 x i64> %1, %1
|
||||
%3 = call <2 x i32> @test_v2i32_v1i64_helper(<1 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i32> %3, %3
|
||||
store <2 x i32> %4, <2 x i32>* %q
|
||||
ret void
|
||||
@ -336,6 +394,8 @@ define void @test_v2i32_v2f32(<2 x float>* %p, <2 x i32>* %q) {
|
||||
%1 = load <2 x float>, <2 x float>* %p
|
||||
%2 = fadd <2 x float> %1, %1
|
||||
%3 = call <2 x i32> @test_v2i32_v2f32_helper(<2 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i32> %3, %3
|
||||
store <2 x i32> %4, <2 x i32>* %q
|
||||
ret void
|
||||
@ -349,6 +409,8 @@ define void @test_v2i32_v4i16(<4 x i16>* %p, <2 x i32>* %q) {
|
||||
%1 = load <4 x i16>, <4 x i16>* %p
|
||||
%2 = add <4 x i16> %1, %1
|
||||
%3 = call <2 x i32> @test_v2i32_v4i16_helper(<4 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i32> %3, %3
|
||||
store <2 x i32> %4, <2 x i32>* %q
|
||||
ret void
|
||||
@ -362,6 +424,8 @@ define void @test_v2i32_v8i8(<8 x i8>* %p, <2 x i32>* %q) {
|
||||
%1 = load <8 x i8>, <8 x i8>* %p
|
||||
%2 = add <8 x i8> %1, %1
|
||||
%3 = call <2 x i32> @test_v2i32_v8i8_helper(<8 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i32> %3, %3
|
||||
store <2 x i32> %4, <2 x i32>* %q
|
||||
ret void
|
||||
@ -374,6 +438,8 @@ define void @test_v4i16_i64(i64* %p, <4 x i16>* %q) {
|
||||
%1 = load i64, i64* %p
|
||||
%2 = add i64 %1, %1
|
||||
%3 = call <4 x i16> @test_v4i16_i64_helper(i64 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i16> %3, %3
|
||||
store <4 x i16> %4, <4 x i16>* %q
|
||||
ret void
|
||||
@ -386,6 +452,8 @@ define void @test_v4i16_f64(double* %p, <4 x i16>* %q) {
|
||||
%1 = load double, double* %p
|
||||
%2 = fadd double %1, %1
|
||||
%3 = call <4 x i16> @test_v4i16_f64_helper(double %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i16> %3, %3
|
||||
store <4 x i16> %4, <4 x i16>* %q
|
||||
ret void
|
||||
@ -398,6 +466,8 @@ define void @test_v4i16_v1i64(<1 x i64>* %p, <4 x i16>* %q) {
|
||||
%1 = load <1 x i64>, <1 x i64>* %p
|
||||
%2 = add <1 x i64> %1, %1
|
||||
%3 = call <4 x i16> @test_v4i16_v1i64_helper(<1 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i16> %3, %3
|
||||
store <4 x i16> %4, <4 x i16>* %q
|
||||
ret void
|
||||
@ -411,6 +481,8 @@ define void @test_v4i16_v2f32(<2 x float>* %p, <4 x i16>* %q) {
|
||||
%1 = load <2 x float>, <2 x float>* %p
|
||||
%2 = fadd <2 x float> %1, %1
|
||||
%3 = call <4 x i16> @test_v4i16_v2f32_helper(<2 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i16> %3, %3
|
||||
store <4 x i16> %4, <4 x i16>* %q
|
||||
ret void
|
||||
@ -424,6 +496,8 @@ define void @test_v4i16_v2i32(<2 x i32>* %p, <4 x i16>* %q) {
|
||||
%1 = load <2 x i32>, <2 x i32>* %p
|
||||
%2 = add <2 x i32> %1, %1
|
||||
%3 = call <4 x i16> @test_v4i16_v2i32_helper(<2 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i16> %3, %3
|
||||
store <4 x i16> %4, <4 x i16>* %q
|
||||
ret void
|
||||
@ -437,6 +511,8 @@ define void @test_v4i16_v8i8(<8 x i8>* %p, <4 x i16>* %q) {
|
||||
%1 = load <8 x i8>, <8 x i8>* %p
|
||||
%2 = add <8 x i8> %1, %1
|
||||
%3 = call <4 x i16> @test_v4i16_v8i8_helper(<8 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i16> %3, %3
|
||||
store <4 x i16> %4, <4 x i16>* %q
|
||||
ret void
|
||||
@ -449,6 +525,8 @@ define void @test_v8i8_i64(i64* %p, <8 x i8>* %q) {
|
||||
%1 = load i64, i64* %p
|
||||
%2 = add i64 %1, %1
|
||||
%3 = call <8 x i8> @test_v8i8_i64_helper(i64 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i8> %3, %3
|
||||
store <8 x i8> %4, <8 x i8>* %q
|
||||
ret void
|
||||
@ -461,6 +539,8 @@ define void @test_v8i8_f64(double* %p, <8 x i8>* %q) {
|
||||
%1 = load double, double* %p
|
||||
%2 = fadd double %1, %1
|
||||
%3 = call <8 x i8> @test_v8i8_f64_helper(double %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i8> %3, %3
|
||||
store <8 x i8> %4, <8 x i8>* %q
|
||||
ret void
|
||||
@ -473,6 +553,8 @@ define void @test_v8i8_v1i64(<1 x i64>* %p, <8 x i8>* %q) {
|
||||
%1 = load <1 x i64>, <1 x i64>* %p
|
||||
%2 = add <1 x i64> %1, %1
|
||||
%3 = call <8 x i8> @test_v8i8_v1i64_helper(<1 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i8> %3, %3
|
||||
store <8 x i8> %4, <8 x i8>* %q
|
||||
ret void
|
||||
@ -486,6 +568,8 @@ define void @test_v8i8_v2f32(<2 x float>* %p, <8 x i8>* %q) {
|
||||
%1 = load <2 x float>, <2 x float>* %p
|
||||
%2 = fadd <2 x float> %1, %1
|
||||
%3 = call <8 x i8> @test_v8i8_v2f32_helper(<2 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i8> %3, %3
|
||||
store <8 x i8> %4, <8 x i8>* %q
|
||||
ret void
|
||||
@ -499,6 +583,8 @@ define void @test_v8i8_v2i32(<2 x i32>* %p, <8 x i8>* %q) {
|
||||
%1 = load <2 x i32>, <2 x i32>* %p
|
||||
%2 = add <2 x i32> %1, %1
|
||||
%3 = call <8 x i8> @test_v8i8_v2i32_helper(<2 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i8> %3, %3
|
||||
store <8 x i8> %4, <8 x i8>* %q
|
||||
ret void
|
||||
@ -512,6 +598,8 @@ define void @test_v8i8_v4i16(<4 x i16>* %p, <8 x i8>* %q) {
|
||||
%1 = load <4 x i16>, <4 x i16>* %p
|
||||
%2 = add <4 x i16> %1, %1
|
||||
%3 = call <8 x i8> @test_v8i8_v4i16_helper(<4 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i8> %3, %3
|
||||
store <8 x i8> %4, <8 x i8>* %q
|
||||
ret void
|
||||
@ -524,6 +612,8 @@ define void @test_f128_v2f64(<2 x double>* %p, fp128* %q) {
|
||||
%1 = load <2 x double>, <2 x double>* %p
|
||||
%2 = fadd <2 x double> %1, %1
|
||||
%3 = call fp128 @test_f128_v2f64_helper(<2 x double> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd fp128 %3, %3
|
||||
store fp128 %4, fp128* %q
|
||||
ret void
|
||||
@ -536,6 +626,8 @@ define void @test_f128_v2i64(<2 x i64>* %p, fp128* %q) {
|
||||
%1 = load <2 x i64>, <2 x i64>* %p
|
||||
%2 = add <2 x i64> %1, %1
|
||||
%3 = call fp128 @test_f128_v2i64_helper(<2 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd fp128 %3, %3
|
||||
store fp128 %4, fp128* %q
|
||||
ret void
|
||||
@ -549,6 +641,8 @@ define void @test_f128_v4f32(<4 x float>* %p, fp128* %q) {
|
||||
%1 = load <4 x float>, <4 x float>* %p
|
||||
%2 = fadd <4 x float> %1, %1
|
||||
%3 = call fp128 @test_f128_v4f32_helper(<4 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd fp128 %3, %3
|
||||
store fp128 %4, fp128* %q
|
||||
ret void
|
||||
@ -562,6 +656,8 @@ define void @test_f128_v4i32(<4 x i32>* %p, fp128* %q) {
|
||||
%1 = load <4 x i32>, <4 x i32>* %p
|
||||
%2 = add <4 x i32> %1, %1
|
||||
%3 = call fp128 @test_f128_v4i32_helper(<4 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd fp128 %3, %3
|
||||
store fp128 %4, fp128* %q
|
||||
ret void
|
||||
@ -575,6 +671,8 @@ define void @test_f128_v8i16(<8 x i16>* %p, fp128* %q) {
|
||||
%1 = load <8 x i16>, <8 x i16>* %p
|
||||
%2 = add <8 x i16> %1, %1
|
||||
%3 = call fp128 @test_f128_v8i16_helper(<8 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd fp128 %3, %3
|
||||
store fp128 %4, fp128* %q
|
||||
ret void
|
||||
@ -588,6 +686,8 @@ define void @test_f128_v16i8(<16 x i8>* %p, fp128* %q) {
|
||||
%1 = load <16 x i8>, <16 x i8>* %p
|
||||
%2 = add <16 x i8> %1, %1
|
||||
%3 = call fp128 @test_f128_v16i8_helper(<16 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd fp128 %3, %3
|
||||
store fp128 %4, fp128* %q
|
||||
ret void
|
||||
@ -600,6 +700,8 @@ define void @test_v2f64_f128(fp128* %p, <2 x double>* %q) {
|
||||
%1 = load fp128, fp128* %p
|
||||
%2 = fadd fp128 %1, %1
|
||||
%3 = call <2 x double> @test_v2f64_f128_helper(fp128 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x double> %3, %3
|
||||
store <2 x double> %4, <2 x double>* %q
|
||||
ret void
|
||||
@ -613,6 +715,8 @@ define void @test_v2f64_v2i64(<2 x i64>* %p, <2 x double>* %q) {
|
||||
%1 = load <2 x i64>, <2 x i64>* %p
|
||||
%2 = add <2 x i64> %1, %1
|
||||
%3 = call <2 x double> @test_v2f64_v2i64_helper(<2 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x double> %3, %3
|
||||
store <2 x double> %4, <2 x double>* %q
|
||||
ret void
|
||||
@ -627,6 +731,8 @@ define void @test_v2f64_v4f32(<4 x float>* %p, <2 x double>* %q) {
|
||||
%1 = load <4 x float>, <4 x float>* %p
|
||||
%2 = fadd <4 x float> %1, %1
|
||||
%3 = call <2 x double> @test_v2f64_v4f32_helper(<4 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x double> %3, %3
|
||||
store <2 x double> %4, <2 x double>* %q
|
||||
ret void
|
||||
@ -641,6 +747,8 @@ define void @test_v2f64_v4i32(<4 x i32>* %p, <2 x double>* %q) {
|
||||
%1 = load <4 x i32>, <4 x i32>* %p
|
||||
%2 = add <4 x i32> %1, %1
|
||||
%3 = call <2 x double> @test_v2f64_v4i32_helper(<4 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x double> %3, %3
|
||||
store <2 x double> %4, <2 x double>* %q
|
||||
ret void
|
||||
@ -655,6 +763,8 @@ define void @test_v2f64_v8i16(<8 x i16>* %p, <2 x double>* %q) {
|
||||
%1 = load <8 x i16>, <8 x i16>* %p
|
||||
%2 = add <8 x i16> %1, %1
|
||||
%3 = call <2 x double> @test_v2f64_v8i16_helper(<8 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x double> %3, %3
|
||||
store <2 x double> %4, <2 x double>* %q
|
||||
ret void
|
||||
@ -669,6 +779,8 @@ define void @test_v2f64_v16i8(<16 x i8>* %p, <2 x double>* %q) {
|
||||
%1 = load <16 x i8>, <16 x i8>* %p
|
||||
%2 = add <16 x i8> %1, %1
|
||||
%3 = call <2 x double> @test_v2f64_v16i8_helper(<16 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <2 x double> %3, %3
|
||||
store <2 x double> %4, <2 x double>* %q
|
||||
ret void
|
||||
@ -681,6 +793,8 @@ define void @test_v2i64_f128(fp128* %p, <2 x i64>* %q) {
|
||||
%1 = load fp128, fp128* %p
|
||||
%2 = fadd fp128 %1, %1
|
||||
%3 = call <2 x i64> @test_v2i64_f128_helper(fp128 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i64> %3, %3
|
||||
store <2 x i64> %4, <2 x i64>* %q
|
||||
ret void
|
||||
@ -694,6 +808,8 @@ define void @test_v2i64_v2f64(<2 x double>* %p, <2 x i64>* %q) {
|
||||
%1 = load <2 x double>, <2 x double>* %p
|
||||
%2 = fadd <2 x double> %1, %1
|
||||
%3 = call <2 x i64> @test_v2i64_v2f64_helper(<2 x double> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i64> %3, %3
|
||||
store <2 x i64> %4, <2 x i64>* %q
|
||||
ret void
|
||||
@ -708,6 +824,8 @@ define void @test_v2i64_v4f32(<4 x float>* %p, <2 x i64>* %q) {
|
||||
%1 = load <4 x float>, <4 x float>* %p
|
||||
%2 = fadd <4 x float> %1, %1
|
||||
%3 = call <2 x i64> @test_v2i64_v4f32_helper(<4 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i64> %3, %3
|
||||
store <2 x i64> %4, <2 x i64>* %q
|
||||
ret void
|
||||
@ -722,6 +840,8 @@ define void @test_v2i64_v4i32(<4 x i32>* %p, <2 x i64>* %q) {
|
||||
%1 = load <4 x i32>, <4 x i32>* %p
|
||||
%2 = add <4 x i32> %1, %1
|
||||
%3 = call <2 x i64> @test_v2i64_v4i32_helper(<4 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i64> %3, %3
|
||||
store <2 x i64> %4, <2 x i64>* %q
|
||||
ret void
|
||||
@ -736,6 +856,8 @@ define void @test_v2i64_v8i16(<8 x i16>* %p, <2 x i64>* %q) {
|
||||
%1 = load <8 x i16>, <8 x i16>* %p
|
||||
%2 = add <8 x i16> %1, %1
|
||||
%3 = call <2 x i64> @test_v2i64_v8i16_helper(<8 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i64> %3, %3
|
||||
store <2 x i64> %4, <2 x i64>* %q
|
||||
ret void
|
||||
@ -750,6 +872,8 @@ define void @test_v2i64_v16i8(<16 x i8>* %p, <2 x i64>* %q) {
|
||||
%1 = load <16 x i8>, <16 x i8>* %p
|
||||
%2 = add <16 x i8> %1, %1
|
||||
%3 = call <2 x i64> @test_v2i64_v16i8_helper(<16 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <2 x i64> %3, %3
|
||||
store <2 x i64> %4, <2 x i64>* %q
|
||||
ret void
|
||||
@ -763,6 +887,8 @@ define void @test_v4f32_f128(fp128* %p, <4 x float>* %q) {
|
||||
%1 = load fp128, fp128* %p
|
||||
%2 = fadd fp128 %1, %1
|
||||
%3 = call <4 x float> @test_v4f32_f128_helper(fp128 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <4 x float> %3, %3
|
||||
store <4 x float> %4, <4 x float>* %q
|
||||
ret void
|
||||
@ -777,6 +903,8 @@ define void @test_v4f32_v2f64(<2 x double>* %p, <4 x float>* %q) {
|
||||
%1 = load <2 x double>, <2 x double>* %p
|
||||
%2 = fadd <2 x double> %1, %1
|
||||
%3 = call <4 x float> @test_v4f32_v2f64_helper(<2 x double> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <4 x float> %3, %3
|
||||
store <4 x float> %4, <4 x float>* %q
|
||||
ret void
|
||||
@ -791,6 +919,8 @@ define void @test_v4f32_v2i64(<2 x i64>* %p, <4 x float>* %q) {
|
||||
%1 = load <2 x i64>, <2 x i64>* %p
|
||||
%2 = add <2 x i64> %1, %1
|
||||
%3 = call <4 x float> @test_v4f32_v2i64_helper(<2 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <4 x float> %3, %3
|
||||
store <4 x float> %4, <4 x float>* %q
|
||||
ret void
|
||||
@ -806,6 +936,8 @@ define void @test_v4f32_v4i32(<4 x i32>* %p, <4 x float>* %q) {
|
||||
%1 = load <4 x i32>, <4 x i32>* %p
|
||||
%2 = add <4 x i32> %1, %1
|
||||
%3 = call <4 x float> @test_v4f32_v4i32_helper(<4 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <4 x float> %3, %3
|
||||
store <4 x float> %4, <4 x float>* %q
|
||||
ret void
|
||||
@ -821,6 +953,8 @@ define void @test_v4f32_v8i16(<8 x i16>* %p, <4 x float>* %q) {
|
||||
%1 = load <8 x i16>, <8 x i16>* %p
|
||||
%2 = add <8 x i16> %1, %1
|
||||
%3 = call <4 x float> @test_v4f32_v8i16_helper(<8 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <4 x float> %3, %3
|
||||
store <4 x float> %4, <4 x float>* %q
|
||||
ret void
|
||||
@ -836,6 +970,8 @@ define void @test_v4f32_v16i8(<16 x i8>* %p, <4 x float>* %q) {
|
||||
%1 = load <16 x i8>, <16 x i8>* %p
|
||||
%2 = add <16 x i8> %1, %1
|
||||
%3 = call <4 x float> @test_v4f32_v16i8_helper(<16 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = fadd <4 x float> %3, %3
|
||||
store <4 x float> %4, <4 x float>* %q
|
||||
ret void
|
||||
@ -849,6 +985,8 @@ define void @test_v4i32_f128(fp128* %p, <4 x i32>* %q) {
|
||||
%1 = load fp128, fp128* %p
|
||||
%2 = fadd fp128 %1, %1
|
||||
%3 = call <4 x i32> @test_v4i32_f128_helper(fp128 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i32> %3, %3
|
||||
store <4 x i32> %4, <4 x i32>* %q
|
||||
ret void
|
||||
@ -863,6 +1001,8 @@ define void @test_v4i32_v2f64(<2 x double>* %p, <4 x i32>* %q) {
|
||||
%1 = load <2 x double>, <2 x double>* %p
|
||||
%2 = fadd <2 x double> %1, %1
|
||||
%3 = call <4 x i32> @test_v4i32_v2f64_helper(<2 x double> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i32> %3, %3
|
||||
store <4 x i32> %4, <4 x i32>* %q
|
||||
ret void
|
||||
@ -877,6 +1017,8 @@ define void @test_v4i32_v2i64(<2 x i64>* %p, <4 x i32>* %q) {
|
||||
%1 = load <2 x i64>, <2 x i64>* %p
|
||||
%2 = add <2 x i64> %1, %1
|
||||
%3 = call <4 x i32> @test_v4i32_v2i64_helper(<2 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i32> %3, %3
|
||||
store <4 x i32> %4, <4 x i32>* %q
|
||||
ret void
|
||||
@ -892,6 +1034,8 @@ define void @test_v4i32_v4f32(<4 x float>* %p, <4 x i32>* %q) {
|
||||
%1 = load <4 x float>, <4 x float>* %p
|
||||
%2 = fadd <4 x float> %1, %1
|
||||
%3 = call <4 x i32> @test_v4i32_v4f32_helper(<4 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i32> %3, %3
|
||||
store <4 x i32> %4, <4 x i32>* %q
|
||||
ret void
|
||||
@ -907,6 +1051,8 @@ define void @test_v4i32_v8i16(<8 x i16>* %p, <4 x i32>* %q) {
|
||||
%1 = load <8 x i16>, <8 x i16>* %p
|
||||
%2 = add <8 x i16> %1, %1
|
||||
%3 = call <4 x i32> @test_v4i32_v8i16_helper(<8 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i32> %3, %3
|
||||
store <4 x i32> %4, <4 x i32>* %q
|
||||
ret void
|
||||
@ -922,6 +1068,8 @@ define void @test_v4i32_v16i8(<16 x i8>* %p, <4 x i32>* %q) {
|
||||
%1 = load <16 x i8>, <16 x i8>* %p
|
||||
%2 = add <16 x i8> %1, %1
|
||||
%3 = call <4 x i32> @test_v4i32_v16i8_helper(<16 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <4 x i32> %3, %3
|
||||
store <4 x i32> %4, <4 x i32>* %q
|
||||
ret void
|
||||
@ -935,6 +1083,8 @@ define void @test_v8i16_f128(fp128* %p, <8 x i16>* %q) {
|
||||
%1 = load fp128, fp128* %p
|
||||
%2 = fadd fp128 %1, %1
|
||||
%3 = call <8 x i16> @test_v8i16_f128_helper(fp128 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i16> %3, %3
|
||||
store <8 x i16> %4, <8 x i16>* %q
|
||||
ret void
|
||||
@ -949,6 +1099,8 @@ define void @test_v8i16_v2f64(<2 x double>* %p, <8 x i16>* %q) {
|
||||
%1 = load <2 x double>, <2 x double>* %p
|
||||
%2 = fadd <2 x double> %1, %1
|
||||
%3 = call <8 x i16> @test_v8i16_v2f64_helper(<2 x double> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i16> %3, %3
|
||||
store <8 x i16> %4, <8 x i16>* %q
|
||||
ret void
|
||||
@ -963,6 +1115,8 @@ define void @test_v8i16_v2i64(<2 x i64>* %p, <8 x i16>* %q) {
|
||||
%1 = load <2 x i64>, <2 x i64>* %p
|
||||
%2 = add <2 x i64> %1, %1
|
||||
%3 = call <8 x i16> @test_v8i16_v2i64_helper(<2 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i16> %3, %3
|
||||
store <8 x i16> %4, <8 x i16>* %q
|
||||
ret void
|
||||
@ -978,6 +1132,8 @@ define void @test_v8i16_v4f32(<4 x float>* %p, <8 x i16>* %q) {
|
||||
%1 = load <4 x float>, <4 x float>* %p
|
||||
%2 = fadd <4 x float> %1, %1
|
||||
%3 = call <8 x i16> @test_v8i16_v4f32_helper(<4 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i16> %3, %3
|
||||
store <8 x i16> %4, <8 x i16>* %q
|
||||
ret void
|
||||
@ -993,6 +1149,8 @@ define void @test_v8i16_v4i32(<4 x i32>* %p, <8 x i16>* %q) {
|
||||
%1 = load <4 x i32>, <4 x i32>* %p
|
||||
%2 = add <4 x i32> %1, %1
|
||||
%3 = call <8 x i16> @test_v8i16_v4i32_helper(<4 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i16> %3, %3
|
||||
store <8 x i16> %4, <8 x i16>* %q
|
||||
ret void
|
||||
@ -1008,6 +1166,8 @@ define void @test_v8i16_v16i8(<16 x i8>* %p, <8 x i16>* %q) {
|
||||
%1 = load <16 x i8>, <16 x i8>* %p
|
||||
%2 = add <16 x i8> %1, %1
|
||||
%3 = call <8 x i16> @test_v8i16_v16i8_helper(<16 x i8> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <8 x i16> %3, %3
|
||||
store <8 x i16> %4, <8 x i16>* %q
|
||||
ret void
|
||||
@ -1021,6 +1181,8 @@ define void @test_v16i8_f128(fp128* %p, <16 x i8>* %q) {
|
||||
%1 = load fp128, fp128* %p
|
||||
%2 = fadd fp128 %1, %1
|
||||
%3 = call <16 x i8> @test_v16i8_f128_helper(fp128 %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <16 x i8> %3, %3
|
||||
store <16 x i8> %4, <16 x i8>* %q
|
||||
ret void
|
||||
@ -1035,6 +1197,8 @@ define void @test_v16i8_v2f64(<2 x double>* %p, <16 x i8>* %q) {
|
||||
%1 = load <2 x double>, <2 x double>* %p
|
||||
%2 = fadd <2 x double> %1, %1
|
||||
%3 = call <16 x i8> @test_v16i8_v2f64_helper(<2 x double> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <16 x i8> %3, %3
|
||||
store <16 x i8> %4, <16 x i8>* %q
|
||||
ret void
|
||||
@ -1049,6 +1213,8 @@ define void @test_v16i8_v2i64(<2 x i64>* %p, <16 x i8>* %q) {
|
||||
%1 = load <2 x i64>, <2 x i64>* %p
|
||||
%2 = add <2 x i64> %1, %1
|
||||
%3 = call <16 x i8> @test_v16i8_v2i64_helper(<2 x i64> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <16 x i8> %3, %3
|
||||
store <16 x i8> %4, <16 x i8>* %q
|
||||
ret void
|
||||
@ -1064,6 +1230,8 @@ define void @test_v16i8_v4f32(<4 x float>* %p, <16 x i8>* %q) {
|
||||
%1 = load <4 x float>, <4 x float>* %p
|
||||
%2 = fadd <4 x float> %1, %1
|
||||
%3 = call <16 x i8> @test_v16i8_v4f32_helper(<4 x float> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <16 x i8> %3, %3
|
||||
store <16 x i8> %4, <16 x i8>* %q
|
||||
ret void
|
||||
@ -1079,6 +1247,8 @@ define void @test_v16i8_v4i32(<4 x i32>* %p, <16 x i8>* %q) {
|
||||
%1 = load <4 x i32>, <4 x i32>* %p
|
||||
%2 = add <4 x i32> %1, %1
|
||||
%3 = call <16 x i8> @test_v16i8_v4i32_helper(<4 x i32> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <16 x i8> %3, %3
|
||||
store <16 x i8> %4, <16 x i8>* %q
|
||||
ret void
|
||||
@ -1094,6 +1264,8 @@ define void @test_v16i8_v8i16(<8 x i16>* %p, <16 x i8>* %q) {
|
||||
%1 = load <8 x i16>, <8 x i16>* %p
|
||||
%2 = add <8 x i16> %1, %1
|
||||
%3 = call <16 x i8> @test_v16i8_v8i16_helper(<8 x i16> %2)
|
||||
br label %return_bb
|
||||
return_bb:
|
||||
%4 = add <16 x i8> %3, %3
|
||||
store <16 x i8> %4, <16 x i8>* %q
|
||||
ret void
|
||||
|
Loading…
Reference in New Issue
Block a user