Skip to content

Commit 047302e

Browse files
committed
Merging r355825:
------------------------------------------------------------------------ r355825 | petarj | 2019-03-11 07:13:31 -0700 (Mon, 11 Mar 2019) | 10 lines [MIPS][microMIPS] Add a pattern to match TruncIntFP A pattern needed to match TruncIntFP was missing. This was causing multiple tests from llvm test suite to fail during compilation for micromips. Patch by Mirko Brkusanin. Differential Revision: https://reviews.llvm.org/D58722 ------------------------------------------------------------------------ llvm-svn: 358936
1 parent 25b6e82 commit 047302e

File tree

3 files changed

+426
-1
lines changed

3 files changed

+426
-1
lines changed

llvm/lib/Target/Mips/MicroMips32r6InstrInfo.td

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1040,7 +1040,7 @@ class TRUNC_L_D_MMR6_DESC : ABSS_FT_MMR6_DESC_BASE<"trunc.l.d", FGR64Opnd,
10401040
class TRUNC_W_S_MMR6_DESC : ABSS_FT_MMR6_DESC_BASE<"trunc.w.s", FGR32Opnd,
10411041
FGR32Opnd, II_TRUNC>;
10421042
class TRUNC_W_D_MMR6_DESC : ABSS_FT_MMR6_DESC_BASE<"trunc.w.d", FGR32Opnd,
1043-
AFGR64Opnd, II_TRUNC>;
1043+
FGR64Opnd, II_TRUNC>;
10441044
class SQRT_S_MMR6_DESC : ABSS_FT_MMR6_DESC_BASE<"sqrt.s", FGR32Opnd, FGR32Opnd,
10451045
II_SQRT_S, fsqrt>;
10461046
class SQRT_D_MMR6_DESC : ABSS_FT_MMR6_DESC_BASE<"sqrt.d", AFGR64Opnd, AFGR64Opnd,
@@ -1750,6 +1750,8 @@ def : MipsPat<(f32 fpimm0), (MTC1_MMR6 ZERO)>, ISA_MICROMIPS32R6;
17501750
def : MipsPat<(f32 fpimm0neg), (FNEG_S_MMR6 (MTC1_MMR6 ZERO))>, ISA_MICROMIPS32R6;
17511751
def : MipsPat<(MipsTruncIntFP FGR64Opnd:$src),
17521752
(TRUNC_W_D_MMR6 FGR64Opnd:$src)>, ISA_MICROMIPS32R6;
1753+
def : MipsPat<(MipsTruncIntFP FGR32Opnd:$src),
1754+
(TRUNC_W_S_MMR6 FGR32Opnd:$src)>, ISA_MICROMIPS32R6;
17531755

17541756
def : MipsPat<(and GPRMM16:$src, immZExtAndi16:$imm),
17551757
(ANDI16_MMR6 GPRMM16:$src, immZExtAndi16:$imm)>,

llvm/lib/Target/Mips/MicroMipsInstrFPU.td

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -425,6 +425,11 @@ def : MipsPat<(f64 (fpextend FGR32Opnd:$src)),
425425
def : MipsPat<(MipsTruncIntFP AFGR64Opnd:$src),
426426
(TRUNC_W_MM AFGR64Opnd:$src)>, ISA_MICROMIPS32_NOT_MIPS32R6,
427427
FGR_32;
428+
def : MipsPat<(MipsTruncIntFP FGR64Opnd:$src),
429+
(CVT_W_D64_MM FGR64Opnd:$src)>, ISA_MICROMIPS32_NOT_MIPS32R6,
430+
FGR_64;
431+
def : MipsPat<(MipsTruncIntFP FGR32Opnd:$src),
432+
(TRUNC_W_S_MM FGR32Opnd:$src)>, ISA_MICROMIPS32_NOT_MIPS32R6;
428433

429434
// Selects
430435
defm : MovzPats0<GPR32, FGR32, MOVZ_I_S_MM, SLT_MM, SLTu_MM, SLTi_MM, SLTiu_MM>,

0 commit comments

Comments
 (0)