<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/63377>63377</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
riscv32 crashes on huge alloca
</td>
</tr>
<tr>
<th>Labels</th>
<td>
backend:RISC-V,
llvm:crash
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
chfast
</td>
</tr>
</table>
<pre>
```
LLVM ERROR: Should only materialize 32-bit constants for RV32
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0. Program arguments: /opt/compiler-explorer/clang-assertions-trunk/bin/llc -o /app/output.s -x86-asm-syntax=intel <source>
1. Running pass 'Function Pass Manager' on module '<source>'.
2. Running pass 'Prologue/Epilogue Insertion & Frame Finalization' on function '@f'
#0 0x000055aba2ce9ccf llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x3575ccf)
#1 0x000055aba2ce7424 SignalHandler(int) Signals.cpp:0:0
#2 0x00007f43b01fc420 __restore_rt (/lib/x86_64-linux-gnu/libpthread.so.0+0x14420)
#3 0x00007f43afcc900b raise (/lib/x86_64-linux-gnu/libc.so.6+0x4300b)
#4 0x00007f43afca8859 abort (/lib/x86_64-linux-gnu/libc.so.6+0x22859)
#5 0x000055ab9ff3fa88 llvm::SuffixTree::insertLeaf(llvm::SuffixTreeInternalNode&, unsigned int, unsigned int) (.cold) SuffixTree.cpp:0:0
#6 0x000055aba2c3d18e (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x34c918e)
#7 0x000055aba1051e8e llvm::RISCVInstrInfo::movImm(llvm::MachineBasicBlock&, llvm::MachineInstrBundleIterator<llvm::MachineInstr, false>, llvm::DebugLoc const&, llvm::Register, unsigned long, llvm::MachineInstr::MIFlag) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x18dde8e)
#8 0x000055aba1058d1f llvm::RISCVRegisterInfo::adjustReg(llvm::MachineBasicBlock&, llvm::MachineInstrBundleIterator<llvm::MachineInstr, false>, llvm::DebugLoc const&, llvm::Register, llvm::Register, llvm::StackOffset, llvm::MachineInstr::MIFlag, llvm::MaybeAlign) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x18e4d1f)
#9 0x000055aba109b316 llvm::RISCVFrameLowering::emitPrologue(llvm::MachineFunction&, llvm::MachineBasicBlock&) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x1927316)
#10 0x000055aba20e8a3d (anonymous namespace)::PEI::runOnMachineFunction(llvm::MachineFunction&) PrologEpilogInserter.cpp:0:0
#11 0x000055aba1f7a47e llvm::MachineFunctionPass::runOnFunction(llvm::Function&) (.part.0) MachineFunctionPass.cpp:0:0
#12 0x000055aba25103f1 llvm::FPPassManager::runOnFunction(llvm::Function&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x2d9c3f1)
#13 0x000055aba2510639 llvm::FPPassManager::runOnModule(llvm::Module&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x2d9c639)
#14 0x000055aba2510eb2 llvm::legacy::PassManagerImpl::run(llvm::Module&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x2d9ceb2)
#15 0x000055ab9fffc734 compileModule(char**, llvm::LLVMContext&) llc.cpp:0:0
```
```llvm
target triple = "riscv32-unknown-linux-gnu"
define void @f() {
%A = alloca i32, i32 -1
ret void
}
```
https://godbolt.org/z/bx9o5GWrq
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzUV91u87gRfRr6hrAhkfq98IXz49ZA0i9wFullQFEjmRuKVEkqn7NPX5BSEsvJdtM2LbCAA0sT-szhOQMOh1krWgWwRukFSq8WbHAHbdb80DDrFpWuX9Yoi6ZPdIWizc3Nwy2-3u9_7BHd4PuDHmSNtZIvuGMOjGBS_AaYkmUlHOZaWceUs7jRBu8fKBlB7m6uN_fX2A5VJxxmuBpabKDXxmGn8cG53iK6QWSLyLYV7jBUK647RLZSPr9-LXujfwXuENkKawewiGwxUzUWisuhBuwOgLlh9oArxp-cYRxWY_p7x_gTroeu91lCKFqhqLwzujWsw8y0QwfKeRIYka3ufRauu15IMEs49lIbMD4mmWqXzFowTmhll84M6gmRbSVU4MnxUnsI1vceaHD94FYWL49FtmS2W9oX5dgR0SuhHEiM6KXVg-GA6PVILPbE9oNSQrW4Z9ZiRPLtoLjPh-984JYp1no6OdYKd7oeJPhVMzCST5snnwHeGS11OwAi2-tehEe8U9OuMCIZ3hrWAd4K5Q1mPjzla165-IxJ1PivkAgjQiMcHaMoitKUVYxwKDlvcDCRbhDd2Bc7PtwZoVyw5RfvEyLF-yLDfj5q6wywDpEMkUsslEOkxIgU_6U5iFxER5rmKecNIuU77_iMd56QBN-LVjH5V6Zq6fGLicYYtive-3KKwt8bEJmA8iahVRQ3PCERfnw0YJ028GjctAspKkS2xyJ7zJKlFGo4Lls1jP_o3cEAq1dWr6LAOE4SEs340pM0rOG8jKIKGyYsfAGfe-QsICc0iqoZcjJHZkWRlphV-kvMT5AJKdJyhpyeaFw2DW1YUZzUxv3QNOL4iwEY30Uoxxtgzaw63pftlAOjmPybrmEqlEGF460eK-b8PVTQimtZBxvfgD53MpuXBK3jAr6tBBNexgXM5MlP88VRGkMBJ_Lsd_eXDztlndmpRo-xTj_vum4mzy3jB6HgglnBL6TmT5MyH1YEqIvB1_bOgWFOG0QvP1_mARom7XiwnIJdQTW0N5qPJ_-HXHtohXVgZl5IrdrfpzRFdlvJWm9TAP4u3eOiruFM9-JM96KOm3PdX_fxLj2rfx2s20P7J1H_j6LhLP7RNBbcV72Zr3qpYCNFq_4HnkFSx_Pjupx7VlY0zs49Cw3sRv8EI1Q7xqET7r3zffTttc3-nmtnvn73RkuS0zh726hvS_N-GkHBaO3zMaXVS6cHixXrwPahh5ZTb73eTY10UD_Uh639wbZLPCo0XgvGOwGYj0ekZzfrmnGTsySHj6q9wvu7ywmxTxmdUfHndc-M832wxJ_gfc6LzFRL44g28Qmv7Z3_6est6t9m9B1ek7rktIlnXtNz1hktv8D6Ntz_5r5Ooe9mnNFyxjg5ZwwVOWEsoWX8ZSrKd-67rpdv_P8vvKEiM95nN5GG5zTBU443OfmBGUQ24XN6FviB6FIrB0c3MZWSf1KH8zHqLBjgQsgx04LDzoje3-LpFUaEGGH5MyXLQT0p_VOdXrPIKV4NjVCAn7Wo8XgXL4J0-cV0VmJE0k1AZVJqzrCgJNyoKcHL-HWRARcwJuj86l9s4WxY03WlpVtp0yKy_c2rfyx1-pe_m38s6jWtS1qyBazjrMijsiApXRzWZZUXKYuLrGaQVaygKacp5LxJKU0aWi7EmkSERllcxAlJYroqyiRrirJOUhazLGMoiaBjQq68jD73IkyE64zSPF9IVoG0YcIlxI-CoOqpKSwfvIDkEhEyGRoGRh9MrxZmHebMamgtSiIprLPvGZxwEtaTMeOcCdbPQ4ehhUndxWDk-j-fZgP9fwYAAP__Rx3Pwg">