From 199f41354c2998627f592a969bc5b31b5227a800 Mon Sep 17 00:00:00 2001 From: Eric Schweitz Date: Tue, 5 Nov 2019 23:39:25 -0800 Subject: [PATCH] Add support for the LLVM FNeg instruction Closes #216 COPYBARA_INTEGRATE_REVIEW=https://github.com/tensorflow/mlir/pull/216 from schweitzpgi:llvmir-fneg-op f9b5f185845d671b745ab6fc213d5d9aff044b34 PiperOrigin-RevId: 278795325 --- include/mlir/Dialect/LLVMIR/LLVMOps.td | 10 ++++++++++ test/Dialect/LLVMIR/roundtrip.mlir | 3 +++ test/Target/llvmir.mlir | 3 +++ 3 files changed, 16 insertions(+) diff --git a/include/mlir/Dialect/LLVMIR/LLVMOps.td b/include/mlir/Dialect/LLVMIR/LLVMOps.td index 13334cb4cb2a..29509268c7a1 100644 --- a/include/mlir/Dialect/LLVMIR/LLVMOps.td +++ b/include/mlir/Dialect/LLVMIR/LLVMOps.td @@ -132,6 +132,15 @@ class LLVM_ArithmeticOpgetOperation(), p); }]; } +class LLVM_UnaryArithmeticOp traits = []> : + LLVM_OneResultOp, + Arguments<(ins LLVM_Type:$operand)>, + LLVM_Builder<"$res = builder." # builderFunc # "($operand);"> { + let parser = [{ return impl::parseOneResultSameOperandTypeOp(parser, result); }]; + let printer = [{ mlir::impl::printOneResultOp(this->getOperation(), p); }]; +} // Integer binary operations. def LLVM_AddOp : LLVM_ArithmeticOp<"add", "CreateAdd", [Commutative]>; @@ -247,6 +256,7 @@ def LLVM_FSubOp : LLVM_ArithmeticOp<"fsub", "CreateFSub">; def LLVM_FMulOp : LLVM_ArithmeticOp<"fmul", "CreateFMul">; def LLVM_FDivOp : LLVM_ArithmeticOp<"fdiv", "CreateFDiv">; def LLVM_FRemOp : LLVM_ArithmeticOp<"frem", "CreateFRem">; +def LLVM_FNegOp : LLVM_UnaryArithmeticOp<"fneg", "CreateFNeg">; // Memory-related operations. def LLVM_AllocaOp : diff --git a/test/Dialect/LLVMIR/roundtrip.mlir b/test/Dialect/LLVMIR/roundtrip.mlir index 0bd839ea361c..d2ff888942ad 100644 --- a/test/Dialect/LLVMIR/roundtrip.mlir +++ b/test/Dialect/LLVMIR/roundtrip.mlir @@ -94,6 +94,9 @@ func @ops(%arg0 : !llvm.i32, %arg1 : !llvm.float) { %27 = llvm.fpext %arg1 : !llvm.float to !llvm.x86_fp80 %28 = llvm.fpext %arg1 : !llvm.float to !llvm.fp128 +// CHECK: %29 = llvm.fneg %arg1 : !llvm.float + %29 = llvm.fneg %arg1 : !llvm.float + // CHECK: llvm.return llvm.return } diff --git a/test/Target/llvmir.mlir b/test/Target/llvmir.mlir index f53d137475a6..8895668bfe55 100644 --- a/test/Target/llvmir.mlir +++ b/test/Target/llvmir.mlir @@ -811,6 +811,9 @@ llvm.func @ops(%arg0: !llvm.float, %arg1: !llvm.float, %arg2: !llvm.i32, %arg3: // CHECK-NEXT: %22 = ashr i32 %2, %3 %18 = llvm.ashr %arg2, %arg3 : !llvm.i32 +// CHECK-NEXT: fneg float %0 + %19 = llvm.fneg %arg0 : !llvm.float + llvm.return %10 : !llvm<"{ float, i32 }"> }