diff --git a/flang/lib/Lower/IntrinsicCall.cpp b/flang/lib/Lower/IntrinsicCall.cpp index 4e24eb4c17ad6..b6a8dddb08e9f 100644 --- a/flang/lib/Lower/IntrinsicCall.cpp +++ b/flang/lib/Lower/IntrinsicCall.cpp @@ -459,6 +459,7 @@ struct IntrinsicLibrary { mlir::Value genIand(mlir::Type, llvm::ArrayRef); mlir::Value genIbits(mlir::Type, llvm::ArrayRef); mlir::Value genIbset(mlir::Type, llvm::ArrayRef); + mlir::Value genIeor(mlir::Type, llvm::ArrayRef); mlir::Value genIshft(mlir::Type, llvm::ArrayRef); mlir::Value genIshftc(mlir::Type, llvm::ArrayRef); fir::ExtendedValue genLbound(mlir::Type, llvm::ArrayRef); @@ -635,6 +636,7 @@ static constexpr IntrinsicHandler handlers[]{ {"iand", &I::genIand}, {"ibits", &I::genIbits}, {"ibset", &I::genIbset}, + {"ieor", &I::genIeor}, {"ishft", &I::genIshft}, {"ishftc", &I::genIshftc}, {"len", @@ -1930,6 +1932,13 @@ mlir::Value IntrinsicLibrary::genIbset(mlir::Type resultType, return builder.create(loc, args[0], mask); } +// IEOR +mlir::Value IntrinsicLibrary::genIeor(mlir::Type resultType, + llvm::ArrayRef args) { + assert(args.size() == 2); + return builder.create(loc, args[0], args[1]); +} + // ISHFT mlir::Value IntrinsicLibrary::genIshft(mlir::Type resultType, llvm::ArrayRef args) { diff --git a/flang/test/Lower/Intrinsics/ieor.f90 b/flang/test/Lower/Intrinsics/ieor.f90 new file mode 100644 index 0000000000000..011bbb9d5cd2b --- /dev/null +++ b/flang/test/Lower/Intrinsics/ieor.f90 @@ -0,0 +1,9 @@ +! RUN: bbc -emit-fir %s -o - | FileCheck %s + +! CHECK-LABEL: ieor_test +subroutine ieor_test(a, b) + integer :: a, b + print *, ieor(a, b) + ! CHECK: %{{[0-9]+}} = arith.xori %{{[0-9]+}}, %{{[0-9]+}} : i{{(8|16|32|64|128)}} +end subroutine ieor_test +