2016-08-04 01:00:10 +02:00
|
|
|
/*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __LINKER_NAMESPACES_H
|
|
|
|
#define __LINKER_NAMESPACES_H
|
|
|
|
|
|
|
|
#include "linker_common_types.h"
|
|
|
|
|
2016-08-04 20:50:36 +02:00
|
|
|
#include <string>
|
2016-08-04 01:00:10 +02:00
|
|
|
#include <vector>
|
2017-02-02 00:28:52 +01:00
|
|
|
#include <unordered_set>
|
|
|
|
|
|
|
|
struct android_namespace_t;
|
|
|
|
|
|
|
|
struct android_namespace_link_t {
|
|
|
|
public:
|
|
|
|
android_namespace_link_t(android_namespace_t* linked_namespace,
|
2018-01-18 05:05:09 +01:00
|
|
|
const std::unordered_set<std::string>& shared_lib_sonames,
|
|
|
|
bool allow_all_shared_libs)
|
|
|
|
: linked_namespace_(linked_namespace), shared_lib_sonames_(shared_lib_sonames),
|
|
|
|
allow_all_shared_libs_(allow_all_shared_libs)
|
2017-02-02 00:28:52 +01:00
|
|
|
{}
|
|
|
|
|
|
|
|
android_namespace_t* linked_namespace() const {
|
|
|
|
return linked_namespace_;
|
|
|
|
}
|
|
|
|
|
2017-05-02 02:45:38 +02:00
|
|
|
const std::unordered_set<std::string>& shared_lib_sonames() const {
|
|
|
|
return shared_lib_sonames_;
|
|
|
|
}
|
|
|
|
|
2017-02-02 00:28:52 +01:00
|
|
|
bool is_accessible(const char* soname) const {
|
2018-01-18 05:05:09 +01:00
|
|
|
return allow_all_shared_libs_ || shared_lib_sonames_.find(soname) != shared_lib_sonames_.end();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool allow_all_shared_libs() const {
|
|
|
|
return allow_all_shared_libs_;
|
2017-02-02 00:28:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
android_namespace_t* const linked_namespace_;
|
|
|
|
const std::unordered_set<std::string> shared_lib_sonames_;
|
2018-01-18 05:05:09 +01:00
|
|
|
bool allow_all_shared_libs_;
|
2017-02-02 00:28:52 +01:00
|
|
|
};
|
2016-08-04 01:00:10 +02:00
|
|
|
|
|
|
|
struct android_namespace_t {
|
|
|
|
public:
|
2017-05-05 15:07:05 +02:00
|
|
|
android_namespace_t() : name_(nullptr), is_isolated_(false), is_greylist_enabled_(false) {}
|
2016-08-04 01:00:10 +02:00
|
|
|
|
|
|
|
const char* get_name() const { return name_; }
|
|
|
|
void set_name(const char* name) { name_ = name; }
|
|
|
|
|
|
|
|
bool is_isolated() const { return is_isolated_; }
|
|
|
|
void set_isolated(bool isolated) { is_isolated_ = isolated; }
|
|
|
|
|
2017-05-05 15:07:05 +02:00
|
|
|
bool is_greylist_enabled() const { return is_greylist_enabled_; }
|
|
|
|
void set_greylist_enabled(bool enabled) { is_greylist_enabled_ = enabled; }
|
|
|
|
|
2016-08-04 01:00:10 +02:00
|
|
|
const std::vector<std::string>& get_ld_library_paths() const {
|
|
|
|
return ld_library_paths_;
|
|
|
|
}
|
|
|
|
void set_ld_library_paths(std::vector<std::string>&& library_paths) {
|
|
|
|
ld_library_paths_ = library_paths;
|
|
|
|
}
|
|
|
|
|
|
|
|
const std::vector<std::string>& get_default_library_paths() const {
|
|
|
|
return default_library_paths_;
|
|
|
|
}
|
|
|
|
void set_default_library_paths(std::vector<std::string>&& library_paths) {
|
|
|
|
default_library_paths_ = library_paths;
|
|
|
|
}
|
2017-03-07 20:19:05 +01:00
|
|
|
void set_default_library_paths(const std::vector<std::string>& library_paths) {
|
|
|
|
default_library_paths_ = library_paths;
|
|
|
|
}
|
2016-08-04 01:00:10 +02:00
|
|
|
|
|
|
|
const std::vector<std::string>& get_permitted_paths() const {
|
|
|
|
return permitted_paths_;
|
|
|
|
}
|
|
|
|
void set_permitted_paths(std::vector<std::string>&& permitted_paths) {
|
|
|
|
permitted_paths_ = permitted_paths;
|
|
|
|
}
|
2017-03-07 20:19:05 +01:00
|
|
|
void set_permitted_paths(const std::vector<std::string>& permitted_paths) {
|
|
|
|
permitted_paths_ = permitted_paths;
|
|
|
|
}
|
2016-08-04 01:00:10 +02:00
|
|
|
|
2017-02-02 00:28:52 +01:00
|
|
|
const std::vector<android_namespace_link_t>& linked_namespaces() const {
|
|
|
|
return linked_namespaces_;
|
|
|
|
}
|
|
|
|
void add_linked_namespace(android_namespace_t* linked_namespace,
|
2018-01-18 05:05:09 +01:00
|
|
|
const std::unordered_set<std::string>& shared_lib_sonames,
|
|
|
|
bool allow_all_shared_libs) {
|
|
|
|
linked_namespaces_.push_back(
|
|
|
|
android_namespace_link_t(linked_namespace, shared_lib_sonames, allow_all_shared_libs));
|
2017-02-02 00:28:52 +01:00
|
|
|
}
|
|
|
|
|
2016-08-04 01:00:10 +02:00
|
|
|
void add_soinfo(soinfo* si) {
|
|
|
|
soinfo_list_.push_back(si);
|
|
|
|
}
|
|
|
|
|
|
|
|
void add_soinfos(const soinfo_list_t& soinfos) {
|
|
|
|
for (auto si : soinfos) {
|
|
|
|
add_soinfo(si);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void remove_soinfo(soinfo* si) {
|
|
|
|
soinfo_list_.remove_if([&](soinfo* candidate) {
|
|
|
|
return si == candidate;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
const soinfo_list_t& soinfo_list() const { return soinfo_list_; }
|
|
|
|
|
|
|
|
// For isolated namespaces - checks if the file is on the search path;
|
|
|
|
// always returns true for not isolated namespace.
|
|
|
|
bool is_accessible(const std::string& path);
|
|
|
|
|
2017-02-03 23:07:34 +01:00
|
|
|
// Returns true if si is accessible from this namespace. A soinfo
|
|
|
|
// is considered accessible when it belongs to this namespace
|
|
|
|
// or one of it's parent soinfos belongs to this namespace.
|
|
|
|
bool is_accessible(soinfo* si);
|
|
|
|
|
2017-05-19 18:01:24 +02:00
|
|
|
soinfo_list_t get_global_group();
|
|
|
|
soinfo_list_t get_shared_group();
|
|
|
|
|
2016-08-04 01:00:10 +02:00
|
|
|
private:
|
|
|
|
const char* name_;
|
|
|
|
bool is_isolated_;
|
2017-05-05 15:07:05 +02:00
|
|
|
bool is_greylist_enabled_;
|
2016-08-04 01:00:10 +02:00
|
|
|
std::vector<std::string> ld_library_paths_;
|
|
|
|
std::vector<std::string> default_library_paths_;
|
|
|
|
std::vector<std::string> permitted_paths_;
|
2017-02-02 00:28:52 +01:00
|
|
|
// Loader looks into linked namespace if it was not able
|
|
|
|
// to find a library in this namespace. Note that library
|
|
|
|
// lookup in linked namespaces are limited by the list of
|
|
|
|
// shared sonames.
|
|
|
|
std::vector<android_namespace_link_t> linked_namespaces_;
|
2016-08-04 01:00:10 +02:00
|
|
|
soinfo_list_t soinfo_list_;
|
|
|
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(android_namespace_t);
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* __LINKER_NAMESPACES_H */
|