
This PR changes the LLVM dialect's IntegerOverflowFlags to be stored on operations as native properties. Reland to fix flang
82 lines
3.2 KiB
C++
82 lines
3.2 KiB
C++
//===- AttrToLLVMConverter.cpp - Arith attributes conversion to LLVM ------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "mlir/Conversion/ArithCommon/AttrToLLVMConverter.h"
|
|
|
|
using namespace mlir;
|
|
|
|
LLVM::FastmathFlags
|
|
mlir::arith::convertArithFastMathFlagsToLLVM(arith::FastMathFlags arithFMF) {
|
|
LLVM::FastmathFlags llvmFMF{};
|
|
const std::pair<arith::FastMathFlags, LLVM::FastmathFlags> flags[] = {
|
|
{arith::FastMathFlags::nnan, LLVM::FastmathFlags::nnan},
|
|
{arith::FastMathFlags::ninf, LLVM::FastmathFlags::ninf},
|
|
{arith::FastMathFlags::nsz, LLVM::FastmathFlags::nsz},
|
|
{arith::FastMathFlags::arcp, LLVM::FastmathFlags::arcp},
|
|
{arith::FastMathFlags::contract, LLVM::FastmathFlags::contract},
|
|
{arith::FastMathFlags::afn, LLVM::FastmathFlags::afn},
|
|
{arith::FastMathFlags::reassoc, LLVM::FastmathFlags::reassoc}};
|
|
for (auto [arithFlag, llvmFlag] : flags) {
|
|
if (bitEnumContainsAny(arithFMF, arithFlag))
|
|
llvmFMF = llvmFMF | llvmFlag;
|
|
}
|
|
return llvmFMF;
|
|
}
|
|
|
|
LLVM::FastmathFlagsAttr
|
|
mlir::arith::convertArithFastMathAttrToLLVM(arith::FastMathFlagsAttr fmfAttr) {
|
|
arith::FastMathFlags arithFMF = fmfAttr.getValue();
|
|
return LLVM::FastmathFlagsAttr::get(
|
|
fmfAttr.getContext(), convertArithFastMathFlagsToLLVM(arithFMF));
|
|
}
|
|
|
|
LLVM::IntegerOverflowFlags mlir::arith::convertArithOverflowFlagsToLLVM(
|
|
arith::IntegerOverflowFlags arithFlags) {
|
|
LLVM::IntegerOverflowFlags llvmFlags{};
|
|
const std::pair<arith::IntegerOverflowFlags, LLVM::IntegerOverflowFlags>
|
|
flags[] = {
|
|
{arith::IntegerOverflowFlags::nsw, LLVM::IntegerOverflowFlags::nsw},
|
|
{arith::IntegerOverflowFlags::nuw, LLVM::IntegerOverflowFlags::nuw}};
|
|
for (auto [arithFlag, llvmFlag] : flags) {
|
|
if (bitEnumContainsAny(arithFlags, arithFlag))
|
|
llvmFlags = llvmFlags | llvmFlag;
|
|
}
|
|
return llvmFlags;
|
|
}
|
|
|
|
LLVM::RoundingMode
|
|
mlir::arith::convertArithRoundingModeToLLVM(arith::RoundingMode roundingMode) {
|
|
switch (roundingMode) {
|
|
case arith::RoundingMode::downward:
|
|
return LLVM::RoundingMode::TowardNegative;
|
|
case arith::RoundingMode::to_nearest_away:
|
|
return LLVM::RoundingMode::NearestTiesToAway;
|
|
case arith::RoundingMode::to_nearest_even:
|
|
return LLVM::RoundingMode::NearestTiesToEven;
|
|
case arith::RoundingMode::toward_zero:
|
|
return LLVM::RoundingMode::TowardZero;
|
|
case arith::RoundingMode::upward:
|
|
return LLVM::RoundingMode::TowardPositive;
|
|
}
|
|
llvm_unreachable("Unhandled rounding mode");
|
|
}
|
|
|
|
LLVM::RoundingModeAttr mlir::arith::convertArithRoundingModeAttrToLLVM(
|
|
arith::RoundingModeAttr roundingModeAttr) {
|
|
assert(roundingModeAttr && "Expecting valid attribute");
|
|
return LLVM::RoundingModeAttr::get(
|
|
roundingModeAttr.getContext(),
|
|
convertArithRoundingModeToLLVM(roundingModeAttr.getValue()));
|
|
}
|
|
|
|
LLVM::FPExceptionBehaviorAttr
|
|
mlir::arith::getLLVMDefaultFPExceptionBehavior(MLIRContext &context) {
|
|
return LLVM::FPExceptionBehaviorAttr::get(&context,
|
|
LLVM::FPExceptionBehavior::Ignore);
|
|
}
|