[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