forked from OSchip/llvm-project
ARM VDUPfd and VDUPfq can just be patterns. The instruction is the same
as for VDUP32d and VDUP32q, respectively. llvm-svn: 127489
This commit is contained in:
parent
6c609d626f
commit
59eea670f8
|
@ -4436,14 +4436,8 @@ def VDUP8q : VDUPQ<0b11101110, 0b00, "8", v16i8>;
|
|||
def VDUP16q : VDUPQ<0b11101010, 0b01, "16", v8i16>;
|
||||
def VDUP32q : VDUPQ<0b11101010, 0b00, "32", v4i32>;
|
||||
|
||||
def VDUPfd : NVDup<0b11101000, 0b1011, 0b00, (outs DPR:$V), (ins GPR:$R),
|
||||
IIC_VMOVIS, "vdup", "32", "$V, $R",
|
||||
[(set DPR:$V, (v2f32 (NEONvdup
|
||||
(f32 (bitconvert GPR:$R)))))]>;
|
||||
def VDUPfq : NVDup<0b11101010, 0b1011, 0b00, (outs QPR:$V), (ins GPR:$R),
|
||||
IIC_VMOVIS, "vdup", "32", "$V, $R",
|
||||
[(set QPR:$V, (v4f32 (NEONvdup
|
||||
(f32 (bitconvert GPR:$R)))))]>;
|
||||
def : Pat<(v2f32 (NEONvdup (f32 (bitconvert GPR:$R)))), (VDUP32d GPR:$R)>;
|
||||
def : Pat<(v4f32 (NEONvdup (f32 (bitconvert GPR:$R)))), (VDUP32q GPR:$R)>;
|
||||
|
||||
// VDUP : Vector Duplicate Lane (from scalar to all elements)
|
||||
|
||||
|
|
|
@ -1632,12 +1632,6 @@ ARMDEBackend::populateInstruction(const CodeGenInstruction &CGI,
|
|||
Name == "BLX_pred" || Name == "TPsoft")
|
||||
return false;
|
||||
|
||||
// Ignore VDUPf[d|q] instructions known to conflict with VDUP32[d-q] for
|
||||
// decoding. The instruction duplicates an element from an ARM core
|
||||
// register into every element of the destination vector. There is no
|
||||
// distinction between data types.
|
||||
if (Name == "VDUPfd" || Name == "VDUPfq") return false;
|
||||
|
||||
// A8-598: VEXT
|
||||
// Vector Extract extracts elements from the bottom end of the second
|
||||
// operand vector and the top end of the first, concatenates them and
|
||||
|
|
Loading…
Reference in New Issue