8f639a4096
The executable can be inside a zip file using the same syntax used for shared objects: path.zip!/libentry.so. The linker currently requires an absolute path. This restriction could be loosened, but it didn't seem important? If it allowed non-absolute paths, we'd need to decide how to handle: - foo/bar (relative to CWD?) - foo (search PATH / LD_LIBRARY_PATH, or also relative to CWD?) - foo.zip!/bar (normalize_path() requires an absolute path) The linker adjusts the argc/argv passed to main() and to constructor functions to hide the initial linker argument, but doesn't adjust the auxv vector or files like /proc/self/{exe,cmdline,auxv,stat}. Those files will report that the kernel loaded the linker as an executable. I think the linker_logger.cpp change guarding against (g_argv == NULL) isn't actually necessary, but it seemed like a good idea given that I'm delaying initialization of g_argv until after C++ constructors have run. Bug: http://b/112050209 Test: bionic unit tests Change-Id: I846faf98b16fd34218946f6167e8b451897debe5
73 lines
2.7 KiB
C++
73 lines
2.7 KiB
C++
/*
|
|
* Copyright (C) 2016 The Android Open Source Project
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* * Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in
|
|
* the documentation and/or other materials provided with the
|
|
* distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
|
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <android/dlext.h>
|
|
|
|
#include <unordered_map>
|
|
#include <vector>
|
|
|
|
#include "linker_namespaces.h"
|
|
#include "linker_soinfo.h"
|
|
|
|
class ProtectedDataGuard {
|
|
public:
|
|
ProtectedDataGuard();
|
|
~ProtectedDataGuard();
|
|
|
|
private:
|
|
void protect_data(int protection);
|
|
static size_t ref_count_;
|
|
};
|
|
|
|
class ElfReader;
|
|
|
|
std::vector<android_namespace_t*> init_default_namespaces(const char* executable_path);
|
|
soinfo* soinfo_alloc(android_namespace_t* ns, const char* name,
|
|
const struct stat* file_stat, off64_t file_offset,
|
|
uint32_t rtld_flags);
|
|
|
|
bool find_libraries(android_namespace_t* ns,
|
|
soinfo* start_with,
|
|
const char* const library_names[],
|
|
size_t library_names_count,
|
|
soinfo* soinfos[],
|
|
std::vector<soinfo*>* ld_preloads,
|
|
size_t ld_preloads_count,
|
|
int rtld_flags,
|
|
const android_dlextinfo* extinfo,
|
|
bool add_as_children,
|
|
bool search_linked_namespaces,
|
|
std::vector<android_namespace_t*>* namespaces = nullptr);
|
|
|
|
void solist_add_soinfo(soinfo* si);
|
|
bool solist_remove_soinfo(soinfo* si);
|
|
soinfo* solist_get_head();
|
|
soinfo* solist_get_somain();
|
|
soinfo* solist_get_vdso();
|