blob: 5ffdf4615a1563f9c8ece08821239ecd29b3d2b2 [file] [log] [blame]
Jiyong Park450cff42017-04-05 14:24:14 +09001# Copyright (C) 2017 The Android Open Source Project
2#
3# Bionic loader config file.
4# This gives the exactly the same namespace setup in pre-O.
5#
6
7# All binaries gets the same configuration 'legacy'
8dir.legacy = /system
changho.shin715b1aa2018-11-28 15:15:16 +09009dir.legacy = /product
Jiyong Park450cff42017-04-05 14:24:14 +090010dir.legacy = /vendor
Alin Jerpeleafa7958e2017-09-27 09:40:59 +020011dir.legacy = /odm
Jiyong Park450cff42017-04-05 14:24:14 +090012dir.legacy = /sbin
13
changho.shin715b1aa2018-11-28 15:15:16 +090014# Except for /postinstall, where only /system and /product are searched
Jiyong Parkd7e6cb22018-03-20 01:12:31 +090015dir.postinstall = /postinstall
16
Martin Stjernholmadf45032019-03-26 16:30:23 +000017# Fallback entry to provide APEX namespace lookups for binaries anywhere else.
18# This must be last.
19dir.legacy = /data
20
Jiyong Park450cff42017-04-05 14:24:14 +090021[legacy]
22namespace.default.isolated = false
Martin Stjernholmc57ed292019-04-25 16:20:32 +010023# Visible to allow links to be created at runtime, e.g. through
24# android_link_namespaces in libnativeloader.
25namespace.default.visible = true
Jiyong Park2498e1b2017-12-12 22:11:47 +090026
27namespace.default.search.paths = /system/${LIB}
changho.shin715b1aa2018-11-28 15:15:16 +090028namespace.default.search.paths += /product/${LIB}
Jiyong Park2498e1b2017-12-12 22:11:47 +090029namespace.default.search.paths += /vendor/${LIB}
30namespace.default.search.paths += /odm/${LIB}
31
32namespace.default.asan.search.paths = /data/asan/system/${LIB}
33namespace.default.asan.search.paths += /system/${LIB}
changho.shin715b1aa2018-11-28 15:15:16 +090034namespace.default.asan.search.paths += /data/asan/product/${LIB}
35namespace.default.asan.search.paths += /product/${LIB}
Jiyong Park2498e1b2017-12-12 22:11:47 +090036namespace.default.asan.search.paths += /data/asan/vendor/${LIB}
37namespace.default.asan.search.paths += /vendor/${LIB}
changho.shin715b1aa2018-11-28 15:15:16 +090038namespace.default.asan.search.paths += /data/asan/odm/${LIB}
39namespace.default.asan.search.paths += /odm/${LIB}
Jiyong Parkd7e6cb22018-03-20 01:12:31 +090040
41###############################################################################
Nicolas Geoffrayad125602019-01-24 21:20:20 +000042# APEX related namespaces.
43###############################################################################
44
Przemyslaw Szczepaniak0bb871d2019-07-10 12:08:57 +010045additional.namespaces = runtime,conscrypt,media,neuralnetworks,resolv
Nicolas Geoffrayad125602019-01-24 21:20:20 +000046
Martin Stjernholmc57ed292019-04-25 16:20:32 +010047# Keep in sync with the "platform" namespace in art/build/apex/ld.config.txt.
chenbruced7717402019-01-29 11:52:41 +080048# If a shared library or an executable requests a shared library that
49# cannot be loaded into the default namespace, the dynamic linker tries
Roland Levillaine51c8762019-03-07 19:06:57 +000050# to load the shared library from the runtime namespace. And then, if the
chenbruced7717402019-01-29 11:52:41 +080051# shared library cannot be loaded from the runtime namespace either, the
52# dynamic linker tries to load the shared library from the resolv namespace.
53# Finally, if all attempts fail, the dynamic linker returns an error.
Przemyslaw Szczepaniak0bb871d2019-07-10 12:08:57 +010054namespace.default.links = runtime,resolv,neuralnetworks
55namespace.default.asan.links = runtime,resolv,neuralnetworks
Martin Stjernholm8a50dad2019-04-30 16:11:30 +010056namespace.default.link.runtime.shared_libs = libandroidicu.so
57namespace.default.link.runtime.shared_libs += libdexfile_external.so
58namespace.default.link.runtime.shared_libs += libdexfiled_external.so
Martin Stjernholm0d28abc2019-06-06 14:11:04 +010059# TODO(b/120786417 or b/134659294): libicuuc.so and libicui18n.so are kept for app compat.
Victor Chang0c7edec2019-05-13 16:14:03 +010060namespace.default.link.runtime.shared_libs += libicui18n.so
61namespace.default.link.runtime.shared_libs += libicuuc.so
Nicolas Geoffrayad125602019-01-24 21:20:20 +000062namespace.default.link.runtime.shared_libs += libnativebridge.so
63namespace.default.link.runtime.shared_libs += libnativehelper.so
64namespace.default.link.runtime.shared_libs += libnativeloader.so
Victor Chang785ba2e2019-01-15 18:04:56 +000065
66# TODO(b/122876336): Remove libpac.so once it's migrated to Webview
67namespace.default.link.runtime.shared_libs += libpac.so
Nicolas Geoffrayad125602019-01-24 21:20:20 +000068
chenbruced7717402019-01-29 11:52:41 +080069# When libnetd_resolv.so can't be found in the default namespace, search for it
70# in the resolv namespace. Don't allow any other libraries from the resolv namespace
71# to be loaded in the default namespace.
chenbruceaa87fd52019-01-24 13:01:21 +080072namespace.default.link.resolv.shared_libs = libnetd_resolv.so
73
Przemyslaw Szczepaniak0bb871d2019-07-10 12:08:57 +010074# LLNDK library moved into apex
75namespace.default.link.neuralnetworks.shared_libs = libneuralnetworks.so
76
Nicolas Geoffrayad125602019-01-24 21:20:20 +000077###############################################################################
78# "runtime" APEX namespace
79#
80# This namespace exposes externally accessible libraries from the Runtime APEX.
Martin Stjernholmc57ed292019-04-25 16:20:32 +010081# Keep in sync with the "runtime" namespace in art/build/apex/ld.config.txt.
Nicolas Geoffrayad125602019-01-24 21:20:20 +000082###############################################################################
83namespace.runtime.isolated = true
Martin Stjernholmc57ed292019-04-25 16:20:32 +010084# Visible to allow links to be created at runtime, e.g. through
85# android_link_namespaces in libnativeloader.
Nicolas Geoffraya9b4f2b2019-01-26 01:06:43 +000086namespace.runtime.visible = true
Nicolas Geoffrayad125602019-01-24 21:20:20 +000087
Martin Stjernholm391332d2019-08-23 15:51:32 +010088# TODO(b/139408016): Split the namespaces for the ART and Runtime APEXes
89namespace.runtime.search.paths = /apex/com.android.art/${LIB}
90namespace.runtime.search.paths += /apex/com.android.runtime/${LIB}
91namespace.runtime.asan.search.paths = /apex/com.android.art/${LIB}
92namespace.runtime.asan.search.paths += /apex/com.android.runtime/${LIB}
Nicolas Geoffrayad125602019-01-24 21:20:20 +000093namespace.runtime.links = default
Martin Stjernholm609236f2019-02-27 21:40:42 +000094# Need allow_all_shared_libs because libart.so can dlopen oat files in
95# /system/framework and /data.
96# TODO(b/130340935): Use a dynamically created linker namespace similar to
97# classloader-namespace for oat files, and tighten this up.
Nicolas Geoffrayad125602019-01-24 21:20:20 +000098namespace.runtime.link.default.allow_all_shared_libs = true
99
100###############################################################################
101# "media" APEX namespace
102#
103# This namespace is for libraries within the media APEX.
104###############################################################################
105namespace.media.isolated = true
106namespace.media.visible = true
107
108namespace.media.search.paths = /apex/com.android.media/${LIB}
109namespace.media.asan.search.paths = /apex/com.android.media/${LIB}
110
Dongwon Kang3408eaa2019-02-22 00:47:13 -0800111namespace.media.permitted.paths = /apex/com.android.media/${LIB}/extractors
112
Nicolas Geoffrayad125602019-01-24 21:20:20 +0000113namespace.media.links = default
Dongwon Kang5744cc42019-04-23 14:56:21 -0700114namespace.media.link.default.shared_libs = libbinder_ndk.so
Dongwon Kanga013e3d2019-03-15 14:43:07 -0700115namespace.media.link.default.shared_libs += libc.so
Yifan Hong063b6be2019-03-29 13:17:35 -0700116namespace.media.link.default.shared_libs += libcgrouprc.so
Dongwon Kanga013e3d2019-03-15 14:43:07 -0700117namespace.media.link.default.shared_libs += libdl.so
118namespace.media.link.default.shared_libs += liblog.so
119namespace.media.link.default.shared_libs += libmediametrics.so
120namespace.media.link.default.shared_libs += libmediandk.so
121namespace.media.link.default.shared_libs += libm.so
122namespace.media.link.default.shared_libs += libvndksupport.so
123
124namespace.media.link.default.shared_libs += libclang_rt.asan-aarch64-android.so
125namespace.media.link.default.shared_libs += libclang_rt.asan-arm-android.so
126namespace.media.link.default.shared_libs += libclang_rt.asan-i686-android.so
127namespace.media.link.default.shared_libs += libclang_rt.asan-x86_64-android.so
128namespace.media.link.default.shared_libs += libclang_rt.hwasan-aarch64-android.so
Nicolas Geoffrayad125602019-01-24 21:20:20 +0000129
130###############################################################################
131# "conscrypt" APEX namespace
132#
133# This namespace is for libraries within the conscrypt APEX.
Martin Stjernholmc57ed292019-04-25 16:20:32 +0100134# Keep in sync with the "conscrypt" namespace in art/build/apex/ld.config.txt.
Nicolas Geoffrayad125602019-01-24 21:20:20 +0000135###############################################################################
136namespace.conscrypt.isolated = true
137namespace.conscrypt.visible = true
138
Nicolas Geoffrayad125602019-01-24 21:20:20 +0000139namespace.conscrypt.search.paths = /apex/com.android.conscrypt/${LIB}
140namespace.conscrypt.asan.search.paths = /apex/com.android.conscrypt/${LIB}
Pete Bentley7b967bf2019-01-30 18:35:48 +0000141namespace.conscrypt.links = runtime,default
Pete Bentleycc6c50a2019-03-21 17:13:14 +0000142namespace.conscrypt.link.runtime.shared_libs = libandroidio.so
Nicolas Geoffrayad125602019-01-24 21:20:20 +0000143namespace.conscrypt.link.default.shared_libs = libc.so
144namespace.conscrypt.link.default.shared_libs += libm.so
145namespace.conscrypt.link.default.shared_libs += libdl.so
Tom Cherryfe1f7012019-02-08 11:55:36 -0800146namespace.conscrypt.link.default.shared_libs += liblog.so
Nicolas Geoffrayad125602019-01-24 21:20:20 +0000147
148###############################################################################
chenbruceaa87fd52019-01-24 13:01:21 +0800149# "resolv" APEX namespace
150#
151# This namespace is for libraries within the resolv APEX.
152###############################################################################
153namespace.resolv.isolated = true
154namespace.resolv.visible = true
155
156namespace.resolv.search.paths = /apex/com.android.resolv/${LIB}
157namespace.resolv.asan.search.paths = /apex/com.android.resolv/${LIB}
158namespace.resolv.links = default
159namespace.resolv.link.default.shared_libs = libc.so
Yifan Hong063b6be2019-03-29 13:17:35 -0700160namespace.resolv.link.default.shared_libs += libcgrouprc.so
chenbruceaa87fd52019-01-24 13:01:21 +0800161namespace.resolv.link.default.shared_libs += libm.so
162namespace.resolv.link.default.shared_libs += libdl.so
163namespace.resolv.link.default.shared_libs += libbinder_ndk.so
Tom Cherryfe1f7012019-02-08 11:55:36 -0800164namespace.resolv.link.default.shared_libs += liblog.so
Dongwon Kang9dff5152019-02-08 14:00:35 -0800165namespace.resolv.link.default.shared_libs += libvndksupport.so
chenbruceaa87fd52019-01-24 13:01:21 +0800166
167###############################################################################
Przemyslaw Szczepaniak0bb871d2019-07-10 12:08:57 +0100168# "neuralnetworks" APEX namespace
169#
170# This namespace is for libraries within the NNAPI APEX.
171###############################################################################
172namespace.neuralnetworks.isolated = true
173namespace.neuralnetworks.visible = true
174
175namespace.neuralnetworks.search.paths = /apex/com.android.neuralnetworks/${LIB}
176namespace.neuralnetworks.asan.search.paths = /apex/com.android.neuralnetworks/${LIB}
177namespace.neuralnetworks.links = default
178namespace.neuralnetworks.link.default.shared_libs = libc.so
179namespace.neuralnetworks.link.default.shared_libs += libcgrouprc.so
180namespace.neuralnetworks.link.default.shared_libs += libdl.so
181namespace.neuralnetworks.link.default.shared_libs += liblog.so
182namespace.neuralnetworks.link.default.shared_libs += libm.so
183namespace.neuralnetworks.link.default.shared_libs += libnativewindow.so
Przemyslaw Szczepaniak6122bc02019-09-17 14:00:10 +0100184namespace.neuralnetworks.link.default.shared_libs += libneuralnetworks_packageinfo.so
Przemyslaw Szczepaniak0bb871d2019-07-10 12:08:57 +0100185namespace.neuralnetworks.link.default.shared_libs += libsync.so
186namespace.neuralnetworks.link.default.shared_libs += libvndksupport.so
187
188
189###############################################################################
Jiyong Parkd7e6cb22018-03-20 01:12:31 +0900190# Namespace config for binaries under /postinstall.
191# Only one default namespace is defined and it has no directories other than
changho.shin715b1aa2018-11-28 15:15:16 +0900192# /system/lib and /product/lib in the search paths. This is because linker
193# calls realpath on the search paths and this causes selinux denial if the
194# paths (/vendor, /odm) are not allowed to the poinstall binaries.
195# There is no reason to allow the binaries to access the paths.
Jiyong Parkd7e6cb22018-03-20 01:12:31 +0900196###############################################################################
197[postinstall]
198namespace.default.isolated = false
changho.shin715b1aa2018-11-28 15:15:16 +0900199namespace.default.search.paths = /system/${LIB}
200namespace.default.search.paths += /product/${LIB}