<table border="1" cellspacing="0" cellpadding="8">
    <tr>
        <th>Issue</th>
        <td>
            <a href=https://github.com/llvm/llvm-project/issues/98272>98272</a>
        </td>
    </tr>

    <tr>
        <th>Summary</th>
        <td>
            X86: Delete MMX types/intrinsics from LLVM IR/backends
        </td>
    </tr>

    <tr>
      <th>Labels</th>
      <td>
            backend:X86
      </td>
    </tr>

    <tr>
      <th>Assignees</th>
      <td>
      </td>
    </tr>

    <tr>
      <th>Reporter</th>
      <td>
          jyknight
      </td>
    </tr>
</table>

<pre>
    This issue is about removing IR and SelectionDAG/Codegen support. Assembler support should remain.

Previous discussion on discourse [Proposal to remove MMX support](https://discourse.llvm.org/t/proposal-to-remove-mmx-support/56304)

The idea is, at the LLVM level, to keep only minimal support for the inlineasm "y" constraints, and remove as much of the rest as possible.

Overall plan:
1. Delete all support for 3dNow! (PR #96246)
2. Delete the `x86_mmx` type from IR. Can be done by using (at the IR level only) a standard vector type, `<1 x i64>`, instead. Notably, Clang already uses `<1 x i64>` for everything except where required to interface with mmx intrinsics and inline-asm. The conversion for those interfaces can be pushed down into SelectionDAG instead. (PR for this pending)
3. Migrate Clang-side MMX builtins to be backed by SSE2 instead of MMX (bug #41665, PR #96540), so they can continue to work without requiring the MMX intrinsic functions in IR (and as a bonus, they'll likely get faster, too).
4. Delete the IR-side MMX intrinsic functions.
   - Open question: how to deal with bitcode backwards compatibility for these? Maybe simplest to convert the intrinsics to inline-asm in autoupgrade.
5. Delete as much of the remaining X86 backend code related to MMX as possible, without breaking inline asm "y" constraints.
6. Decide whether to do anything about inserting EMMS instructions (bug #41664). At this point, it'd be only relevant to inline-asm. So we could potentially insert such an instruction directly after all inline-asm which have MMX register inputs/outputs/clobbers. Or we could also (continue to) not bother.

@efriedma-quic @phoebewang @topperc @RKSimon
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJx0Vt9y2joTfxpxs4PHyGDMBReUlG8yX9N2ks6Z3p2RrQWrkSVXWkP89mfWNiSc6blJsIx29_dnd1ExmpND3IrVJ7F6mKmOah-2v_pXZ041zUqv--2P2kQwMXYIJoIqfUcQsPFn407w-AzKaXhBixUZ7x52_xPysPcaT-ggdm3rAyWwixGb0mK4HkGsfWc1B1LGJSJ9EOlu_Ps94Nn4LoI2sepiNN6Bd8OT70JEEKtP34NvfVQWyI-1IDw9_bwGF6sHIYuaqI0i2wl5EPJwu55Ye24SH05CHkjIQzuFmpOfj6HmTfM2v4aSh1WepUshNx9r_FEjGI0KTBRyD4qAaoQvX_56AotntHxIHl4RW_DO9tAYZxplb_CPPgxXjLPGoYoNCCl7ISVU3kUKyjgaQzt9RagiNF1Vgz8OVwNG4rPWx2hKi3ckfjtjUNZCa5VjDobDRQIPaJEQ-NXHUjL91V-EXICQxfdnEDLb5HKZ31DL203OLPL0rcj_bpo3kadAfYtwDL6Bx-cE9spBiaC9Qyh76CK7RMhioujxeSRoYEXIDSiIpJxWQcMZK2Ja-hYZuchTke0X8AYmX4rsMz_LPRgXCZVO4KsnVXKQPeytcidQNqDSnBPjn24PSPGMoaeaq8K3CluCS42B2fzdmYCaZTOOMBxVhXAxVEPTvPFRMC6aKg6KjLLNVWwSYC9U3p0xDFYdlfUR38NEqEZW2i7WqEH7i-O3_q5v3pGNIoyBTIQWnTbudBMjS-DJnIIiHIHPo9Gj_8vOWDIuMogSoVTVK2qW4eXls7zGZ__wl4Usyo61yZaLPF8xj1fpV8uUs8k9RM-y9QOAyjsyrkOOfvHhdWBnnAbMHVPKEnPsG11w7NwAMIJxrD5bwWn2rYLSu24wOacQcm0tWPOKtocTEhxVJAxjJ3khN5O_l3dWfHx-R_-HpNMdAJjDtxYd_O4w8huR7aD2F4aiUdlR6NJQ5fXI20UFHaHyTavIlMYa6q9NG1FkB3hSfYkQTdNabkTykwlo6uubXwZDXe3CLKiOfNeegtLXnl29N-a_e5zHIzP7s8hHPZ2GociAVtHoVwb_YRAwZVdpyoDqle-PJcB_TJqpjpzrqJjPS41UYxj48aDc1DLj9DcuYiB-_vz09DL4KnSTyveu4rmZwI4mI3vjaOhhEnKt2aLDcAxo8awc3VOVwIuHC_cWL4rWEzoyytp-yg-RiVLuY37QJmBFtgd1JAzDnPtA_qU2VQ21mtZFwJNhj4Fxbcfj9uA7mj5V1pclhpjAt_BehbLRM8QPrcBDzHmC0jNhd0NYLFM8BoO6UfPfnalALNO29ljiheeVWKbk2xbD8OL5_y-m8W6mt5neZBs1w-1iLdNVURRpPqu3BcrFcVkVm1Um11VR5Hot5WatjpvqWC2KdGa2MpXLdL1I05VM02WiN8fFIsUqX2OxKBeay2mUsbcNOBu2-nZTyLWcWVWijcMvASknp4ls97PIhZT84yBs-d687E5RLFNrIsX3SGTI4pa_nO2uXmaKeZgznR_6YVgVw6p8fBbyMKWKsy7Y7f3OPhmquzKpfCPkgVNN_-Zt8L-w4uU8IOAEI4jzVv4TAAD__4nD9VE">