Skip to content
  • Craig Topper's avatar
    5440b63f
    [X86] Teach LowerMUL/LowerMULH for vXi8 to unpack constant RHS. · 5440b63f
    Craig Topper authored
    Summary:
    We need to unpackl and unpackh the operands to use two vXi16 multiplies. Previously it looks like the low unpack would get constant folded at least in the 128-bit case after shuffle lowering turned the unpackl into ZERO_EXTEND_VECTOR_INREG and X86 custom DAG combined it. The same doesn't happen for the high half. So we'd load a constant and then shuffle it. But the low half would just be loaded and used by the multiply directly.
    
    After this patch we now end up with a constant pool entry for the low and high unpacks separately with no shuffle operations.
    
    This is a step towards removing custom constant folding for ZERO_EXTEND_VECTOR_INREG/SIGN_EXTEND_VECTOR_INREG in the X86 backend.
    
    Reviewers: RKSimon, spatel
    
    Reviewed By: RKSimon
    
    Subscribers: llvm-commits
    
    Differential Revision: https://reviews.llvm.org/D55165
    
    llvm-svn: 348159
    5440b63f
    [X86] Teach LowerMUL/LowerMULH for vXi8 to unpack constant RHS.
    Craig Topper authored
    Summary:
    We need to unpackl and unpackh the operands to use two vXi16 multiplies. Previously it looks like the low unpack would get constant folded at least in the 128-bit case after shuffle lowering turned the unpackl into ZERO_EXTEND_VECTOR_INREG and X86 custom DAG combined it. The same doesn't happen for the high half. So we'd load a constant and then shuffle it. But the low half would just be loaded and used by the multiply directly.
    
    After this patch we now end up with a constant pool entry for the low and high unpacks separately with no shuffle operations.
    
    This is a step towards removing custom constant folding for ZERO_EXTEND_VECTOR_INREG/SIGN_EXTEND_VECTOR_INREG in the X86 backend.
    
    Reviewers: RKSimon, spatel
    
    Reviewed By: RKSimon
    
    Subscribers: llvm-commits
    
    Differential Revision: https://reviews.llvm.org/D55165
    
    llvm-svn: 348159
Loading