Skip to content

Commit

Permalink
Tweak POSIX fail on EOF to kill heisenbug (#4035)
Browse files Browse the repository at this point in the history
Tweak POSIX fail on EOF to kill heisenbug
  • Loading branch information
eisenhauer authored Feb 20, 2024
1 parent d943ecb commit d44c52d
Showing 1 changed file with 13 additions and 5 deletions.
18 changes: 13 additions & 5 deletions source/adios2/toolkit/transport/file/FilePOSIX.cpp
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
/*
* Distributed under the OSI-approved Apache License, Version 2.0. See
* accompanying file Copyright.txt for details.
*
* FilePOSIX.cpp file I/O using POSIX I/O library
*
Expand Down Expand Up @@ -437,9 +435,19 @@ void FilePOSIX::Read(char *buffer, size_t size, size_t start)
{
if (m_FailOnEOF)
{
helper::Throw<std::ios_base::failure>(
"Toolkit", "transport::file::FilePOSIX", "Read",
"Read past end of file on " + m_Name + " " + SysErrMsg());
// we got an EOF on data that *should* be present,
// but maybe we've got filesystem consistency
// issues. We'll wait, but if the backoff time
// reaches 30 seconds (nearly 45 seconds total
// wait time) and we still don't have data, treat
// this as a real failure and throw an exception.
std::this_thread::sleep_for(std::chrono::nanoseconds(backoff_ns));
backoff_ns *= 2;
if (std::chrono::nanoseconds(backoff_ns) > std::chrono::seconds(30))
helper::Throw<std::ios_base::failure>(
"Toolkit", "transport::file::FilePOSIX", "Read",
"Read past end of file on " + m_Name + " trying to read " +
std::to_string(size) + " bytes " + SysErrMsg());
}
else
{
Expand Down

0 comments on commit d44c52d

Please sign in to comment.