<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/64439>64439</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[x86_64] `insertelement` after `extractelement` for vxi1 crashes when targeting `sapphirerapids` / `znver4` CPU
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
HazyFish
</td>
</tr>
</table>
<pre>
## Description
When targeting Intel `sapphirerapids` or AMD `znver4` CPU, the following code crashes `x86_64` backend with assertion `Op.getScalarValueSizeInBits() == BitWidth && "Mask size mismatches value type size!"` failed during `TargetLowering::SimplifyDemandedBits` in 'X86 DAG->DAG Instruction Selection' pass.
The problem doesn't exist when targeting `znver3`, `alderlake`, or `raptorlake` CPUs, or when CPU is not specified.
## Minimal Reproduction
https://godbolt.org/z/s7jcjbfbr
### Code
```ll
define void @f(ptr %0, <32 x i1> %1, i32 %2) {
BB:
%E = extractelement <32 x i1> %1, i32 3
%I = insertelement <32 x i1> %1, i1 %E, i32 %2
store <32 x i1> %I, ptr %0
ret void
}
```
### Stack Trace
```console
llc: /root/llvm-project/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp:1075: bool llvm::TargetLowering::SimplifyDemandedBits(llvm::SDValue, const llvm::APInt&, const llvm::APInt&, llvm::KnownBits&, llvm::TargetLowering::TargetLoweringOpt&, unsigned int, bool) const: Assertion `Op.getScalarValueSizeInBits() == BitWidth && "Mask size mismatches value type size!"' failed.
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 -mtriple=x86_64 -mcpu=znver4 <source>
1. Running pass 'Function Pass Manager' on module '<source>'.
2. Running pass 'X86 DAG->DAG Instruction Selection' on function '@f'
#0 0x0000000003398418 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x3398418)
#1 0x0000000003395d0c SignalHandler(int) Signals.cpp:0:0
#2 0x00007f6b2d987420 __restore_rt (/lib/x86_64-linux-gnu/libpthread.so.0+0x14420)
#3 0x00007f6b2d44a00b raise (/lib/x86_64-linux-gnu/libc.so.6+0x4300b)
#4 0x00007f6b2d429859 abort (/lib/x86_64-linux-gnu/libc.so.6+0x22859)
#5 0x00007f6b2d429729 (/lib/x86_64-linux-gnu/libc.so.6+0x22729)
#6 0x00007f6b2d43afd6 (/lib/x86_64-linux-gnu/libc.so.6+0x33fd6)
#7 0x00000000031cc515 llvm::TargetLowering::SimplifyDemandedBits(llvm::SDValue, llvm::APInt const&, llvm::APInt const&, llvm::KnownBits&, llvm::TargetLowering::TargetLoweringOpt&, unsigned int, bool) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x31cc515)
#8 0x0000000001d05986 llvm::X86TargetLowering::SimplifyDemandedBitsForTargetNode(llvm::SDValue, llvm::APInt const&, llvm::APInt const&, llvm::KnownBits&, llvm::TargetLowering::TargetLoweringOpt&, unsigned int) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x1d05986)
#9 0x00000000031c3adb llvm::TargetLowering::SimplifyDemandedBits(llvm::SDValue, llvm::APInt const&, llvm::APInt const&, llvm::KnownBits&, llvm::TargetLowering::TargetLoweringOpt&, unsigned int, bool) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x31c3adb)
#10 0x00000000031c537e llvm::TargetLowering::SimplifyDemandedBits(llvm::SDValue, llvm::APInt const&, llvm::APInt const&, llvm::KnownBits&, llvm::TargetLowering::TargetLoweringOpt&, unsigned int, bool) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x31c537e)
#11 0x00000000031c4baa llvm::TargetLowering::SimplifyDemandedBits(llvm::SDValue, llvm::APInt const&, llvm::APInt const&, llvm::KnownBits&, llvm::TargetLowering::TargetLoweringOpt&, unsigned int, bool) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x31c4baa)
#12 0x0000000001d069f9 llvm::X86TargetLowering::SimplifyDemandedBitsForTargetNode(llvm::SDValue, llvm::APInt const&, llvm::APInt const&, llvm::KnownBits&, llvm::TargetLowering::TargetLoweringOpt&, unsigned int) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x1d069f9)
#13 0x00000000031c3adb llvm::TargetLowering::SimplifyDemandedBits(llvm::SDValue, llvm::APInt const&, llvm::APInt const&, llvm::KnownBits&, llvm::TargetLowering::TargetLoweringOpt&, unsigned int, bool) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x31c3adb)
#14 0x00000000031d7299 llvm::TargetLowering::SimplifyDemandedBits(llvm::SDValue, llvm::APInt const&, llvm::KnownBits&, llvm::TargetLowering::TargetLoweringOpt&, unsigned int, bool) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x31d7299)
#15 0x00000000031d7459 llvm::TargetLowering::SimplifyDemandedBits(llvm::SDValue, llvm::APInt const&, llvm::TargetLowering::DAGCombinerInfo&) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x31d7459)
#16 0x0000000001ce887e combineVectorShiftImm(llvm::SDNode*, llvm::SelectionDAG&, llvm::TargetLowering::DAGCombinerInfo&, llvm::X86Subtarget const&) X86ISelLowering.cpp:0:0
#17 0x0000000001cf5149 llvm::X86TargetLowering::PerformDAGCombine(llvm::SDNode*, llvm::TargetLowering::DAGCombinerInfo&) const (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x1cf5149)
#18 0x0000000003019451 (anonymous namespace)::DAGCombiner::combine(llvm::SDNode*) DAGCombiner.cpp:0:0
#19 0x000000000301af0c (anonymous namespace)::DAGCombiner::Run(llvm::CombineLevel) DAGCombiner.cpp:0:0
#20 0x000000000301d50c llvm::SelectionDAG::Combine(llvm::CombineLevel, llvm::AAResults*, llvm::CodeGenOpt::Level) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x301d50c)
#21 0x000000000316c6e7 llvm::SelectionDAGISel::CodeGenAndEmitDAG() (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x316c6e7)
#22 0x000000000316ff88 llvm::SelectionDAGISel::SelectAllBasicBlocks(llvm::Function const&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x316ff88)
#23 0x0000000003171c82 llvm::SelectionDAGISel::runOnMachineFunction(llvm::MachineFunction&) (.part.0) SelectionDAGISel.cpp:0:0
#24 0x0000000001b894bc (anonymous namespace)::X86DAGToDAGISel::runOnMachineFunction(llvm::MachineFunction&) X86ISelDAGToDAG.cpp:0:0
#25 0x0000000002680049 llvm::MachineFunctionPass::runOnFunction(llvm::Function&) (.part.0) MachineFunctionPass.cpp:0:0
#26 0x0000000002bf8bb9 llvm::FPPassManager::runOnFunction(llvm::Function&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x2bf8bb9)
#27 0x0000000002bf8df1 llvm::FPPassManager::runOnModule(llvm::Module&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x2bf8df1)
#28 0x0000000002bf9612 llvm::legacy::PassManagerImpl::run(llvm::Module&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x2bf9612)
#29 0x000000000075e092 compileModule(char**, llvm::LLVMContext&) llc.cpp:0:0
#30 0x000000000069a7e6 main (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x69a7e6)
#31 0x00007f6b2d42b083 __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24083)
#32 0x0000000000754a4e _start (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x754a4e)
Program terminated with signal: SIGSEGV
Compiler returned: 139
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzsWl9z26jb_TTkhrEHof8XuXDiOJt5m3czdbfbuwySHtlsJdAAapx--t-AZMco3jTbzXZnZ9ppGwfQ4TyHh4MMMK35RgCco_gCxcsz1putVOe_sK-PK663Z4WsHs8RDREN8RJ0qXhnuBSILBFZDP__vgWBDVMbMFxs8I0w0GCUEM26bssVKNbxSqOEYKnw4nZp676KL6AiW3Z59xuil9hsAdeyaeSDxShlBbhUTG9B2-a7LLlPXPOClZ9BVPiBmy1mWoOydGybX7v5Bsy6ZA1TH1nTw5p_hRtxwY1GNEM0xyhconCJL7j5nVdmixFNEE0wovSW6c9Y86-AW65bZkrb7xcLgs1jB64K0QBRajnUjDdQ4apXlitKyAcX_Dv5ALYEhQsULta87RpePy6hZaKCyvFICOYCI5p-yhK8XFzPUHi1XFzjG6GN6ksXyhoacJ8QTXHHtJ4fi_1hC7hTsmigxZUEbVsZDDuuDX7wB2Ivc4gSYiVGCWFNBaphn2EsksqWKtYZuS-2A6LHOgd4efcb5hoLabDuoOQ1h8qjNGbHLRe8ZQ1-D52S1RDMcbOtMZ222tAVoquNrArZmLlUG0RXXxFd6fSP8o-iLtRzbAt_KSvwahIy_G2aoaCCmgvAXySvMIpIjWjWGYURjYfow8uQ4h3mAQqvbGlgS3lI7Wfq0iO9GJAuLixN9xHb2iubORh2RrHSQAMtCPMCXnj06I17lAubp994MnBdeaRGHG2kgueP3di2hxDHtgqMk2AUKV1O1Dot7tqw8jP-oFh5WuNSCi2bsa5pShQuMKIrJaVBdNU0X9pZp-QfUO5_tT94gejKDts1CERXh7xeLq4RXflzZl52HQoXAUlji11I2WCH4-bSq-cXzZ4eWi-dC1iRLH1zhLe4uxHGzf6X655K_0_Ih9FKJjWnuPllv3Z7vF44s60wt11cujBt5jkONu7Fv2BoNB0NbZzUd--uFusrrPui5QYzXPQbrKCTymAj8WQWc7Pti3kp26Nx97OBa92DRnSFmbCBl01fgbN75-_O0O3EgrH7IRWrvu0Ok5DMEcnvlNwo1mKmNr2dRnrMQWnVXZWy7XgDaga7rpEKlC1rmNjMDmuEnhnVi8-IrgouHM8Sz6SFYF1ngXrT9Wau8WyXJTOm25l-FIbtULjkbkmbtUbxrgEULof1CM_asutRuBxWMztDtexVCSi8GpgHlvn7Xgjrx9bLrfevejE4_Z0tuGWCbSzfFEuBW1n1DdhWHhhNR3XoKcDXLiZS4Hrft-3BmWQ6OgeiIcFkR_Z_wjDPoiA7ynT9qIcPd4oL48ZpcIzjWafYw73URgFrx6R3uZ5jl7J_a7QQvSC7kRai-RPvYMI7rkiJ13wjWPMLE1Vj8bORxlCsR78h7t8BiI5AaZ0UtMqzNKIE398rcA58r8wYxWBtQxLMGi763Wwj-qGiM1sFrJprOSeOcRBFlHh8Q6-bKGKEFFgxruEV-KVFThxyFBJSeMiRj0zzLM4xK-SrmB8hU5rFuYccT5HTw5i-GjOlPmbiY4asrpK_hhmGdZV4mKmXC0FZxkH8hivJZJ0YnXu6JrxU9wNWkjeba4N8nr7Zsb5BReI8S45i-JQlr5V4JdXQ9P_tm91_Su831nmU0dM5n-RxyKriZx5_dx5b-Q762iWDTPSNwxR-6vvd-lr5PH2Dib5RwdhPfb9bXyufpy-d-HCS1_lPH_7bPmxl9HQOf_rwP-rDka9vldI8_-H6_qc0dBJ5GsZTDaP4x2t4qpfl4vpStgUXoG5ELd0z_4AeUezrkXjeWEKWpYDLgchHKI1U6y2vzU3bTkIeHHDhB-bvW31n1Je-N6_7YtinPRIzx5-y5GYNzWRP7Og7qg0u9YOr4yB6hfHfgaqlap-ovSbyf2lIx6C8IfW-doQkyKM4sP0xIcVjK3uNBWtBd247In9GdSgoXw49x0dPnBY_n9BgNSn_Mo33vfAojLXv4As0r2FByYRFFZPyzxL2uIcXevVm-eI96L6xhjBJiHEz11qe-_1A-a0m8xDL8cjTyYtkUiaQ_kmwdvJ4RBeiumq5cRM3e0ueAw2PJ53wrOss-ybPoXTRNBdM8_KikeVn34YPe4XHPvF2UViSXhST1500KDP6zShUL34Vt6zccgF7wl4Uz-r2Ycw7psycuI25CfTp1PdeF4Iiy6PimxPwU5YsF9cf5FtwHi16j3eapLce0yQjxLPoCfId0_qI00kyLyp3Au80L29dpEWdFcUxr9WdfXS_H_2XGb1FSo6kvJRMp6yrOngF61u3k-4P6Vj01oyrOvAYZxPGeRIcT6IGNqx8HNflJ-43bfeUmz-Ct6Xl8fZWN5LGQHKKxz4OcpZbptzCMFkb3r37eHsphYHd3qaapjyZh_45A0lylkKCW-ZOxt8kuAHyOLbDGcF-_7ogWYjv7xtelPfaMGXujwi8dkc7Ilno9UInCkYsAjzgv1VsA-ih1_2xmAHVcsEMjFcjtDvnQOECr2-u11fXH4fml2PHWIHplYDKtgjCfHLee1adh1Ue5uwMzoMkD4I0CeLobHse5EUFKYGsTMI0DBKAqCiKqq6juszipD7j55TQkGQkCnKSB9E8KrOUpQAEAohJVKCIQMt4M7epM5dqc-ZOCM-TKArzs4YV0Gh3GYVSAQ_YVSJKUbw8U-fubLHoNxpFpOHa6CcUw03jbrGMd0Vid8_EO3lHCcGsNuAuPfjH-e5ah1T4y44Hh4snz-9TPL_Sgujq2X2Ws141599_UOqU-F8AAAD__0yV5is">