mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-03 13:31:05 +00:00
[AArch64] Extend the number of scalar instructions supported in the AdvSIMD
scalar integer instruction pass. This is a patch I had lying around from a few months ago. The pass is currently disabled by default, so nothing to interesting. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@214779 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a770bd6cae
commit
82c93451f3
@ -166,6 +166,12 @@ static int getTransformOpcode(unsigned Opc) {
|
||||
return AArch64::ADDv1i64;
|
||||
case AArch64::SUBXrr:
|
||||
return AArch64::SUBv1i64;
|
||||
case AArch64::ANDXrr:
|
||||
return AArch64::ANDv8i8;
|
||||
case AArch64::EORXrr:
|
||||
return AArch64::EORv8i8;
|
||||
case AArch64::ORRXrr:
|
||||
return AArch64::ORRv8i8;
|
||||
}
|
||||
// No AdvSIMD equivalent, so just return the original opcode.
|
||||
return Opc;
|
||||
|
@ -65,3 +65,44 @@ define double @add_sub_su64(<2 x i64> %a, <2 x i64> %b) nounwind readnone {
|
||||
%retval = bitcast i64 %sub.i to double
|
||||
ret double %retval
|
||||
}
|
||||
define double @and_su64(<2 x i64> %a, <2 x i64> %b) nounwind readnone {
|
||||
; CHECK-LABEL: and_su64:
|
||||
; CHECK: and.8b v0, v1, v0
|
||||
; CHECK-NEXT: ret
|
||||
; GENERIC-LABEL: and_su64:
|
||||
; GENERIC: and v0.8b, v1.8b, v0.8b
|
||||
; GENERIC-NEXT: ret
|
||||
%vecext = extractelement <2 x i64> %a, i32 0
|
||||
%vecext1 = extractelement <2 x i64> %b, i32 0
|
||||
%or.i = and i64 %vecext1, %vecext
|
||||
%retval = bitcast i64 %or.i to double
|
||||
ret double %retval
|
||||
}
|
||||
|
||||
define double @orr_su64(<2 x i64> %a, <2 x i64> %b) nounwind readnone {
|
||||
; CHECK-LABEL: orr_su64:
|
||||
; CHECK: orr.8b v0, v1, v0
|
||||
; CHECK-NEXT: ret
|
||||
; GENERIC-LABEL: orr_su64:
|
||||
; GENERIC: orr v0.8b, v1.8b, v0.8b
|
||||
; GENERIC-NEXT: ret
|
||||
%vecext = extractelement <2 x i64> %a, i32 0
|
||||
%vecext1 = extractelement <2 x i64> %b, i32 0
|
||||
%or.i = or i64 %vecext1, %vecext
|
||||
%retval = bitcast i64 %or.i to double
|
||||
ret double %retval
|
||||
}
|
||||
|
||||
define double @xorr_su64(<2 x i64> %a, <2 x i64> %b) nounwind readnone {
|
||||
; CHECK-LABEL: xorr_su64:
|
||||
; CHECK: eor.8b v0, v1, v0
|
||||
; CHECK-NEXT: ret
|
||||
; GENERIC-LABEL: xorr_su64:
|
||||
; GENERIC: eor v0.8b, v1.8b, v0.8b
|
||||
; GENERIC-NEXT: ret
|
||||
%vecext = extractelement <2 x i64> %a, i32 0
|
||||
%vecext1 = extractelement <2 x i64> %b, i32 0
|
||||
%xor.i = xor i64 %vecext1, %vecext
|
||||
%retval = bitcast i64 %xor.i to double
|
||||
ret double %retval
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user