From 701d05d32c8b415c6fbb2e8c9439185333870046 Mon Sep 17 00:00:00 2001 From: Wei Wang Date: Tue, 7 Nov 2017 09:44:16 -0800 Subject: [PATCH] Vold: Add fsync in writeStringToFile() Test: Build, test with ag/3180275 Bug: 68901441 Change-Id: Ieca9e5227025e00184a67508d5e8fbbddd12f21e --- KeyStorage.cpp | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/KeyStorage.cpp b/KeyStorage.cpp index 9d61555..20b2391 100644 --- a/KeyStorage.cpp +++ b/KeyStorage.cpp @@ -35,6 +35,7 @@ #include #include +#include #include @@ -153,10 +154,29 @@ static bool readFileToString(const std::string& filename, std::string* result) { } static bool writeStringToFile(const std::string& payload, const std::string& filename) { - if (!android::base::WriteStringToFile(payload, filename)) { - PLOG(ERROR) << "Failed to write to " << filename; + android::base::unique_fd fd(TEMP_FAILURE_RETRY( + open(filename.c_str(), O_WRONLY | O_CREAT | O_NOFOLLOW | O_TRUNC | O_CLOEXEC, 0666))); + if (fd == -1) { + PLOG(ERROR) << "Failed to open " << filename; return false; } + if (!android::base::WriteStringToFd(payload, fd)) { + PLOG(ERROR) << "Failed to write to " << filename; + unlink(filename.c_str()); + return false; + } + // fsync as close won't guarantee flush data + // see close(2), fsync(2) and b/68901441 + if (fsync(fd) == -1) { + if (errno == EROFS || errno == EINVAL) { + PLOG(WARNING) << "Skip fsync " << filename + << " on a file system does not support synchronization"; + } else { + PLOG(ERROR) << "Failed to fsync " << filename; + unlink(filename.c_str()); + return false; + } + } return true; }