forked from OSchip/llvm-project
[AArch64]Implement the copy of two FPR8 registers by using FMOVss of two FPR32 registers in copyPhysReg.
llvm-svn: 201061
This commit is contained in:
parent
0a43c2c393
commit
6e73761dc8
|
@ -132,6 +132,16 @@ void AArch64InstrInfo::copyPhysReg(MachineBasicBlock &MBB,
|
|||
.addImm(16);
|
||||
return;
|
||||
}
|
||||
} else if (AArch64::FPR8RegClass.contains(DestReg, SrcReg)) {
|
||||
// The copy of two FPR8 registers is implemented by the copy of two FPR32
|
||||
const TargetRegisterInfo *TRI = &getRegisterInfo();
|
||||
unsigned Dst = TRI->getMatchingSuperReg(DestReg, AArch64::sub_8,
|
||||
&AArch64::FPR32RegClass);
|
||||
unsigned Src = TRI->getMatchingSuperReg(SrcReg, AArch64::sub_8,
|
||||
&AArch64::FPR32RegClass);
|
||||
BuildMI(MBB, I, DL, get(AArch64::FMOVss), Dst)
|
||||
.addReg(Src);
|
||||
return;
|
||||
} else if (AArch64::FPR16RegClass.contains(DestReg, SrcReg)) {
|
||||
// The copy of two FPR16 registers is implemented by the copy of two FPR32
|
||||
const TargetRegisterInfo *TRI = &getRegisterInfo();
|
||||
|
|
|
@ -1291,6 +1291,19 @@ entry:
|
|||
ret <2 x i64> %vecinit2
|
||||
}
|
||||
|
||||
declare <1 x i8> @llvm.aarch64.neon.vsqadd.v1i8(<1 x i8>, <1 x i8>)
|
||||
|
||||
; This case tests the copy of two FPR8 registers, which is implemented by fmov
|
||||
; of two FPR32 registers.
|
||||
define <1 x i8> @test_copy_FPR8_FPR8(<1 x i8> %a, <1 x i8> %b) {
|
||||
; CHECK-LABEL: test_copy_FPR8_FPR8:
|
||||
; CHECK: usqadd b1, b0
|
||||
; CHECK-NEXT: fmov s0, s1
|
||||
entry:
|
||||
%vsqadd2.i = call <1 x i8> @llvm.aarch64.neon.vsqadd.v1i8(<1 x i8> %b, <1 x i8> %a)
|
||||
ret <1 x i8> %vsqadd2.i
|
||||
}
|
||||
|
||||
declare <1 x i16> @llvm.aarch64.neon.vsqadd.v1i16(<1 x i16>, <1 x i16>)
|
||||
|
||||
define <1 x i16> @test_copy_FPR16_FPR16(<1 x i16> %a, <1 x i16> %b) {
|
||||
|
|
Loading…
Reference in New Issue