[flang-commits] [flang] 9c54d76 - [flang][runtime] Signal new I/O error on floating-point input overflow
Peter Klausler via flang-commits
flang-commits at lists.llvm.org
Fri Jun 3 22:55:14 PDT 2022
Author: Peter Klausler
Date: 2022-06-03T22:55:03-07:00
New Revision: 9c54d76251163ecf5c56ce984542d3bcf36a3c16
URL: https://github.com/llvm/llvm-project/commit/9c54d76251163ecf5c56ce984542d3bcf36a3c16
DIFF: https://github.com/llvm/llvm-project/commit/9c54d76251163ecf5c56ce984542d3bcf36a3c16.diff
LOG: [flang][runtime] Signal new I/O error on floating-point input overflow
Besides raising the IEEE floating-point overflow exception, treat
a floating-point overflow on input as an I/O error catchable with
ERR=, IOSTAT=, &/or IOMSG=.
Differential Revision: https://reviews.llvm.org/D127022
Added:
Modified:
flang/include/flang/Runtime/iostat.h
flang/runtime/edit-input.cpp
flang/runtime/iostat.cpp
Removed:
################################################################################
diff --git a/flang/include/flang/Runtime/iostat.h b/flang/include/flang/Runtime/iostat.h
index 562efb73f96c9..c8154c1a32510 100644
--- a/flang/include/flang/Runtime/iostat.h
+++ b/flang/include/flang/Runtime/iostat.h
@@ -74,6 +74,7 @@ enum Iostat {
IostatBadWaitUnit,
IostatBOZInputOverflow,
IostatIntegerInputOverflow,
+ IostatRealInputOverflow,
};
const char *IostatErrorString(int);
diff --git a/flang/runtime/edit-input.cpp b/flang/runtime/edit-input.cpp
index 7e53b54f59949..3c8630cebc596 100644
--- a/flang/runtime/edit-input.cpp
+++ b/flang/runtime/edit-input.cpp
@@ -428,6 +428,9 @@ static bool TryFastPathRealInput(
io.HandleRelativePosition(p - str);
// Set FP exception flags
if (converted.flags != decimal::ConversionResultFlags::Exact) {
+ if (converted.flags & decimal::ConversionResultFlags::Overflow) {
+ return false; // let slow path deal with it
+ }
RaiseFPExceptions(converted.flags);
}
return true;
@@ -505,6 +508,10 @@ bool EditCommonRealInput(IoStatementState &io, const DataEdit &edit, void *n) {
converted.binary;
// Set FP exception flags
if (converted.flags != decimal::ConversionResultFlags::Exact) {
+ if (converted.flags & decimal::ConversionResultFlags::Overflow) {
+ io.GetIoErrorHandler().SignalError(IostatRealInputOverflow);
+ return false;
+ }
RaiseFPExceptions(converted.flags);
}
return true;
diff --git a/flang/runtime/iostat.cpp b/flang/runtime/iostat.cpp
index 5ab1ee435ef22..017be1c9164e0 100644
--- a/flang/runtime/iostat.cpp
+++ b/flang/runtime/iostat.cpp
@@ -92,6 +92,8 @@ const char *IostatErrorString(int iostat) {
return "B/O/Z input value overflows variable";
case IostatIntegerInputOverflow:
return "Integer input value overflows variable";
+ case IostatRealInputOverflow:
+ return "Real or complex input value overflows type";
default:
return nullptr;
}
More information about the flang-commits
mailing list