blob: 1d7563b0daf0b13d91719d33219eed25340ef0d9 [file] [log] [blame]
/*
* Copyright (C) 2019 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.
*/
// Framework-side code runs in this namespace. Libs from /vendor partition can't
// be loaded in this namespace.
#include "linkerconfig/environment.h"
#include "linkerconfig/namespace.h"
#include "linkerconfig/namespacebuilder.h"
using android::linkerconfig::modules::AsanPath;
using android::linkerconfig::modules::Namespace;
namespace {
// Keep in sync with the "platform" namespace in art/build/apex/ld.config.txt.
const std::vector<std::string> kLibsFromArt = {
"libdexfile_external.so",
"libdexfiled_external.so",
"libnativebridge.so",
"libnativehelper.so",
"libnativeloader.so",
"libandroidicu.so",
// TODO(b/122876336): Remove libpac.so once it's migrated to Webview
"libpac.so",
// TODO(b/120786417 or b/134659294): libicuuc.so
// and libicui18n.so are kept for app compat.
"libicui18n.so",
"libicuuc.so",
};
// We can't have entire /system/${LIB} as permitted paths because doing so makes
// it possible to load libs in /system/${LIB}/vndk* directories by their
// absolute paths, e.g. dlopen("/system/lib/vndk/libbase.so"). VNDK libs are
// built with previous versions of Android and thus must not be loaded into this
// namespace where libs built with the current version of Android are loaded.
// Mixing the two types of libs in the same namespace can cause unexpected
// problems.
const std::vector<std::string> kPermittedPaths = {
"/system/${LIB}/drm",
"/system/${LIB}/extractors",
"/system/${LIB}/hw",
"/@{SYSTEM_EXT:system_ext}/${LIB}",
"/@{PRODUCT:product}/${LIB}",
// These are where odex files are located. libart has to be able to
// dlopen the files
"/system/framework",
"/system/app",
"/system/priv-app",
"/@{SYSTEM_EXT:system_ext}/framework",
"/@{SYSTEM_EXT:system_ext}/app",
"/@{SYSTEM_EXT:system_ext}/priv-app",
"/vendor/framework",
"/vendor/app",
"/vendor/priv-app",
"/system/vendor/framework",
"/system/vendor/app",
"/system/vendor/priv-app",
"/odm/framework",
"/odm/app",
"/odm/priv-app",
"/oem/app",
"/@{PRODUCT:product}/framework",
"/@{PRODUCT:product}/app",
"/@{PRODUCT:product}/priv-app",
"/data",
"/mnt/expand",
"/apex/com.android.runtime/${LIB}/bionic",
"/system/${LIB}/bootstrap"};
void BuildPermittedPath(Namespace& ns) {
for (const auto& path : kPermittedPaths) {
ns.AddPermittedPath(path, AsanPath::SAME_PATH);
}
}
} // namespace
namespace android {
namespace linkerconfig {
namespace contents {
Namespace BuildSystemDefaultNamespace([[maybe_unused]] const Context& ctx) {
bool is_fully_treblelized = ctx.IsDefaultConfig();
// Visible to allow links to be created at runtime, e.g. through
// android_link_namespaces in libnativeloader.
Namespace ns("default",
/*is_isolated=*/is_fully_treblelized,
/*is_visible=*/true);
ns.AddSearchPath("/system/${LIB}", AsanPath::WITH_DATA_ASAN);
ns.AddSearchPath("/@{SYSTEM_EXT:system_ext}/${LIB}", AsanPath::WITH_DATA_ASAN);
ns.AddSearchPath("/@{PRODUCT:product}/${LIB}", AsanPath::WITH_DATA_ASAN);
if (!is_fully_treblelized) {
ns.AddSearchPath("/vendor/${LIB}", AsanPath::WITH_DATA_ASAN);
ns.AddSearchPath("/odm/${LIB}", AsanPath::WITH_DATA_ASAN);
}
if (is_fully_treblelized) {
BuildPermittedPath(ns);
}
ns.GetLink("art").AddSharedLib(kLibsFromArt);
ns.GetLink("resolv").AddSharedLib("libnetd_resolv.so");
ns.GetLink("neuralnetworks").AddSharedLib("libneuralnetworks.so");
return ns;
}
} // namespace contents
} // namespace linkerconfig
} // namespace android