From a2fa8d8be1acdf5b4642d1af24988edaaf454e2e Mon Sep 17 00:00:00 2001 From: topjohnwu Date: Mon, 29 Apr 2019 20:04:39 -0400 Subject: [PATCH] Stop fdsan complains --- native/jni/core/bootstages.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/native/jni/core/bootstages.cpp b/native/jni/core/bootstages.cpp index c02c79ce7..a2f2c3b2a 100644 --- a/native/jni/core/bootstages.cpp +++ b/native/jni/core/bootstages.cpp @@ -498,20 +498,20 @@ void unlock_blocks() { struct dirent *entry; int fd, dev, OFF = 0; - if ((dev = xopen("/dev/block", O_RDONLY | O_CLOEXEC)) < 0) + if (!(dir = xopendir("/dev/block"))) return; - dir = xfdopendir(dev); + dev = dirfd(dir); while((entry = readdir(dir))) { if (entry->d_type == DT_BLK) { - if ((fd = openat(dev, entry->d_name, O_RDONLY)) < 0) + if ((fd = openat(dev, entry->d_name, O_RDONLY | O_CLOEXEC)) < 0) continue; - if (ioctl(fd, BLKROSET, &OFF) == -1) + if (ioctl(fd, BLKROSET, &OFF) < 0) PLOGE("unlock %s", entry->d_name); close(fd); } } - close(dev); + closedir(dir); } static bool log_dump = false;