mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-03 09:28:58 +00:00
Don't use %g0 to materialize 0 directly.
The wired physreg doesn't work on tied operands like on MOVXCC. Add a README note to fix this later. llvm-svn: 182225
This commit is contained in:
parent
f4ec84c2d4
commit
50d419ac93
@ -57,3 +57,5 @@ int %t1(int %a, int %b) {
|
||||
* Fill delay slots
|
||||
|
||||
* Implement JIT support
|
||||
|
||||
* Use %g0 directly to materialize 0. No instruction is required.
|
||||
|
@ -59,10 +59,6 @@ defm SRAX : F3_S<"srax", 0b100111, 1, sra, i64, I64Regs>;
|
||||
// preferable to use a constant pool load instead, depending on the
|
||||
// microarchitecture.
|
||||
|
||||
// The %g0 register is constant 0.
|
||||
// This is useful for stx %g0, [...], for example.
|
||||
def : Pat<(i64 0), (i64 G0)>, Requires<[Is64Bit]>;
|
||||
|
||||
// Single-instruction patterns.
|
||||
|
||||
// The ALU instructions want their simm13 operands as i32 immediates.
|
||||
|
@ -26,7 +26,7 @@ define i64 @sra_reg(i64 %a, i64 %b) {
|
||||
; restore %g0, %g0, %o0
|
||||
;
|
||||
; CHECK: ret_imm0
|
||||
; CHECK: or %g0, %g0, %i0
|
||||
; CHECK: or %g0, 0, %i0
|
||||
define i64 @ret_imm0() {
|
||||
ret i64 0
|
||||
}
|
||||
|
@ -98,3 +98,14 @@ entry:
|
||||
%rv = select i1 %tobool, double %a, double %b
|
||||
ret double %rv
|
||||
}
|
||||
|
||||
; The MOVXCC instruction can't use %g0 for its tied operand.
|
||||
; CHECK: select_consti64_xcc
|
||||
; CHECK: subcc
|
||||
; CHECK: movg %xcc, 123, %i0
|
||||
define i64 @select_consti64_xcc(i64 %x, i64 %y) {
|
||||
entry:
|
||||
%tobool = icmp sgt i64 %x, %y
|
||||
%rv = select i1 %tobool, i64 123, i64 0
|
||||
ret i64 %rv
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user