[llvm] [AMDGPU][True16][CodeGen] enable true16 for more codegen test patch 1 (PR #131206)
Mikael Holmén via llvm-commits
llvm-commits at lists.llvm.org
Mon Mar 17 01:29:01 PDT 2025
mikaelholmen wrote:
Hi @broxigarchen
With this patch
```CodeGen/AMDGPU/fneg-combines.f16.ll```
fails if you've compiled llc with EXPENSIVE_CHECKS.
Then it fails like
```
# After Instruction Selection
# Machine code for function fneg_fadd_0_f16: IsSSA, TracksLiveness
Function Live Ins: $sgpr0 in %0, $sgpr1 in %1
bb.0..entry:
liveins: $sgpr0, $sgpr1
%1:sgpr_32 = COPY $sgpr1
%0:sgpr_32 = COPY $sgpr0
%2:vgpr_16 = nofpexcept V_RCP_F16_t16_e64 0, %1:sgpr_32, 0, 0, 0, implicit $mode, implicit $exec
%3:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
%5:vgpr_16 = COPY %3:vgpr_32
%4:vgpr_16 = nofpexcept V_MUL_F16_t16_e64 0, killed %2:vgpr_16, 0, %5:vgpr_16, 0, 0, 0, implicit $mode, implicit $exec
%7:vgpr_16 = COPY %3:vgpr_32
%6:vgpr_16 = nofpexcept V_ADD_F16_t16_e64 0, killed %4:vgpr_16, 0, %7:vgpr_16, 0, 0, 0, implicit $mode, implicit $exec
%8:sreg_32_xm0_xexec = nofpexcept V_CMP_NLT_F16_t16_e64 0, %6:vgpr_16, 0, %0:sgpr_32, 0, 0, implicit $mode, implicit $exec
%9:sreg_32 = S_MOV_B32 32768
%20:vgpr_32 = COPY %6:vgpr_16
%21:vgpr_32 = V_XOR_B32_e64 %20:vgpr_32, killed %9:sreg_32, implicit $exec
%13:sgpr_lo16 = COPY %0:sgpr_32
%12:vgpr_16 = V_CNDMASK_B16_t16_e64 0, killed %21:vgpr_32, 0, %13:sgpr_lo16, killed %8:sreg_32_xm0_xexec, 0, implicit $exec
%15:vgpr_16 = COPY %3:vgpr_32
%14:sreg_32_xm0_xexec = nofpexcept V_CMP_NGT_F16_t16_e64 0, killed %12:vgpr_16, 0, %15:vgpr_16, 0, 0, implicit $mode, implicit $exec
%16:vgpr_32 = V_MOV_B32_e32 32256, implicit $exec
%18:vgpr_16 = COPY %16:vgpr_32
%19:vgpr_16 = COPY %3:vgpr_32
%17:vgpr_16 = V_CNDMASK_B16_t16_e64 0, killed %18:vgpr_16, 0, %19:vgpr_16, killed %14:sreg_32_xm0_xexec, 0, implicit $exec
$vgpr0 = COPY %17:vgpr_16
SI_RETURN_TO_EPILOG $vgpr0
# End machine code for function fneg_fadd_0_f16.
*** Bad machine code: Illegal virtual register for instruction ***
- function: fneg_fadd_0_f16
- basic block: %bb.0 .entry (0x562e994ac130)
- instruction: %12:vgpr_16 = V_CNDMASK_B16_t16_e64 0, killed %21:vgpr_32, 0, %13:sgpr_lo16, killed %8:sreg_32_xm0_xexec, 0, implicit $exec
- operand 2: killed %21:vgpr_32
Expected a VS_16 register, but got a VGPR_32 register
*** Bad machine code: Illegal virtual register for instruction ***
- function: fneg_fadd_0_f16
- basic block: %bb.0 .entry (0x562e994ac130)
- instruction: %12:vgpr_16 = V_CNDMASK_B16_t16_e64 0, killed %21:vgpr_32, 0, %13:sgpr_lo16, killed %8:sreg_32_xm0_xexec, 0, implicit $exec
- operand 4: %13:sgpr_lo16
Expected a VS_16 register, but got a SGPR_LO16 register
LLVM ERROR: Found 2 machine code errors.
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0. Program arguments: /repo/uabelho/main-github/llvm/build-all-expensive/bin/llc -mtriple=amdgcn -mcpu=gfx1100 -mattr=+real-true16
1. Running pass 'CallGraph Pass Manager' on module '<stdin>'.
2. Running pass 'Verify generated machine code' on function '@fneg_fadd_0_f16'
#0 0x0000562e95d9efd6 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/repo/uabelho/main-github/llvm/build-all-expensive/bin/llc+0x7e70fd6)
#1 0x0000562e95d9ca3e llvm::sys::RunSignalHandlers() (/repo/uabelho/main-github/llvm/build-all-expensive/bin/llc+0x7e6ea3e)
#2 0x0000562e95d9f699 SignalHandler(int, siginfo_t*, void*) Signals.cpp:0:0
#3 0x00007f77a641bd10 __restore_rt (/lib64/libpthread.so.0+0x12d10)
#4 0x00007f77a3dbb52f raise (/lib64/libc.so.6+0x4e52f)
#5 0x00007f77a3d8ee65 abort (/lib64/libc.so.6+0x21e65)
#6 0x0000562e95ce0713 llvm::report_fatal_error(llvm::Twine const&, bool) (/repo/uabelho/main-github/llvm/build-all-expensive/bin/llc+0x7db2713)
#7 0x0000562e94d95450 llvm::initializeMachineVerifierLegacyPassPass(llvm::PassRegistry&) (/repo/uabelho/main-github/llvm/build-all-expensive/bin/llc+0x6e67450)
#8 0x0000562e94d96472 (anonymous namespace)::MachineVerifierLegacyPass::runOnMachineFunction(llvm::MachineFunction&) MachineVerifier.cpp:0:0
#9 0x0000562e94c40657 llvm::MachineFunctionPass::runOnFunction(llvm::Function&) (/repo/uabelho/main-github/llvm/build-all-expensive/bin/llc+0x6d12657)
#10 0x0000562e9524101e llvm::FPPassManager::runOnFunction(llvm::Function&) (/repo/uabelho/main-github/llvm/build-all-expensive/bin/llc+0x731301e)
#11 0x0000562e9464776a (anonymous namespace)::CGPassManager::runOnModule(llvm::Module&) CallGraphSCCPass.cpp:0:0
#12 0x0000562e95241b46 llvm::legacy::PassManagerImpl::run(llvm::Module&) (/repo/uabelho/main-github/llvm/build-all-expensive/bin/llc+0x7313b46)
#13 0x0000562e92a02587 compileModule(char**, llvm::LLVMContext&) llc.cpp:0:0
#14 0x0000562e929ffb20 main (/repo/uabelho/main-github/llvm/build-all-expensive/bin/llc+0x4ad1b20)
#15 0x00007f77a3da77e5 __libc_start_main (/lib64/libc.so.6+0x3a7e5)
#16 0x0000562e929fef6e _start (/repo/uabelho/main-github/llvm/build-all-expensive/bin/llc+0x4ad0f6e)
/repo/uabelho/main-github/llvm/test/CodeGen/AMDGPU/fneg-combines.f16.ll:560:28: error: GFX11-SAFE-TRUE16-LABEL: expected string not found in input
; GFX11-SAFE-TRUE16-LABEL: v_fneg_add_multi_use_fneg_x_f16:
^
<stdin>:263:33: note: scanning from here
v_fneg_add_store_use_fneg_x_f16: ; @v_fneg_add_store_use_fneg_x_f16
^
<stdin>:263:37: note: possible intended match here
v_fneg_add_store_use_fneg_x_f16: ; @v_fneg_add_store_use_fneg_x_f16
^
Input file: <stdin>
Check file: /repo/uabelho/main-github/llvm/test/CodeGen/AMDGPU/fneg-combines.f16.ll
-dump-input=help explains the following input dump.
Input was:
<<<<<<
.
.
.
258: .long 0
259: .text
260: .globl v_fneg_add_store_use_fneg_x_f16 ; -- Begin function v_fneg_add_store_use_fneg_x_f16
261: .p2align 2
262: .type v_fneg_add_store_use_fneg_x_f16, at function
263: v_fneg_add_store_use_fneg_x_f16: ; @v_fneg_add_store_use_fneg_x_f16
label:560'0 X~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ error: no match found
label:560'1 ? possible intended match
264: ; %bb.0:
label:560'0 ~~~~~~~~~
265: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
label:560'0 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
266: v_mov_b16_e32 v0.h, v0.l
label:560'0 ~~~~~~~~~~~~~~~~~~~~~~~~~~
267: s_delay_alu instid0(VALU_DEP_1) | instskip(SKIP_1) | instid1(VALU_DEP_2)
label:560'0 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
268: v_sub_f16_e32 v0.l, v1.l, v0.h
label:560'0 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.
.
.
>>>>>>
--
********************
********************
Failed Tests (1):
LLVM :: CodeGen/AMDGPU/fneg-combines.f16.ll
```
It also fails with a normal build if you just add "-verify-machineinstrs" like
```llc -mtriple=amdgcn -mcpu=gfx1100 -mattr=+real-true16 < /repo/uabelho/main-github/llvm/test/CodeGen/AMDGPU/fneg-combines.f16.ll -verify-machineinstrs```
https://github.com/llvm/llvm-project/pull/131206
More information about the llvm-commits
mailing list