<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/133517>133517</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[libc][math] Optimize fputil::cast for targets with fast half precision conversion
</td>
</tr>
<tr>
<th>Labels</th>
<td>
libc
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
meltq
</td>
</tr>
</table>
<pre>
`fputil::cast` lacks specialization for targets that have fast half precision to single precision conversions. This leads to the cast being emulated when it could be done using the much faster `static_cast`. This was observed to cause a slow down, during the performance testing of the `hypotf16` function being introduced [here](https://github.com/llvm/llvm-project/pull/131991).
</pre>
<img width="1" height="1" alt="" src="http://email.email.llvm.org/o/eJyUkj-P2zwMxj-NvBBvYEuREw8e7t4ga5fuhf7QkVrZckUqwd2nL-zr4dqiSycRFMmHfPAzRPG2II5CPwt9aUzlkMs4Y-Lvjc3-ZRR9O62VYxLqSagnZ4hF30Iy7hsBreiiSfHVcMwLTLkAm3JDJuBgGIK5I0yGtihNsBZ0kbZKzkBxuSX8JefycseyhXSAzyESJDSetloOCJsyWIzLDXCuyTB6eARcIDK4XJMHi-DzglC30XvPXF3Y9bGA6Ftiw9F9-XnDAd5UHoYgW8JyR7-JOVMJwQCl_ACfH4uQ_4Ov5X3oimXKZTaLQ2Ak3vJ52r9E34aXNfPU9ZtJU13cbszb2nHhkn116EHo54AFhb4IeQ7MK232yquQ11vkUO3B5VnIa0r39-e_teSv6FjI61pTEvLaqW4YOiGHQ-NH5Qc1mAbH7nRU3XA8n9omjGfbybOWUlllztoMk1dOyv6kTD_YdpiaOMpW6lbJs2yPJ90ept763hqppB6U1Z04tjibmA7bDodcbk0kqjh2Sunu1CRjMdGOj5QpWiek3EAq476zrTcSxzZFYvqYwJHTjtzeoC9CP8-Gg9AX-LRynOMrwp_Q_QbXI3L4K1cfDDW1pPGfnd1vo93b_bz7KH8EAAD__3zGDLg">