summaryrefslogtreecommitdiffstats
path: root/otafault/ota_io.cpp
diff options
context:
space:
mode:
authorTao Bao <tbao@google.com>2016-11-29 06:21:37 +0100
committerandroid-build-merger <android-build-merger@google.com>2016-11-29 06:21:37 +0100
commit839fbbdad3fc212dbc7f907a079bb0f9893d908f (patch)
tree3ed073ab6e81a78dd7c48a7acd83ae1eef11cced /otafault/ota_io.cpp
parentMerge "tests: Add testcases for EMMC targets." (diff)
parentMerge "Add ota_close(unique_fd&) and ota_fclose(std::unique_ptr<FILE>&)." (diff)
downloadandroid_bootable_recovery-839fbbdad3fc212dbc7f907a079bb0f9893d908f.tar
android_bootable_recovery-839fbbdad3fc212dbc7f907a079bb0f9893d908f.tar.gz
android_bootable_recovery-839fbbdad3fc212dbc7f907a079bb0f9893d908f.tar.bz2
android_bootable_recovery-839fbbdad3fc212dbc7f907a079bb0f9893d908f.tar.lz
android_bootable_recovery-839fbbdad3fc212dbc7f907a079bb0f9893d908f.tar.xz
android_bootable_recovery-839fbbdad3fc212dbc7f907a079bb0f9893d908f.tar.zst
android_bootable_recovery-839fbbdad3fc212dbc7f907a079bb0f9893d908f.zip
Diffstat (limited to 'otafault/ota_io.cpp')
-rw-r--r--otafault/ota_io.cpp14
1 files changed, 12 insertions, 2 deletions
diff --git a/otafault/ota_io.cpp b/otafault/ota_io.cpp
index 2efd3004a..874cb1d5c 100644
--- a/otafault/ota_io.cpp
+++ b/otafault/ota_io.cpp
@@ -14,7 +14,7 @@
* limitations under the License.
*/
-#include <map>
+#include "ota_io.h"
#include <errno.h>
#include <fcntl.h>
@@ -22,8 +22,10 @@
#include <sys/stat.h>
#include <unistd.h>
+#include <map>
+#include <memory>
+
#include "config.h"
-#include "ota_io.h"
static std::map<intptr_t, const char*> filename_cache;
static std::string read_fault_file_name = "";
@@ -74,11 +76,19 @@ int ota_close(int fd) {
return close(fd);
}
+int ota_close(unique_fd& fd) {
+ return ota_close(fd.release());
+}
+
int ota_fclose(FILE* fh) {
filename_cache.erase((intptr_t)fh);
return fclose(fh);
}
+int ota_fclose(std::unique_ptr<FILE, int (*)(FILE*)>& fh) {
+ return ota_fclose(fh.release());
+}
+
size_t ota_fread(void* ptr, size_t size, size_t nitems, FILE* stream) {
if (should_fault_inject(OTAIO_READ)) {
auto cached = filename_cache.find((intptr_t)stream);