From 2a44cfbd7d64596795836e9ae6f6c642869d6d78 Mon Sep 17 00:00:00 2001 From: Spencer Low Date: Wed, 22 Apr 2015 18:06:51 -0700 Subject: ScopedFd: Don't use TEMP_FAILURE_RETRY() with close() According to the comments in Posix_close(), TEMP_FAILURE_RETRY() should not be used with close(): https://android.googlesource.com/platform/libcore/+/462bdac45c10f43d88d8f07f6994e272a27c14a2%5E%21/#F12 Kill ScopedFd by simplifying the single caller. Bug: http://b/20501816 Change-Id: I248c40b8c2fc95f1938a6edfc245c81847fc44af Signed-off-by: Spencer Low (cherry picked from commit 0346ad7a4fb6e253317577ee8b9cc79d958f4349) --- libc/private/ScopedFd.h | 59 ------------------------------------------------- linker/linker.cpp | 47 +++++++++++++++++++++------------------ 2 files changed, 25 insertions(+), 81 deletions(-) delete mode 100644 libc/private/ScopedFd.h diff --git a/libc/private/ScopedFd.h b/libc/private/ScopedFd.h deleted file mode 100644 index e56c139..0000000 --- a/libc/private/ScopedFd.h +++ /dev/null @@ -1,59 +0,0 @@ -/* - * Copyright (C) 2009 The Android Open Source Project - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -#ifndef SCOPED_FD_H -#define SCOPED_FD_H - -#include -#include "bionic_macros.h" - -// A smart pointer that closes the given fd on going out of scope. -// Use this when the fd is incidental to the purpose of your function, -// but needs to be cleaned up on exit. -class ScopedFd { -public: - explicit ScopedFd(int fd) : fd(fd) { - } - - ~ScopedFd() { - reset(); - } - - int get() const { - return fd; - } - - int release() __attribute__((warn_unused_result)) { - int localFd = fd; - fd = -1; - return localFd; - } - - void reset(int new_fd = -1) { - if (fd != -1) { - TEMP_FAILURE_RETRY(close(fd)); - } - fd = new_fd; - } - -private: - int fd; - - // Disallow copy and assignment. - DISALLOW_COPY_AND_ASSIGN(ScopedFd); -}; - -#endif // SCOPED_FD_H diff --git a/linker/linker.cpp b/linker/linker.cpp index 64b6d4d..9d796ae 100644 --- a/linker/linker.cpp +++ b/linker/linker.cpp @@ -47,7 +47,6 @@ #include "private/bionic_tls.h" #include "private/KernelArgumentBlock.h" #include "private/ScopedPthreadMutexLocker.h" -#include "private/ScopedFd.h" #include "private/ScopeGuard.h" #include "private/UniquePtr.h" @@ -1225,29 +1224,10 @@ static void for_each_dt_needed(const soinfo* si, F action) { } } -static soinfo* load_library(LoadTaskList& load_tasks, +static soinfo* load_library(int fd, off64_t file_offset, + LoadTaskList& load_tasks, const char* name, int rtld_flags, const android_dlextinfo* extinfo) { - int fd = -1; - off64_t file_offset = 0; - ScopedFd file_guard(-1); - - if (extinfo != nullptr && (extinfo->flags & ANDROID_DLEXT_USE_LIBRARY_FD) != 0) { - fd = extinfo->library_fd; - if ((extinfo->flags & ANDROID_DLEXT_USE_LIBRARY_FD_OFFSET) != 0) { - file_offset = extinfo->library_fd_offset; - } - } else { - // Open the file. - fd = open_library(name, &file_offset); - if (fd == -1) { - DL_ERR("library \"%s\" not found", name); - return nullptr; - } - - file_guard.reset(fd); - } - if ((file_offset % PAGE_SIZE) != 0) { DL_ERR("file offset for the library \"%s\" is not page-aligned: %" PRId64, name, file_offset); return nullptr; @@ -1323,6 +1303,29 @@ static soinfo* load_library(LoadTaskList& load_tasks, return si; } +static soinfo* load_library(LoadTaskList& load_tasks, + const char* name, int rtld_flags, + const android_dlextinfo* extinfo) { + if (extinfo != nullptr && (extinfo->flags & ANDROID_DLEXT_USE_LIBRARY_FD) != 0) { + off64_t file_offset = 0; + if ((extinfo->flags & ANDROID_DLEXT_USE_LIBRARY_FD_OFFSET) != 0) { + file_offset = extinfo->library_fd_offset; + } + return load_library(extinfo->library_fd, file_offset, load_tasks, name, rtld_flags, extinfo); + } + + // Open the file. + off64_t file_offset; + int fd = open_library(name, &file_offset); + if (fd == -1) { + DL_ERR("library \"%s\" not found", name); + return nullptr; + } + soinfo* result = load_library(fd, file_offset, load_tasks, name, rtld_flags, extinfo); + close(fd); + return result; +} + static soinfo *find_loaded_library_by_soname(const char* name) { // Ignore filename with path. if (strchr(name, '/') != nullptr) { -- cgit v1.1