<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/133429>133429</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[llvm-mca] Add instruction customization
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
r-belenov
</td>
</tr>
</table>
<pre>
I'd like to get feedback on the idea of customizing properties of individual instruction (using custom private InstrDesc and callback in InstrBuilder::createInstruction). Most obvious use is to model cache misses by manual annotations in the input assembler code, but it also opens the door for "what-if" analysis during CPU design (thus generic customization seems better than just specifying the latency). I have internal implementation; primary idea is here - https://squidex.jugru.team/api/assets/srm/40f77a92-171d-425b-8174-8b306afb22fe/llvm-upside-down-cppconf2025.pdf - on slide 49 (slides in Russian, but the code should be clear). Still need to get approval to contribute the code from the employer, but first would like to know whether it may fit well in MCA code base.
</pre>
<img width="1" height="1" alt="" src="http://email.email.llvm.org/o/eJxUVM9u-zgPfBrlQjiwZbtxDj6kLQL08AM-fIt9AP2hY7Wy5BWpZLNPv5Dzyxa9BJFFD2eGQysidwmIo-hfRf--U5nnmMZUafQY4nWno72PH0IeLHj3hcARLsgwIVqtzBfEADwjOIsK4gQmE8fF_ePCBdYUV0zskMqNC9Zdnc3KgwvEKRt2MYCQQ6ZS_XgT1uSuihE-Ss07kgEVLBjl_dbOhcfNa3beYhLtSbQnk1AxfnyjCnncw69IDFFfXcwEmRAcFfZLtOjBKDMjLI4ICfQdFhUKMxVCZFUgqLTalIU1MygiXLTHBCZaFPINdGZwDMpThLhioK3axphgigmElLdZceUmISWooPydHIHNqYh9-9-fYLFYXwzgORNcMGBy5j8HNxZAiAuBRmZMwLMK8JmJgVY0broXqNLVK8Zg7pvsD5jVtdBmTKGYvaweFwwPWaJ9LRYvKt0fM3MEMyaECmbmlYqh8izkmf7KzuLf-898SXnPqBYhz2p15ZcImUpNKg-7ejoc1FFWzaGxVSd7XQ3NoasG3dYvatJSTijk2fvrUuWVnMXKxluozLqaGCZZy36_2gmqkiXyziJ0x2LL9n-bw_8zkVPhaXuRXMYANMfsLWgE41GlTf8f7LyHgGifWVXrmuJV-XI2MXByOjPCN8yU4rKdcFl9vGN6NppcIobb1uSZ_q8Qb3CbkWdMJQCLusPkGG7oS7Lh19vpgaoV4V7UJ1GfdnZs7bE9qh2OzaFrm5dmGPrdPDZt3b70duobYxv9Ypuul4Pu9HCY0L4cu50biz91K4emaYe636vO6GMztJPqe9N1R9HVuCjn98XffUyXnSPKODZt28njziuNnrbtljLgDbZbIWVZ9jRuQ9H5QqKrvSOmbxh27LfPwlazGCX6dzhZ-2N7f4R1l5Mff6bo4njOem_i8jsBzyCsKX6iYSHPG6GSpt-Mr6P8NwAA__-xVpDS">