From 7db0038ac038ffad9a3551b693d47513a20e6674 Mon Sep 17 00:00:00 2001 From: Akira Hatanaka Date: Wed, 7 Dec 2011 23:14:41 +0000 Subject: [PATCH] 32 to 64-bit zext pattern. llvm-svn: 146096 --- lib/Target/Mips/Mips64InstrInfo.td | 5 +++++ test/CodeGen/Mips/mips64ext.ll | 11 +++++++++++ 2 files changed, 16 insertions(+) create mode 100644 test/CodeGen/Mips/mips64ext.ll diff --git a/lib/Target/Mips/Mips64InstrInfo.td b/lib/Target/Mips/Mips64InstrInfo.td index bc9c5602cad..91c91022fd8 100644 --- a/lib/Target/Mips/Mips64InstrInfo.td +++ b/lib/Target/Mips/Mips64InstrInfo.td @@ -222,6 +222,9 @@ def DynAlloc64 : EffectiveAddress<"daddiu\t$rt, $addr", CPU64Regs, mem_ea_64>, def DEXT : ExtBase<3, "dext", CPU64Regs>; def DINS : InsBase<7, "dins", CPU64Regs>; +def DSLL64_32 : FR<0x3c, 0x00, (outs CPU64Regs:$rd), (ins CPURegs:$rt), + "dsll32\t$rd, $rt, 0", [], IIAlu>; + //===----------------------------------------------------------------------===// // Arbitrary patterns that map to one or more instructions //===----------------------------------------------------------------------===// @@ -296,3 +299,5 @@ def : Pat<(MipsDynAlloc addr:$f), (DynAlloc64 addr:$f)>, Requires<[IsN64]>; def : Pat<(i32 (trunc CPU64Regs:$src)), (SLL (EXTRACT_SUBREG CPU64Regs:$src, sub_32), 0)>, Requires<[IsN64]>; +// 32-to-64-bit extension +def : Pat<(i64 (zext CPURegs:$src)), (DSRL32 (DSLL64_32 CPURegs:$src), 0)>; diff --git a/test/CodeGen/Mips/mips64ext.ll b/test/CodeGen/Mips/mips64ext.ll new file mode 100644 index 00000000000..33af0d852da --- /dev/null +++ b/test/CodeGen/Mips/mips64ext.ll @@ -0,0 +1,11 @@ +; RUN: llc < %s -march=mips64el -mcpu=mips64 -mattr=n64 | FileCheck %s + +define i64 @zext64_32(i32 %a) nounwind readnone { +entry: +; CHECK: addiu $[[R0:[0-9]+]], ${{[0-9]+}}, 2 +; CHECK: dsll32 $[[R1:[0-9]+]], $[[R0]], 0 +; CHECK: dsrl32 ${{[0-9]+}}, $[[R1]], 0 + %add = add i32 %a, 2 + %conv = zext i32 %add to i64 + ret i64 %conv +}