mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-23 20:29:30 +00:00
Also avoid pinsrw and pinsrb with a variable insertelement index.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@54803 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
44eb65cf58
commit
ef521f14b7
@ -4143,7 +4143,8 @@ X86TargetLowering::LowerINSERT_VECTOR_ELT_SSE4(SDValue Op, SelectionDAG &DAG){
|
|||||||
SDValue N1 = Op.getOperand(1);
|
SDValue N1 = Op.getOperand(1);
|
||||||
SDValue N2 = Op.getOperand(2);
|
SDValue N2 = Op.getOperand(2);
|
||||||
|
|
||||||
if ((EVT.getSizeInBits() == 8) || (EVT.getSizeInBits() == 16)) {
|
if ((EVT.getSizeInBits() == 8 || EVT.getSizeInBits() == 16) &&
|
||||||
|
isa<ConstantSDNode>(N2)) {
|
||||||
unsigned Opc = (EVT.getSizeInBits() == 8) ? X86ISD::PINSRB
|
unsigned Opc = (EVT.getSizeInBits() == 8) ? X86ISD::PINSRB
|
||||||
: X86ISD::PINSRW;
|
: X86ISD::PINSRW;
|
||||||
// Transform it so it match pinsr{b,w} which expects a GR32 as its second
|
// Transform it so it match pinsr{b,w} which expects a GR32 as its second
|
||||||
|
Loading…
x
Reference in New Issue
Block a user