[flang-commits] [PATCH] D132168: [flang][runtime] Handle endian-swapped record headers & footers on input
Peter Klausler via Phabricator via flang-commits
flang-commits at lists.llvm.org
Thu Aug 18 15:42:56 PDT 2022
This revision was automatically updated to reflect the committed changes.
Closed by commit rGc7fe5e83dbb4: [flang][runtime] Handle endian-swapped record headers & footers on input (authored by klausler).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D132168/new/
https://reviews.llvm.org/D132168
Files:
flang/runtime/unit.cpp
flang/runtime/unit.h
Index: flang/runtime/unit.h
===================================================================
--- flang/runtime/unit.h
+++ flang/runtime/unit.h
@@ -134,6 +134,7 @@
void CommitWrites();
bool CheckDirectAccess(IoErrorHandler &);
void HitEndOnRead(IoErrorHandler &);
+ std::int32_t ReadHeaderOrFooter(std::int64_t frameOffset);
Lock lock_;
// TODO: replace with a thread ID
Index: flang/runtime/unit.cpp
===================================================================
--- flang/runtime/unit.cpp
+++ flang/runtime/unit.cpp
@@ -279,7 +279,7 @@
}
}
-static void SwapEndianness(
+static inline void SwapEndianness(
char *data, std::size_t bytes, std::size_t elementBytes) {
if (elementBytes > 1) {
auto half{elementBytes >> 1};
@@ -733,7 +733,7 @@
"record #%jd (file offset %jd): truncated record header";
}
} else {
- std::memcpy(&header, Frame() + recordOffsetInFrame_, sizeof header);
+ header = ReadHeaderOrFooter(recordOffsetInFrame_);
recordLength = sizeof header + header; // does not include footer
need = recordOffsetInFrame_ + *recordLength + sizeof footer;
got = ReadFrame(frameOffsetInFile_, need, handler);
@@ -742,8 +742,7 @@
"record #%jd (file offset %jd): hit EOF reading record with "
"length %jd bytes";
} else {
- std::memcpy(&footer, Frame() + recordOffsetInFrame_ + *recordLength,
- sizeof footer);
+ footer = ReadHeaderOrFooter(recordOffsetInFrame_ + *recordLength);
if (footer != header) {
error = "Unformatted variable-length sequential file input failed at "
"record #%jd (file offset %jd): record header has length %jd "
@@ -800,7 +799,7 @@
void ExternalFileUnit::BackspaceVariableUnformattedRecord(
IoErrorHandler &handler) {
- std::int32_t header{0}, footer{0};
+ std::int32_t header{0};
auto headerBytes{static_cast<std::int64_t>(sizeof header)};
frameOffsetInFile_ += recordOffsetInFrame_;
recordOffsetInFrame_ = 0;
@@ -817,8 +816,7 @@
handler.SignalError(IostatShortRead);
return;
}
- std::memcpy(&footer, Frame(), sizeof footer);
- recordLength = footer;
+ recordLength = ReadHeaderOrFooter(0);
if (frameOffsetInFile_ < *recordLength + 2 * headerBytes) {
handler.SignalError(IostatBadUnformattedRecord);
return;
@@ -835,7 +833,7 @@
handler.SignalError(IostatShortRead);
return;
}
- std::memcpy(&header, Frame() + recordOffsetInFrame_, sizeof header);
+ header = ReadHeaderOrFooter(recordOffsetInFrame_);
if (header != *recordLength) {
handler.SignalError(IostatBadUnformattedRecord);
return;
@@ -993,6 +991,16 @@
}
}
+std::int32_t ExternalFileUnit::ReadHeaderOrFooter(std::int64_t frameOffset) {
+ std::int32_t word;
+ char *wordPtr{reinterpret_cast<char *>(&word)};
+ std::memcpy(wordPtr, Frame() + frameOffset, sizeof word);
+ if (swapEndianness_) {
+ SwapEndianness(wordPtr, sizeof word, sizeof word);
+ }
+ return word;
+}
+
void ChildIo::EndIoStatement() {
io_.reset();
u_.emplace<std::monostate>();
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D132168.453818.patch
Type: text/x-patch
Size: 3102 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/flang-commits/attachments/20220818/14f0c71c/attachment.bin>
More information about the flang-commits
mailing list