<html>
<head>
<base href="https://bugs.llvm.org/">
</head>
<body><table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Bug ID</th>
<td><a class="bz_bug_link
bz_status_NEW "
title="NEW - UNREACHABLE executed at llvm/lib/Target/AArch64/GISel/AArch64RegisterBankInfo.cpp:270!"
href="https://bugs.llvm.org/show_bug.cgi?id=47109">47109</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>UNREACHABLE executed at llvm/lib/Target/AArch64/GISel/AArch64RegisterBankInfo.cpp:270!
</td>
</tr>
<tr>
<th>Product</th>
<td>libraries
</td>
</tr>
<tr>
<th>Version</th>
<td>trunk
</td>
</tr>
<tr>
<th>Hardware</th>
<td>PC
</td>
</tr>
<tr>
<th>OS</th>
<td>Linux
</td>
</tr>
<tr>
<th>Status</th>
<td>NEW
</td>
</tr>
<tr>
<th>Severity</th>
<td>normal
</td>
</tr>
<tr>
<th>Priority</th>
<td>P
</td>
</tr>
<tr>
<th>Component</th>
<td>Backend: AArch64
</td>
</tr>
<tr>
<th>Assignee</th>
<td>unassignedbugs@nondot.org
</td>
</tr>
<tr>
<th>Reporter</th>
<td>raul@tambre.ee
</td>
</tr>
<tr>
<th>CC</th>
<td>arnaud.degrandmaison@arm.com, llvm-bugs@lists.llvm.org, smithp352@googlemail.com, Ties.Stuij@arm.com
</td>
</tr></table>
<p>
<div>
<pre>This occurs when compiling libunwind.cpp for AArch64. Seems to be a recent
regression introduced after the Clang 12 branch point.
clang++ unwind.cpp --target=aarch64-linux-gnu
unwind.cpp:
void a()
{
register long b __asm("x17");
asm("" : "+r"(b));
}
Stacktrace:
Register class not supported
UNREACHABLE executed at
/opt/llvm/llvm/lib/Target/AArch64/GISel/AArch64RegisterBankInfo.cpp:270!
PLEASE submit a bug report to <a href="https://bugs.llvm.org/">https://bugs.llvm.org/</a> and include the crash
backtrace, preprocessed source, and associated run script.
Stack dump:
0. Program arguments: /opt/llvm/build/bin/clang-12 -cc1 -triple
aarch64-unknown-linux-gnu -emit-obj -mrelax-all --mrelax-relocations
-disable-free -main-file-name unwind.cpp -mrelocation-model static
-mframe-pointer=non-leaf -fmath-errno -fno-rounding-math -mconstructor-aliases
-target-cpu generic -target-feature +neon -target-abi aapcs
-fallow-half-arguments-and-returns -fno-split-dwarf-inlining
-debugger-tuning=gdb -resource-dir /opt/llvm/build/lib/clang/12.0.0
-internal-isystem /usr/local/include -internal-isystem
/opt/llvm/build/lib/clang/12.0.0/include -internal-externc-isystem /include
-internal-externc-isystem /usr/include -fdeprecated-macro
-fdebug-compilation-dir /opt/llvm/dev -ferror-limit 19 -fno-signed-char
-fgnuc-version=4.2.1 -fcxx-exceptions -fexceptions -fcolor-diagnostics
-faddrsig -o /tmp/unwind-31afd1.o -x c++ unwind.cpp
1. <eof> parser at end of file
2. Code generation
3. Running pass 'Function Pass Manager' on module 'unwind.cpp'.
4. Running pass 'RegBankSelect' on function '@_Z1av'
#0 0x0000000005f4f3c7 llvm::sys::PrintStackTrace(llvm::raw_ostream&)
/opt/llvm/llvm/lib/Support/Unix/Signals.inc:563:11
#1 0x0000000005f4f569 PrintStackTraceSignalHandler(void*)
/opt/llvm/llvm/lib/Support/Unix/Signals.inc:624:1
#2 0x0000000005f4dd7b llvm::sys::RunSignalHandlers()
/opt/llvm/llvm/lib/Support/Signals.cpp:67:5
#3 0x0000000005f4fc8d SignalHandler(int)
/opt/llvm/llvm/lib/Support/Unix/Signals.inc:405:1
#4 0x00007fe2e81cb140 __restore_rt
(/lib/x86_64-linux-gnu/libpthread.so.0+0x14140)
#5 0x00007fe2e7ca3db1 raise ./signal/../sysdeps/unix/sysv/linux/raise.c:51:1
#6 0x00007fe2e7c8d537 abort ./stdlib/abort.c:81:7
#7 0x0000000005e87524 /opt/llvm/llvm/lib/Support/ErrorHandling.cpp:210:3
#8 0x00000000041889fb
llvm::AArch64RegisterBankInfo::getRegBankFromRegClass(llvm::TargetRegisterClass
const&, llvm::LLT) const
/opt/llvm/llvm/lib/Target/AArch64/GISel/AArch64RegisterBankInfo.cpp:272:1
#9 0x0000000007702117 llvm::RegisterBankInfo::getRegBank(llvm::Register,
llvm::MachineRegisterInfo const&, llvm::TargetRegisterInfo const&) const
/opt/llvm/llvm/lib/CodeGen/GlobalISel/RegisterBankInfo.cpp:88:5
#10 0x0000000004189bcd
llvm::AArch64RegisterBankInfo::getInstrMapping(llvm::MachineInstr const&) const
/opt/llvm/llvm/lib/Target/AArch64/GISel/AArch64RegisterBankInfo.cpp:582:27
#11 0x00000000076fa7d4 llvm::RegBankSelect::assignInstr(llvm::MachineInstr&)
/opt/llvm/llvm/lib/CodeGen/GlobalISel/RegBankSelect.cpp:630:25
#12 0x00000000076fadc7
llvm::RegBankSelect::runOnMachineFunction(llvm::MachineFunction&)
/opt/llvm/llvm/lib/CodeGen/GlobalISel/RegBankSelect.cpp:705:11
#13 0x0000000004e51d77
llvm::MachineFunctionPass::runOnFunction(llvm::Function&)
/opt/llvm/llvm/lib/CodeGen/MachineFunctionPass.cpp:73:8
#14 0x000000000551f542 llvm::FPPassManager::runOnFunction(llvm::Function&)
/opt/llvm/llvm/lib/IR/LegacyPassManager.cpp:1587:23
#15 0x00000000055247a5 llvm::FPPassManager::runOnModule(llvm::Module&)
/opt/llvm/llvm/lib/IR/LegacyPassManager.cpp:1633:16
#16 0x000000000551fee6 (anonymous
namespace)::MPPassManager::runOnModule(llvm::Module&)
/opt/llvm/llvm/lib/IR/LegacyPassManager.cpp:1702:23
#17 0x000000000551fa16 llvm::legacy::PassManagerImpl::run(llvm::Module&)
/opt/llvm/llvm/lib/IR/LegacyPassManager.cpp:614:16
#18 0x0000000005524aa1 llvm::legacy::PassManager::run(llvm::Module&)
/opt/llvm/llvm/lib/IR/LegacyPassManager.cpp:1829:3
#19 0x000000000632023a (anonymous
namespace)::EmitAssemblyHelper::EmitAssembly(clang::BackendAction,
std::unique_ptr<llvm::raw_pwrite_stream,
std::default_delete<llvm::raw_pwrite_stream> >)
/opt/llvm/clang/lib/CodeGen/BackendUtil.cpp:969:3
#20 0x000000000631c333 clang::EmitBackendOutput(clang::DiagnosticsEngine&,
clang::HeaderSearchOptions const&, clang::CodeGenOptions const&,
clang::TargetOptions const&, clang::LangOptions const&, llvm::DataLayout
const&, llvm::Module*, clang::BackendAction,
std::unique_ptr<llvm::raw_pwrite_stream,
std::default_delete<llvm::raw_pwrite_stream> >)
/opt/llvm/clang/lib/CodeGen/BackendUtil.cpp:1685:5
#21 0x000000000712c135
clang::BackendConsumer::HandleTranslationUnit(clang::ASTContext&)
/opt/llvm/clang/lib/CodeGen/CodeGenAction.cpp:335:7
#22 0x0000000007ea1348 clang::ParseAST(clang::Sema&, bool, bool)
/opt/llvm/clang/lib/Parse/ParseAST.cpp:178:12
#23 0x0000000006f5ad1d clang::ASTFrontendAction::ExecuteAction()
/opt/llvm/clang/lib/Frontend/FrontendAction.cpp:1059:1
#24 0x00000000071285bf clang::CodeGenAction::ExecuteAction()
/opt/llvm/clang/lib/CodeGen/CodeGenAction.cpp:1183:1
#25 0x0000000006f5a6e8 clang::FrontendAction::Execute()
/opt/llvm/clang/lib/Frontend/FrontendAction.cpp:954:7
#26 0x0000000006e882dc
clang::CompilerInstance::ExecuteAction(clang::FrontendAction&)
/opt/llvm/clang/lib/Frontend/CompilerInstance.cpp:984:23
#27 0x000000000711714c
clang::ExecuteCompilerInvocation(clang::CompilerInstance*)
/opt/llvm/clang/lib/FrontendTool/ExecuteCompilerInvocation.cpp:278:8
#28 0x0000000003f8d8ac cc1_main(llvm::ArrayRef<char const*>, char const*,
void*) /opt/llvm/clang/tools/driver/cc1_main.cpp:240:13
#29 0x0000000003f814ba ExecuteCC1Tool(llvm::SmallVectorImpl<char const*>&)
/opt/llvm/clang/tools/driver/driver.cpp:330:5
#30 0x0000000003f806dd main /opt/llvm/clang/tools/driver/driver.cpp:407:5
#31 0x00007fe2e7c8ecca __libc_start_main ./csu/../csu/libc-start.c:308:16
#32 0x0000000003f7fe8a _start (/opt/llvm/build/bin/clang-12+0x3f7fe8a)</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are on the CC list for the bug.</li>
</ul>
</body>
</html>