mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-03 05:41:42 +00:00
Add VCMPZ and VABS.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@116383 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
67be08a2f1
commit
1fc6d8837f
@ -175,23 +175,6 @@ class ADuI_Encode<bits<5> opcod1, bits<2> opcod2, bits<4> opcod3,
|
|||||||
let Inst{22} = Dd{4};
|
let Inst{22} = Dd{4};
|
||||||
}
|
}
|
||||||
|
|
||||||
class ASuI_Encode<bits<5> opcod1, bits<2> opcod2, bits<4> opcod3,
|
|
||||||
bits<2> opcod4, bit opcod5, dag oops, dag iops,
|
|
||||||
InstrItinClass itin, string opc, string asm,
|
|
||||||
list<dag> pattern>
|
|
||||||
: ASuI<opcod1, opcod2, opcod3, opcod4, opcod5, oops, iops, itin, opc,
|
|
||||||
asm, pattern> {
|
|
||||||
// Instruction operands.
|
|
||||||
bits<5> Sd;
|
|
||||||
bits<5> Sm;
|
|
||||||
|
|
||||||
// Encode instruction operands.
|
|
||||||
let Inst{3-0} = Sm{4-1};
|
|
||||||
let Inst{5} = Sm{0};
|
|
||||||
let Inst{15-12} = Sd{4-1};
|
|
||||||
let Inst{22} = Sd{0};
|
|
||||||
}
|
|
||||||
|
|
||||||
class ASbI_Encode<bits<5> opcod1, bits<2> opcod2, bit op6, bit op4, dag oops,
|
class ASbI_Encode<bits<5> opcod1, bits<2> opcod2, bit op6, bit op4, dag oops,
|
||||||
dag iops, InstrItinClass itin, string opc, string asm,
|
dag iops, InstrItinClass itin, string opc, string asm,
|
||||||
list<dag> pattern>
|
list<dag> pattern>
|
||||||
@ -228,6 +211,40 @@ class ASbIn_Encode<bits<5> opcod1, bits<2> opcod2, bit op6, bit op4, dag oops,
|
|||||||
let Inst{22} = Sd{0};
|
let Inst{22} = Sd{0};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class ASuI_Encode<bits<5> opcod1, bits<2> opcod2, bits<4> opcod3,
|
||||||
|
bits<2> opcod4, bit opcod5, dag oops, dag iops,
|
||||||
|
InstrItinClass itin, string opc, string asm,
|
||||||
|
list<dag> pattern>
|
||||||
|
: ASuI<opcod1, opcod2, opcod3, opcod4, opcod5, oops, iops, itin, opc,
|
||||||
|
asm, pattern> {
|
||||||
|
// Instruction operands.
|
||||||
|
bits<5> Sd;
|
||||||
|
bits<5> Sm;
|
||||||
|
|
||||||
|
// Encode instruction operands.
|
||||||
|
let Inst{3-0} = Sm{4-1};
|
||||||
|
let Inst{5} = Sm{0};
|
||||||
|
let Inst{15-12} = Sd{4-1};
|
||||||
|
let Inst{22} = Sd{0};
|
||||||
|
}
|
||||||
|
|
||||||
|
class ASuIn_Encode<bits<5> opcod1, bits<2> opcod2, bits<4> opcod3,
|
||||||
|
bits<2> opcod4, bit opcod5, dag oops, dag iops,
|
||||||
|
InstrItinClass itin, string opc, string asm,
|
||||||
|
list<dag> pattern>
|
||||||
|
: ASuIn<opcod1, opcod2, opcod3, opcod4, opcod5, oops, iops, itin, opc,
|
||||||
|
asm, pattern> {
|
||||||
|
// Instruction operands.
|
||||||
|
bits<5> Sd;
|
||||||
|
bits<5> Sm;
|
||||||
|
|
||||||
|
// Encode instruction operands.
|
||||||
|
let Inst{3-0} = Sm{4-1};
|
||||||
|
let Inst{5} = Sm{0};
|
||||||
|
let Inst{15-12} = Sd{4-1};
|
||||||
|
let Inst{22} = Sd{0};
|
||||||
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// FP Binary Operations.
|
// FP Binary Operations.
|
||||||
//
|
//
|
||||||
@ -313,27 +330,37 @@ def VCMPS : ASuI<0b11101, 0b11, 0b0100, 0b01, 0, (outs), (ins SPR:$a, SPR:$b),
|
|||||||
// FP Unary Operations.
|
// FP Unary Operations.
|
||||||
//
|
//
|
||||||
|
|
||||||
def VABSD : ADuI<0b11101, 0b11, 0b0000, 0b11, 0, (outs DPR:$dst), (ins DPR:$a),
|
def VABSD : ADuI_Encode<0b11101, 0b11, 0b0000, 0b11, 0,
|
||||||
IIC_fpUNA64, "vabs", ".f64\t$dst, $a",
|
(outs DPR:$Dd), (ins DPR:$Dm),
|
||||||
[(set DPR:$dst, (fabs (f64 DPR:$a)))]>;
|
IIC_fpUNA64, "vabs", ".f64\t$Dd, $Dm",
|
||||||
|
[(set DPR:$Dd, (fabs (f64 DPR:$Dm)))]>;
|
||||||
|
|
||||||
def VABSS : ASuIn<0b11101, 0b11, 0b0000, 0b11, 0,(outs SPR:$dst), (ins SPR:$a),
|
def VABSS : ASuIn_Encode<0b11101, 0b11, 0b0000, 0b11, 0,
|
||||||
IIC_fpUNA32, "vabs", ".f32\t$dst, $a",
|
(outs SPR:$Sd), (ins SPR:$Sm),
|
||||||
[(set SPR:$dst, (fabs SPR:$a))]>;
|
IIC_fpUNA32, "vabs", ".f32\t$Sd, $Sm",
|
||||||
|
[(set SPR:$Sd, (fabs SPR:$Sm))]>;
|
||||||
|
|
||||||
let Defs = [FPSCR] in {
|
let Defs = [FPSCR] in {
|
||||||
def VCMPEZD : ADuI<0b11101, 0b11, 0b0101, 0b11, 0, (outs), (ins DPR:$a),
|
def VCMPEZD : ADuI_Encode<0b11101, 0b11, 0b0101, 0b11, 0,
|
||||||
IIC_fpCMP64, "vcmpe", ".f64\t$a, #0",
|
(outs), (ins DPR:$Dd),
|
||||||
[(arm_cmpfp0 (f64 DPR:$a))]>;
|
IIC_fpCMP64, "vcmpe", ".f64\t$Dd, #0",
|
||||||
|
[(arm_cmpfp0 (f64 DPR:$Dd))]> {
|
||||||
|
let Inst{3-0} = 0b0000;
|
||||||
|
let Inst{5} = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
def VCMPEZS : ASuI_Encode<0b11101, 0b11, 0b0101, 0b11, 0,
|
||||||
|
(outs), (ins SPR:$Sd),
|
||||||
|
IIC_fpCMP32, "vcmpe", ".f32\t$Sd, #0",
|
||||||
|
[(arm_cmpfp0 SPR:$Sd)]> {
|
||||||
|
let Inst{3-0} = 0b0000;
|
||||||
|
let Inst{5} = 0;
|
||||||
|
}
|
||||||
|
|
||||||
def VCMPZD : ADuI<0b11101, 0b11, 0b0101, 0b01, 0, (outs), (ins DPR:$a),
|
def VCMPZD : ADuI<0b11101, 0b11, 0b0101, 0b01, 0, (outs), (ins DPR:$a),
|
||||||
IIC_fpCMP64, "vcmp", ".f64\t$a, #0",
|
IIC_fpCMP64, "vcmp", ".f64\t$a, #0",
|
||||||
[/* For disassembly only; pattern left blank */]>;
|
[/* For disassembly only; pattern left blank */]>;
|
||||||
|
|
||||||
def VCMPEZS : ASuI<0b11101, 0b11, 0b0101, 0b11, 0, (outs), (ins SPR:$a),
|
|
||||||
IIC_fpCMP32, "vcmpe", ".f32\t$a, #0",
|
|
||||||
[(arm_cmpfp0 SPR:$a)]>;
|
|
||||||
|
|
||||||
def VCMPZS : ASuI<0b11101, 0b11, 0b0101, 0b01, 0, (outs), (ins SPR:$a),
|
def VCMPZS : ASuI<0b11101, 0b11, 0b0101, 0b01, 0, (outs), (ins SPR:$a),
|
||||||
IIC_fpCMP32, "vcmp", ".f32\t$a, #0",
|
IIC_fpCMP32, "vcmp", ".f32\t$a, #0",
|
||||||
[/* For disassembly only; pattern left blank */]>;
|
[/* For disassembly only; pattern left blank */]>;
|
||||||
|
@ -104,3 +104,39 @@ entry:
|
|||||||
%cmp = fcmp oeq float %a, %b
|
%cmp = fcmp oeq float %a, %b
|
||||||
ret i1 %cmp
|
ret i1 %cmp
|
||||||
}
|
}
|
||||||
|
|
||||||
|
define i1 @f13(double %a) nounwind readnone {
|
||||||
|
entry:
|
||||||
|
; CHECK: f13
|
||||||
|
; CHECK: vcmpe.f64 d16, #0 @ encoding: [0xc0,0x0b,0xf5,0xee]
|
||||||
|
%cmp = fcmp oeq double %a, 0.000000e+00
|
||||||
|
ret i1 %cmp
|
||||||
|
}
|
||||||
|
|
||||||
|
define i1 @f14(float %a) nounwind readnone {
|
||||||
|
entry:
|
||||||
|
; CHECK: f14
|
||||||
|
; CHECK: vcmpe.f32 s0, #0 @ encoding: [0xc0,0x0a,0xb5,0xee]
|
||||||
|
%cmp = fcmp oeq float %a, 0.000000e+00
|
||||||
|
ret i1 %cmp
|
||||||
|
}
|
||||||
|
|
||||||
|
define double @f15(double %a) nounwind {
|
||||||
|
entry:
|
||||||
|
; CHECK: f15
|
||||||
|
; CHECK: vabs.f64 d16, d16 @ encoding: [0xe0,0x0b,0xf0,0xee]
|
||||||
|
%call = tail call double @fabsl(double %a)
|
||||||
|
ret double %call
|
||||||
|
}
|
||||||
|
|
||||||
|
declare double @fabsl(double)
|
||||||
|
|
||||||
|
define float @f16(float %a) nounwind {
|
||||||
|
entry:
|
||||||
|
; CHECK: f16
|
||||||
|
; This call generates a "bfc" instruction instead of "vabs.f32".
|
||||||
|
%call = tail call float @fabsf(float %a)
|
||||||
|
ret float %call
|
||||||
|
}
|
||||||
|
|
||||||
|
declare float @fabsf(float)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user