Issue 172621
Summary Clang with assertions crashes during AsmPrinter with -O3 on inline assembly using label pointers
Labels backend:X86, crash-on-invalid
Assignees
Reporter AbyssStaror
    ### Link for quick verification: https://godbolt.org/z/e5n8a1e5h
```c
int main() {    
    label_one:
    label_two:

    void *l1 = &&label_one; 
    void *l2 = &&label_two;

  __asm__ volatile (
     ".long %[l1] - .\n"
     ".long %[l2] - .\n"
  :: [l1]"p"(l1), [l2]"p"(l2));
}
```
Go back to the `clang version 15.0.0(assertions)` and the compiler crashed with the optimization flag.
## Stack dump:
```
clang-21: /workspace/install/llvm/src/llvm-project/llvm/lib/Target/X86/X86AsmPrinter.cpp:503: void llvm::X86AsmPrinter::PrintMemReference(const llvm::MachineInstr*, unsigned int, llvm::raw_ostream&, llvm::StringRef): Assertion `isMem(*MI, OpNo) && "Invalid memory reference!"' failed.
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace, preprocessed source, and associated run script.
Stack dump:
0. Program arguments: /workspace/install/llvm/build_21.1.4/bin/clang-21 -cc1 -triple x86_64-unknown-linux-gnu -O3 -emit-obj -dumpdir a- -disable-free -clear-ast-before-backend -main-file-name 29835.fuzz -mrelocation-model pic -pic-level 2 -pic-is-pie -mframe-pointer=none -fmath-errno -ffp-contract=on -fno-rounding-math -mconstructor-aliases -funwind-tables=2 -target-cpu x86-64 -tune-cpu generic -debugger-tuning=gdb -fdebug-compilation-dir=/workspace/exps/featurefuzz/random_combine_feature_set_2_exp -fcoverage-compilation-dir=/workspace/exps/featurefuzz/random_combine_feature_set_2_exp -resource-dir /workspace/install/llvm/build_21.1.4/lib/clang/21 -internal-isystem /usr/lib/gcc/x86_64-linux-gnu/13/../../../../include/c++/13 -internal-isystem /usr/lib/gcc/x86_64-linux-gnu/13/../../../../include/x86_64-linux-gnu/c++/13 -internal-isystem /usr/lib/gcc/x86_64-linux-gnu/13/../../../../include/c++/13/backward -internal-isystem /workspace/install/llvm/build_21.1.4/lib/clang/21/include -internal-isystem /usr/local/include -internal-isystem /usr/lib/gcc/x86_64-linux-gnu/13/../../../../x86_64-linux-gnu/include -internal-externc-isystem /usr/include/x86_64-linux-gnu -internal-externc-isystem /include -internal-externc-isystem /usr/include -std=c++20 -fdeprecated-macro -ferror-limit 19 -fmessage-length=131 -fgnuc-version=4.2.1 -fno-implicit-modules -fskip-odr-check-in-gmf -fcxx-exceptions -fexceptions -fcolor-diagnostics -vectorize-loops -vectorize-slp -faddrsig -D__GCC_HAVE_DWARF2_CFI_ASM=1 -o /tmp/29835-6987e8.o -x c++ /workspace/exps/featurefuzz/generate_feature_fine_tuning_qwen_4b_choose_2_5_exp/bugs/29835.fuzz
1. <eof> parser at end of file
2.      Code generation
3.      Running pass 'Function Pass Manager' on module '/workspace/exps/featurefuzz/generate_feature_fine_tuning_qwen_4b_choose_2_5_exp/bugs/29835.fuzz'.
4. Running pass 'X86 Assembly Printer' on function '@main'
 #0 0x000055555ebe5c2a llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x9691c2a)
 #1 0x000055555ebe6457 PrintStackTraceSignalHandler(void*) Signals.cpp:0:0
 #2 0x000055555ebdff57 llvm::sys::RunSignalHandlers() (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x968bf57)
 #3 0x000055555ebe01c7 SignalHandler(int, siginfo_t*, void*) Signals.cpp:0:0
 #4 0x00007ffff7a3b330 (/lib/x86_64-linux-gnu/libc.so.6+0x45330)
 #5 0x00007ffff7a94b2c __pthread_kill_implementation ./nptl/pthread_kill.c:44:76
 #6 0x00007ffff7a94b2c __pthread_kill_internal ./nptl/pthread_kill.c:78:10
 #7 0x00007ffff7a94b2c pthread_kill ./nptl/pthread_kill.c:89:10
 #8 0x00007ffff7a3b27e raise ./signal/../sysdeps/posix/raise.c:27:6
 #9 0x00007ffff7a1e8ff abort ./stdlib/abort.c:81:7
#10 0x00007ffff7a1e81b _nl_load_domain ./intl/loadmsgcat.c:1177:9
#11 0x00007ffff7a31517 (/lib/x86_64-linux-gnu/libc.so.6+0x3b517)
#12 0x000055555c778a64 llvm::X86AsmPrinter::PrintMemReference(llvm::MachineInstr const*, unsigned int, llvm::raw_ostream&, llvm::StringRef) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x7224a64)
#13 0x000055555c779584 llvm::X86AsmPrinter::PrintAsmMemoryOperand(llvm::MachineInstr const*, unsigned int, char const*, llvm::raw_ostream&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x7225584)
#14 0x00005555602a2895 EmitInlineAsmStr(char const*, llvm::MachineInstr const*, llvm::MachineModuleInfo*, llvm::MCAsmInfo const*, llvm::AsmPrinter*, unsigned long, llvm::raw_ostream&) AsmPrinterInlineAsm.cpp:0:0
#15 0x00005555602a47e5 llvm::AsmPrinter::emitInlineAsm(llvm::MachineInstr const*) const (/workspace/install/llvm/build_21.1.4/bin/clang-21+0xad507e5)
#16 0x00005555602972b3 llvm::AsmPrinter::emitFunctionBody() (/workspace/install/llvm/build_21.1.4/bin/clang-21+0xad432b3)
#17 0x000055555c775602 llvm::X86AsmPrinter::runOnMachineFunction(llvm::MachineFunction&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x7221602)
#18 0x000055555d708586 llvm::MachineFunctionPass::runOnFunction(llvm::Function&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x81b4586)
#19 0x000055555e1026a9 llvm::FPPassManager::runOnFunction(llvm::Function&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x8bae6a9)
#20 0x000055555e102e89 llvm::FPPassManager::runOnModule(llvm::Module&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x8baee89)
#21 0x000055555e101b77 llvm::legacy::PassManagerImpl::run(llvm::Module&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x8badb77)
#22 0x000055555e102469 llvm::legacy::PassManager::run(llvm::Module&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x8bae469)
#23 0x000055555f01149e clang::emitBackendOutput(clang::CompilerInstance&, clang::CodeGenOptions&, llvm::StringRef, llvm::Module*, clang::BackendAction, llvm::IntrusiveRefCntPtr<llvm::vfs::FileSystem>, std::unique_ptr<llvm::raw_pwrite_stream, std::default_delete<llvm::raw_pwrite_stream>>, clang::BackendConsumer*) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x9abd49e)
#24 0x000055555f9fa3a2 clang::BackendConsumer::HandleTranslationUnit(clang::ASTContext&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0xa4a63a2)
#25 0x00005555620c5eb5 clang::ParseAST(clang::Sema&, bool, bool) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0xcb71eb5)
#26 0x000055555fe0d92b clang::ASTFrontendAction::ExecuteAction() (/workspace/install/llvm/build_21.1.4/bin/clang-21+0xa8b992b)
#27 0x000055555f9fb360 clang::CodeGenAction::ExecuteAction() (/workspace/install/llvm/build_21.1.4/bin/clang-21+0xa4a7360)
#28 0x000055555fe159cf clang::FrontendAction::Execute() (/workspace/install/llvm/build_21.1.4/bin/clang-21+0xa8c19cf)
#29 0x000055555fd5bf46 clang::CompilerInstance::ExecuteAction(clang::FrontendAction&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0xa807f46)
#30 0x000055555ff9df7b clang::ExecuteCompilerInvocation(clang::CompilerInstance*) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0xaa49f7b)
#31 0x0000555559d0c523 cc1_main(llvm::ArrayRef<char const*>, char const*, void*) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x47b8523)
#32 0x0000555559cfcc58 ExecuteCC1Tool(llvm::SmallVectorImpl<char const*>&, llvm::ToolContext const&) driver.cpp:0:0
#33 0x0000555559d02b28 clang_main(int, char**, llvm::ToolContext const&) (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x47aeb28)
#34 0x0000555559b5db4a main (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x4609b4a)
#35 0x00007ffff7a201ca __libc_start_call_main ./csu/../sysdeps/nptl/libc_start_call_main.h:74:3
#36 0x00007ffff7a2028b call_init ./csu/../csu/libc-start.c:128:20
#37 0x00007ffff7a2028b __libc_start_main ./csu/../csu/libc-start.c:347:5
#38 0x0000555559cfaf55 _start (/workspace/install/llvm/build_21.1.4/bin/clang-21+0x47a6f55)
clang++: error: unable to execute command: Aborted (core dumped)
```
_______________________________________________
llvm-bugs mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-bugs

Reply via email to