mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
Add patterns for matching immediates whose lower 16-bit is cleared. These
patterns emit a single LUi instruction instead of a pair of LUi and ORi. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@146900 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
1e2ec6abd4
commit
f06cb2b207
@ -225,6 +225,8 @@ def : Pat<(i64 immSExt16:$in),
|
||||
(DADDiu ZERO_64, imm:$in)>;
|
||||
def : Pat<(i64 immZExt16:$in),
|
||||
(ORi64 ZERO_64, imm:$in)>;
|
||||
def : Pat<(i64 immLUiOpnd:$in),
|
||||
(LUi64 (HI16 imm:$in))>;
|
||||
|
||||
// 32-bit immediates
|
||||
def : Pat<(i64 immSExt32:$imm),
|
||||
|
@ -219,6 +219,12 @@ def immZExt16 : PatLeaf<(imm), [{
|
||||
return (uint64_t)N->getZExtValue() == (unsigned short)N->getZExtValue();
|
||||
}], LO16>;
|
||||
|
||||
// Immediate can be loaded with LUi (32-bit int with lower 16-bit cleared).
|
||||
def immLUiOpnd : PatLeaf<(imm), [{
|
||||
int64_t Val = N->getSExtValue();
|
||||
return isInt<32>(Val) && !(Val & 0xffff);
|
||||
}]>;
|
||||
|
||||
// shamt field must fit in 5 bits.
|
||||
def immZExt5 : ImmLeaf<i32, [{return Imm == (Imm & 0x1f);}]>;
|
||||
|
||||
@ -933,6 +939,8 @@ def : Pat<(i32 immSExt16:$in),
|
||||
(ADDiu ZERO, imm:$in)>;
|
||||
def : Pat<(i32 immZExt16:$in),
|
||||
(ORi ZERO, imm:$in)>;
|
||||
def : Pat<(i32 immLUiOpnd:$in),
|
||||
(LUi (HI16 imm:$in))>;
|
||||
|
||||
// Arbitrary immediates
|
||||
def : Pat<(i32 imm:$imm),
|
||||
|
@ -5,9 +5,8 @@
|
||||
define double @func0(double %d0, double %d1) nounwind readnone {
|
||||
entry:
|
||||
; MIPS32-EL: func0:
|
||||
; MIPS32-EL: lui $[[T1:[0-9]+]], 32768
|
||||
; MIPS32-EL: ori $[[MSK1:[0-9]+]], $[[T1]], 0
|
||||
; MIPS32-EL: mfc1 $[[HI0:[0-9]+]], $f15
|
||||
; MIPS32-EL: lui $[[MSK1:[0-9]+]], 32768
|
||||
; MIPS32-EL: and $[[AND1:[0-9]+]], $[[HI0]], $[[MSK1]]
|
||||
; MIPS32-EL: lui $[[T0:[0-9]+]], 32767
|
||||
; MIPS32-EL: ori $[[MSK0:[0-9]+]], $[[T0]], 65535
|
||||
@ -18,9 +17,8 @@ entry:
|
||||
; MIPS32-EL: mtc1 $[[LO0]], $f0
|
||||
; MIPS32-EL: mtc1 $[[OR]], $f1
|
||||
;
|
||||
; MIPS32-EB: lui $[[T1:[0-9]+]], 32768
|
||||
; MIPS32-EB: ori $[[MSK1:[0-9]+]], $[[T1]], 0
|
||||
; MIPS32-EB: mfc1 $[[HI1:[0-9]+]], $f14
|
||||
; MIPS32-EB: lui $[[MSK1:[0-9]+]], 32768
|
||||
; MIPS32-EB: and $[[AND1:[0-9]+]], $[[HI1]], $[[MSK1]]
|
||||
; MIPS32-EB: lui $[[T0:[0-9]+]], 32767
|
||||
; MIPS32-EB: ori $[[MSK0:[0-9]+]], $[[T0]], 65535
|
||||
@ -46,9 +44,8 @@ declare double @copysign(double, double) nounwind readnone
|
||||
define float @func1(float %f0, float %f1) nounwind readnone {
|
||||
entry:
|
||||
; MIPS32-EL: func1:
|
||||
; MIPS32-EL: lui $[[T1:[0-9]+]], 32768
|
||||
; MIPS32-EL: ori $[[MSK1:[0-9]+]], $[[T1]], 0
|
||||
; MIPS32-EL: mfc1 $[[ARG1:[0-9]+]], $f14
|
||||
; MIPS32-EL: lui $[[MSK1:[0-9]+]], 32768
|
||||
; MIPS32-EL: and $[[T3:[0-9]+]], $[[ARG1]], $[[MSK1]]
|
||||
; MIPS32-EL: lui $[[T0:[0-9]+]], 32767
|
||||
; MIPS32-EL: ori $[[MSK0:[0-9]+]], $[[T0]], 65535
|
||||
|
@ -1,5 +1,13 @@
|
||||
; RUN: llc -march=mips64el -mcpu=mips64 < %s | FileCheck %s
|
||||
|
||||
define i32 @foo1() nounwind readnone {
|
||||
entry:
|
||||
; CHECK: foo1
|
||||
; CHECK: lui ${{[0-9]+}}, 4660
|
||||
; CHECK-NOT: ori
|
||||
ret i32 305397760
|
||||
}
|
||||
|
||||
define i64 @foo3() nounwind readnone {
|
||||
entry:
|
||||
; CHECK: foo3
|
||||
|
Loading…
Reference in New Issue
Block a user