<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/133507>133507</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
clang 19 or 20 miscompiles llvm::MergeBasicBlockIntoOnlyPred for PPC32
</td>
</tr>
<tr>
<th>Labels</th>
<td>
clang
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
kernigh
</td>
</tr>
</table>
<pre>
For target powerpc-unknown-openbsd, clang-19 or clang-20 miscompiles the function llvm::MergeBasicBlockIntoOnlyPred in llvm 19. clang-18 works. This means that clang-19 miscompiles itself for 32-bit PowerPC. If my target clang-19 contains a miscompiled MergeBasicBlockIntoOnlyPred, then it will (with most .c files) either crash SIGSEGV or get stuck in an infinite loop.
My target clang-19's source tree has a few modifications. One of them moves MergeBasicBlockIntoOnlyPred from llvm/lib/Transforms/Utils/Local.cpp to its own file. The attached [emini.zip](https://github.com/user-attachments/files/19510915/emini.zip) contains
- emini.cpp, a MergeBasicBlockIntoOnlyPred preprocessed by clang-16 with OpenBSD/macppc headers.
- ecompile.sh, a script to cross-compile emini.cpp,
$ sh ecompile.sh -c emini.cpp -o whatever.o
You can build emini.cpp with clang 16 to 20. It doesn't work with git main, because clang-21 seems to drop support for __is_referencable in my libc++ headers.
I have started a git bisect of llvm-project on my fast AMD64 machine. I can cross-compile emini.cpp on the AMD64 and copy the .o to my slow PPC32 machine, where I link it into my target clang-19, then try to compile and run OpenBSD date(1) with my target clang-19. If it works, git bisect good. If it crashes or times out, git bisect bad. I know that releases/20.x is bad and releases/18.x is good. I need about 2 hours to build each git commit, so I might take a few more days to finish my bisect.
</pre>
<img width="1" height="1" alt="" src="http://email.email.llvm.org/o/eJyMVU2P2zYQ_TX0ZWBBoqy1dNBhna0DAw2yQNICPQUUNbJY80PgUOu6v74gZcdugi56Wq05nHlv3ryhIFJHi9iyaseql5WYw-h8e0Jv1XFcda6_tHvnIQh_xACTO6Of5Hq2J-vOdu0mtB31jH8AqYU9rosGnL9-8xyMIunMpDQShBFhmK0MylnQ-s2w8pmVz5_QH3EnSMmddvJ0sMF9tvry6rEHtQRC0WS3_DWcnT9RBl9HRWBQ2JhZhHv9x5oqEOoBBueh5OtOBXiNDF4_ZHAYwFxuvL5fls4GoSyBeMjTwzsgI_cwogUV4Ky0BsbrswojGEcBMglDRMJ4A6jCiB6kFzTCl8PHL798_D12KwKgMMtT5CssKDsoqwKCdm7KWP7M8udPP0FlfEtAbvYSIXhEGEVEPeAZjOvVoKSInaYMPlsEN0SQBox7Q3qPDgzemUUevteqY3z_1QtLg_OGGN__FpSOf391UuhMThMEF9sM7mwT1agMgghByBF7YNUOjbIq-1tNrHphvB5DmChqz_eM748qjHOXSRfrzYR-vVw1aEOsc-3evmiqIm-KivH9PR-_C7a0aQ3LoZymqIt4l-nkcfJOIhH20F1unX2CJN_nCe3uywvjeyPkNEkYUfToKVvKXEcjo3EpRNKrKcRmSO-I1tfzf-FZMDK-ARofM8Ba3uNg7eA8ioBv6DO3XPnDzSCFhW5Wun8ITUATbCieYm2eZ3AI0Dsky_g2JLMsYUcVwAhlI9wOpZgJbz4tgBANxQS9dxPQPE3Oh2Sbb98UffM4oEcrRacxDqm5gFadZHzH-O6xMSx_PsAo3hAoCB-wB5EKd4pQhjiFcbLWk3d_pv9TqkFQgOdPL08bMEKOymIGh8T3P1oZ78VtstwRtgfppkv6KXORhbkAaXeG19cPJb8ljcTPI3qEA2hlT9Gwyi7RP3nr6ungL0nSK4JYys_2NhvQi4CM10UcxMXzP6VKi0YtQlDM-9COo3P97TxtBaS4D4Iy8WMOP4R3IkZD3LzLyvOoUVCyB8-zv0BRjFlQ3o-Kejm6VgOLUZbOzQE4jG72SfjraAm5TIp0xqgEgBwcwKjjGCCIE35fMR6hF5d0N64rSuQXpNmqb8u-KRuxwrbYbsqibqqyXI3t0HQir8XQbau6afq-KLGu-k7WeV8_dcVmpVqe8yoveV00RV2V2VPBh7LpN2LTbQWvt2yToxFKZ3GQMuePK0U0Y1uUZZVvV1p0qCm9ZpwnDRjn8WHzbZq8bj4S2-RaUaB7iqCCxvZqpPSC_fB2_b_nKvoljdxq9rp9Z8_d1uuDFxjfJyJJsYXLW8v_CQAA___1oJWi">