[llvm] 9f81acf - [Mips] Regenerate test checks (NFC)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Tue Oct 1 05:49:24 PDT 2024
Author: Nikita Popov
Date: 2024-10-01T14:49:14+02:00
New Revision: 9f81acf4ef39e05bb2833cb3d79914940f31ac6c
URL: https://github.com/llvm/llvm-project/commit/9f81acf4ef39e05bb2833cb3d79914940f31ac6c
DIFF: https://github.com/llvm/llvm-project/commit/9f81acf4ef39e05bb2833cb3d79914940f31ac6c.diff
LOG: [Mips] Regenerate test checks (NFC)
Some of these check lines are insufficient to determine correctness.
Generate full check lines instead.
To reduce noise, add nounwind and use static relocation model.
Added:
Modified:
llvm/test/CodeGen/Mips/fp16-promote.ll
Removed:
################################################################################
diff --git a/llvm/test/CodeGen/Mips/fp16-promote.ll b/llvm/test/CodeGen/Mips/fp16-promote.ll
index 6cbfab5f776698..348cf38e519743 100644
--- a/llvm/test/CodeGen/Mips/fp16-promote.ll
+++ b/llvm/test/CodeGen/Mips/fp16-promote.ll
@@ -1,11 +1,30 @@
-; RUN: llc -asm-verbose=false -mtriple=mipsel-linux-gnu -relocation-model=pic < %s | FileCheck %s -check-prefix=CHECK-LIBCALL
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
+; RUN: llc -mtriple=mipsel-linux-gnu < %s | FileCheck %s -check-prefix=CHECK-LIBCALL
+define void @test_fadd(ptr %p, ptr %q) nounwind {
; CHECK-LIBCALL-LABEL: test_fadd:
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL-DAG: add.s
-; CHECK-LIBCALL-DAG: %call16(__gnu_f2h_ieee)
-define void @test_fadd(ptr %p, ptr %q) #0 {
+; CHECK-LIBCALL: # %bb.0:
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, -40
+; CHECK-LIBCALL-NEXT: sdc1 $f20, 32($sp) # 8-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $ra, 28($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $17, 24($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $16, 20($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: move $17, $4
+; CHECK-LIBCALL-NEXT: lhu $4, 0($4)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: move $16, $5
+; CHECK-LIBCALL-NEXT: lhu $4, 0($16)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: mov.s $f20, $f0
+; CHECK-LIBCALL-NEXT: jal __gnu_f2h_ieee
+; CHECK-LIBCALL-NEXT: add.s $f12, $f20, $f0
+; CHECK-LIBCALL-NEXT: sh $2, 0($17)
+; CHECK-LIBCALL-NEXT: lw $16, 20($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $17, 24($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $ra, 28($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: ldc1 $f20, 32($sp) # 8-byte Folded Reload
+; CHECK-LIBCALL-NEXT: jr $ra
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, 40
%a = load half, ptr %p, align 2
%b = load half, ptr %q, align 2
%r = fadd half %a, %b
@@ -13,84 +32,229 @@ define void @test_fadd(ptr %p, ptr %q) #0 {
ret void
}
+define float @test_fpext_float(ptr %p) nounwind {
; CHECK-LIBCALL-LABEL: test_fpext_float:
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-define float @test_fpext_float(ptr %p) {
+; CHECK-LIBCALL: # %bb.0:
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, -24
+; CHECK-LIBCALL-NEXT: sw $ra, 20($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: lhu $4, 0($4)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: nop
+; CHECK-LIBCALL-NEXT: lw $ra, 20($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: jr $ra
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, 24
%a = load half, ptr %p, align 2
%r = fpext half %a to float
ret float %r
}
+define double @test_fpext_double(ptr %p) nounwind {
; CHECK-LIBCALL-LABEL: test_fpext_double:
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL: cvt.d.s
-define double @test_fpext_double(ptr %p) {
+; CHECK-LIBCALL: # %bb.0:
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, -24
+; CHECK-LIBCALL-NEXT: sw $ra, 20($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: lhu $4, 0($4)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: nop
+; CHECK-LIBCALL-NEXT: cvt.d.s $f0, $f0
+; CHECK-LIBCALL-NEXT: lw $ra, 20($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: jr $ra
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, 24
%a = load half, ptr %p, align 2
%r = fpext half %a to double
ret double %r
}
+define void @test_fptrunc_float(float %f, ptr %p) nounwind {
; CHECK-LIBCALL-LABEL: test_fptrunc_float:
-; CHECK-LIBCALL: %call16(__gnu_f2h_ieee)
-define void @test_fptrunc_float(float %f, ptr %p) #0 {
+; CHECK-LIBCALL: # %bb.0:
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, -24
+; CHECK-LIBCALL-NEXT: sw $ra, 20($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $16, 16($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: jal __gnu_f2h_ieee
+; CHECK-LIBCALL-NEXT: move $16, $5
+; CHECK-LIBCALL-NEXT: sh $2, 0($16)
+; CHECK-LIBCALL-NEXT: lw $16, 16($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $ra, 20($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: jr $ra
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, 24
%a = fptrunc float %f to half
store half %a, ptr %p
ret void
}
+define void @test_fptrunc_double(double %d, ptr %p) nounwind {
; CHECK-LIBCALL-LABEL: test_fptrunc_double:
-; CHECK-LIBCALL: %call16(__truncdfhf2)
-define void @test_fptrunc_double(double %d, ptr %p) #0 {
+; CHECK-LIBCALL: # %bb.0:
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, -24
+; CHECK-LIBCALL-NEXT: sw $ra, 20($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $16, 16($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: jal __truncdfhf2
+; CHECK-LIBCALL-NEXT: move $16, $6
+; CHECK-LIBCALL-NEXT: sh $2, 0($16)
+; CHECK-LIBCALL-NEXT: lw $16, 16($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $ra, 20($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: jr $ra
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, 24
%a = fptrunc double %d to half
store half %a, ptr %p
ret void
}
+define <4 x float> @test_vec_fpext_float(ptr %p) nounwind {
; CHECK-LIBCALL-LABEL: test_vec_fpext_float:
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-define <4 x float> @test_vec_fpext_float(ptr %p) #0 {
+; CHECK-LIBCALL: # %bb.0:
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, -32
+; CHECK-LIBCALL-NEXT: sw $ra, 28($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $17, 24($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $16, 20($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: move $17, $4
+; CHECK-LIBCALL-NEXT: lhu $4, 6($5)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: move $16, $5
+; CHECK-LIBCALL-NEXT: lhu $4, 4($16)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: swc1 $f0, 12($17)
+; CHECK-LIBCALL-NEXT: swc1 $f0, 8($17)
+; CHECK-LIBCALL-NEXT: lhu $4, 2($16)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: nop
+; CHECK-LIBCALL-NEXT: swc1 $f0, 4($17)
+; CHECK-LIBCALL-NEXT: lhu $4, 0($16)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: nop
+; CHECK-LIBCALL-NEXT: swc1 $f0, 0($17)
+; CHECK-LIBCALL-NEXT: lw $16, 20($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $17, 24($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $ra, 28($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: jr $ra
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, 32
%a = load <4 x half>, ptr %p, align 8
%b = fpext <4 x half> %a to <4 x float>
ret <4 x float> %b
}
-; This test is not robust against variations in instruction scheduling.
-; See the discussion in http://reviews.llvm.org/D8804
+define <4 x double> @test_vec_fpext_double(ptr %p) nounwind {
; CHECK-LIBCALL-LABEL: test_vec_fpext_double:
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL: cvt.d.s
-; CHECK-LIBCALL: cvt.d.s
-; CHECK-LIBCALL: cvt.d.s
-; CHECK-LIBCALL: %call16(__gnu_h2f_ieee)
-; CHECK-LIBCALL: cvt.d.s
-define <4 x double> @test_vec_fpext_double(ptr %p) #0 {
+; CHECK-LIBCALL: # %bb.0:
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, -40
+; CHECK-LIBCALL-NEXT: sdc1 $f20, 32($sp) # 8-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $ra, 28($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $17, 24($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $16, 20($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: move $17, $4
+; CHECK-LIBCALL-NEXT: lhu $4, 6($5)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: move $16, $5
+; CHECK-LIBCALL-NEXT: lhu $4, 4($16)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: mov.s $f20, $f0
+; CHECK-LIBCALL-NEXT: lhu $4, 2($16)
+; CHECK-LIBCALL-NEXT: cvt.d.s $f0, $f0
+; CHECK-LIBCALL-NEXT: cvt.d.s $f2, $f20
+; CHECK-LIBCALL-NEXT: sdc1 $f2, 24($17)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: sdc1 $f0, 16($17)
+; CHECK-LIBCALL-NEXT: cvt.d.s $f0, $f0
+; CHECK-LIBCALL-NEXT: sdc1 $f0, 8($17)
+; CHECK-LIBCALL-NEXT: lhu $4, 0($16)
+; CHECK-LIBCALL-NEXT: jal __gnu_h2f_ieee
+; CHECK-LIBCALL-NEXT: nop
+; CHECK-LIBCALL-NEXT: cvt.d.s $f0, $f0
+; CHECK-LIBCALL-NEXT: sdc1 $f0, 0($17)
+; CHECK-LIBCALL-NEXT: lw $16, 20($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $17, 24($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $ra, 28($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: ldc1 $f20, 32($sp) # 8-byte Folded Reload
+; CHECK-LIBCALL-NEXT: jr $ra
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, 40
%a = load <4 x half>, ptr %p, align 8
%b = fpext <4 x half> %a to <4 x double>
ret <4 x double> %b
}
+define void @test_vec_fptrunc_float(<4 x float> %a, ptr %p) nounwind {
; CHECK-LIBCALL-LABEL: test_vec_fptrunc_float:
-; CHECK-LIBCALL: %call16(__gnu_f2h_ieee)
-; CHECK-LIBCALL: %call16(__gnu_f2h_ieee)
-; CHECK-LIBCALL: %call16(__gnu_f2h_ieee)
-; CHECK-LIBCALL: %call16(__gnu_f2h_ieee)
-define void @test_vec_fptrunc_float(<4 x float> %a, ptr %p) #0 {
+; CHECK-LIBCALL: # %bb.0:
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, -40
+; CHECK-LIBCALL-NEXT: sw $ra, 36($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $19, 32($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $18, 28($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $17, 24($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $16, 20($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: move $16, $7
+; CHECK-LIBCALL-NEXT: move $17, $5
+; CHECK-LIBCALL-NEXT: move $18, $4
+; CHECK-LIBCALL-NEXT: jal __gnu_f2h_ieee
+; CHECK-LIBCALL-NEXT: mtc1 $6, $f12
+; CHECK-LIBCALL-NEXT: move $19, $2
+; CHECK-LIBCALL-NEXT: jal __gnu_f2h_ieee
+; CHECK-LIBCALL-NEXT: mtc1 $16, $f12
+; CHECK-LIBCALL-NEXT: mtc1 $17, $f12
+; CHECK-LIBCALL-NEXT: lw $16, 56($sp)
+; CHECK-LIBCALL-NEXT: sh $2, 6($16)
+; CHECK-LIBCALL-NEXT: jal __gnu_f2h_ieee
+; CHECK-LIBCALL-NEXT: sh $19, 4($16)
+; CHECK-LIBCALL-NEXT: sh $2, 2($16)
+; CHECK-LIBCALL-NEXT: jal __gnu_f2h_ieee
+; CHECK-LIBCALL-NEXT: mtc1 $18, $f12
+; CHECK-LIBCALL-NEXT: sh $2, 0($16)
+; CHECK-LIBCALL-NEXT: lw $16, 20($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $17, 24($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $18, 28($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $19, 32($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $ra, 36($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: jr $ra
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, 40
%b = fptrunc <4 x float> %a to <4 x half>
store <4 x half> %b, ptr %p, align 8
ret void
}
+define void @test_vec_fptrunc_double(<4 x double> %a, ptr %p) nounwind {
; CHECK-LIBCALL-LABEL: test_vec_fptrunc_double:
-; CHECK-LIBCALL: %call16(__truncdfhf2)
-; CHECK-LIBCALL: %call16(__truncdfhf2)
-; CHECK-LIBCALL: %call16(__truncdfhf2)
-; CHECK-LIBCALL: %call16(__truncdfhf2)
-define void @test_vec_fptrunc_double(<4 x double> %a, ptr %p) #0 {
+; CHECK-LIBCALL: # %bb.0:
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, -72
+; CHECK-LIBCALL-NEXT: sw $ra, 68($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $19, 64($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $18, 60($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $17, 56($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: sw $16, 52($sp) # 4-byte Folded Spill
+; CHECK-LIBCALL-NEXT: move $16, $5
+; CHECK-LIBCALL-NEXT: move $17, $4
+; CHECK-LIBCALL-NEXT: lw $1, 92($sp)
+; CHECK-LIBCALL-NEXT: sw $1, 36($sp)
+; CHECK-LIBCALL-NEXT: lw $1, 88($sp)
+; CHECK-LIBCALL-NEXT: sw $1, 32($sp)
+; CHECK-LIBCALL-NEXT: lw $1, 96($sp)
+; CHECK-LIBCALL-NEXT: lw $2, 100($sp)
+; CHECK-LIBCALL-NEXT: sw $2, 44($sp)
+; CHECK-LIBCALL-NEXT: sw $1, 40($sp)
+; CHECK-LIBCALL-NEXT: ldc1 $f12, 32($sp)
+; CHECK-LIBCALL-NEXT: sw $7, 28($sp)
+; CHECK-LIBCALL-NEXT: jal __truncdfhf2
+; CHECK-LIBCALL-NEXT: sw $6, 24($sp)
+; CHECK-LIBCALL-NEXT: move $18, $2
+; CHECK-LIBCALL-NEXT: jal __truncdfhf2
+; CHECK-LIBCALL-NEXT: ldc1 $f12, 40($sp)
+; CHECK-LIBCALL-NEXT: ldc1 $f12, 24($sp)
+; CHECK-LIBCALL-NEXT: lw $19, 104($sp)
+; CHECK-LIBCALL-NEXT: sh $2, 6($19)
+; CHECK-LIBCALL-NEXT: jal __truncdfhf2
+; CHECK-LIBCALL-NEXT: sh $18, 4($19)
+; CHECK-LIBCALL-NEXT: sh $2, 2($19)
+; CHECK-LIBCALL-NEXT: sw $16, 20($sp)
+; CHECK-LIBCALL-NEXT: sw $17, 16($sp)
+; CHECK-LIBCALL-NEXT: jal __truncdfhf2
+; CHECK-LIBCALL-NEXT: ldc1 $f12, 16($sp)
+; CHECK-LIBCALL-NEXT: sh $2, 0($19)
+; CHECK-LIBCALL-NEXT: lw $16, 52($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $17, 56($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $18, 60($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $19, 64($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: lw $ra, 68($sp) # 4-byte Folded Reload
+; CHECK-LIBCALL-NEXT: jr $ra
+; CHECK-LIBCALL-NEXT: addiu $sp, $sp, 72
%b = fptrunc <4 x double> %a to <4 x half>
store <4 x half> %b, ptr %p, align 8
ret void
More information about the llvm-commits
mailing list