mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-01 00:33:09 +00:00
[PowerPC] Expand v2i64 shifts
These operations need to be expanded during legalization so that isel does not crash. In theory, we might be able to custom lower some of these. That, however, would need to be follow-up work. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@204963 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b5e6ddca56
commit
276d854549
@ -581,6 +581,10 @@ PPCTargetLowering::PPCTargetLowering(PPCTargetMachine &TM)
|
||||
setOperationAction(ISD::ADD, MVT::v2i64, Expand);
|
||||
setOperationAction(ISD::SUB, MVT::v2i64, Expand);
|
||||
|
||||
setOperationAction(ISD::SHL, MVT::v2i64, Expand);
|
||||
setOperationAction(ISD::SRA, MVT::v2i64, Expand);
|
||||
setOperationAction(ISD::SRL, MVT::v2i64, Expand);
|
||||
|
||||
setOperationAction(ISD::LOAD, MVT::v2i64, Promote);
|
||||
AddPromotedToType (ISD::LOAD, MVT::v2i64, MVT::v2f64);
|
||||
setOperationAction(ISD::STORE, MVT::v2i64, Promote);
|
||||
|
@ -487,3 +487,45 @@ define <2 x i64> @test56(<2 x i64> %a, <2 x i64> %b) {
|
||||
; CHECK: blr
|
||||
}
|
||||
|
||||
define <2 x i64> @test60(<2 x i64> %a, <2 x i64> %b) {
|
||||
%v = shl <2 x i64> %a, %b
|
||||
ret <2 x i64> %v
|
||||
|
||||
; CHECK-LABEL: @test60
|
||||
; This should scalarize, and the current code quality is not good.
|
||||
; CHECK: stxvd2x
|
||||
; CHECK: stxvd2x
|
||||
; CHECK: sld
|
||||
; CHECK: sld
|
||||
; CHECK: lxvd2x
|
||||
; CHECK: blr
|
||||
}
|
||||
|
||||
define <2 x i64> @test61(<2 x i64> %a, <2 x i64> %b) {
|
||||
%v = lshr <2 x i64> %a, %b
|
||||
ret <2 x i64> %v
|
||||
|
||||
; CHECK-LABEL: @test61
|
||||
; This should scalarize, and the current code quality is not good.
|
||||
; CHECK: stxvd2x
|
||||
; CHECK: stxvd2x
|
||||
; CHECK: srd
|
||||
; CHECK: srd
|
||||
; CHECK: lxvd2x
|
||||
; CHECK: blr
|
||||
}
|
||||
|
||||
define <2 x i64> @test62(<2 x i64> %a, <2 x i64> %b) {
|
||||
%v = ashr <2 x i64> %a, %b
|
||||
ret <2 x i64> %v
|
||||
|
||||
; CHECK-LABEL: @test62
|
||||
; This should scalarize, and the current code quality is not good.
|
||||
; CHECK: stxvd2x
|
||||
; CHECK: stxvd2x
|
||||
; CHECK: srad
|
||||
; CHECK: srad
|
||||
; CHECK: lxvd2x
|
||||
; CHECK: blr
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user