Jiyong Park | 450cff4 | 2017-04-05 14:24:14 +0900 | [diff] [blame] | 1 | # 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' |
| 8 | dir.legacy = /system |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 9 | dir.legacy = /product |
Jiyong Park | 450cff4 | 2017-04-05 14:24:14 +0900 | [diff] [blame] | 10 | dir.legacy = /vendor |
Alin Jerpelea | fa7958e | 2017-09-27 09:40:59 +0200 | [diff] [blame] | 11 | dir.legacy = /odm |
Jiyong Park | 450cff4 | 2017-04-05 14:24:14 +0900 | [diff] [blame] | 12 | dir.legacy = /sbin |
| 13 | |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 14 | # Except for /postinstall, where only /system and /product are searched |
Jiyong Park | d7e6cb2 | 2018-03-20 01:12:31 +0900 | [diff] [blame] | 15 | dir.postinstall = /postinstall |
| 16 | |
Martin Stjernholm | adf4503 | 2019-03-26 16:30:23 +0000 | [diff] [blame] | 17 | # Fallback entry to provide APEX namespace lookups for binaries anywhere else. |
| 18 | # This must be last. |
| 19 | dir.legacy = /data |
| 20 | |
Jiyong Park | 450cff4 | 2017-04-05 14:24:14 +0900 | [diff] [blame] | 21 | [legacy] |
| 22 | namespace.default.isolated = false |
Martin Stjernholm | c57ed29 | 2019-04-25 16:20:32 +0100 | [diff] [blame] | 23 | # Visible to allow links to be created at runtime, e.g. through |
| 24 | # android_link_namespaces in libnativeloader. |
| 25 | namespace.default.visible = true |
Jiyong Park | 2498e1b | 2017-12-12 22:11:47 +0900 | [diff] [blame] | 26 | |
| 27 | namespace.default.search.paths = /system/${LIB} |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 28 | namespace.default.search.paths += /product/${LIB} |
Jiyong Park | 2498e1b | 2017-12-12 22:11:47 +0900 | [diff] [blame] | 29 | namespace.default.search.paths += /vendor/${LIB} |
| 30 | namespace.default.search.paths += /odm/${LIB} |
| 31 | |
| 32 | namespace.default.asan.search.paths = /data/asan/system/${LIB} |
| 33 | namespace.default.asan.search.paths += /system/${LIB} |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 34 | namespace.default.asan.search.paths += /data/asan/product/${LIB} |
| 35 | namespace.default.asan.search.paths += /product/${LIB} |
Jiyong Park | 2498e1b | 2017-12-12 22:11:47 +0900 | [diff] [blame] | 36 | namespace.default.asan.search.paths += /data/asan/vendor/${LIB} |
| 37 | namespace.default.asan.search.paths += /vendor/${LIB} |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 38 | namespace.default.asan.search.paths += /data/asan/odm/${LIB} |
| 39 | namespace.default.asan.search.paths += /odm/${LIB} |
Jiyong Park | d7e6cb2 | 2018-03-20 01:12:31 +0900 | [diff] [blame] | 40 | |
| 41 | ############################################################################### |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 42 | # APEX related namespaces. |
| 43 | ############################################################################### |
| 44 | |
chenbruce | aa87fd5 | 2019-01-24 13:01:21 +0800 | [diff] [blame] | 45 | additional.namespaces = runtime,conscrypt,media,resolv |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 46 | |
Martin Stjernholm | c57ed29 | 2019-04-25 16:20:32 +0100 | [diff] [blame] | 47 | # Keep in sync with the "platform" namespace in art/build/apex/ld.config.txt. |
chenbruce | d771740 | 2019-01-29 11:52:41 +0800 | [diff] [blame] | 48 | # 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 Levillain | e51c876 | 2019-03-07 19:06:57 +0000 | [diff] [blame] | 50 | # to load the shared library from the runtime namespace. And then, if the |
chenbruce | d771740 | 2019-01-29 11:52:41 +0800 | [diff] [blame] | 51 | # 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. |
chenbruce | aa87fd5 | 2019-01-24 13:01:21 +0800 | [diff] [blame] | 54 | namespace.default.links = runtime,resolv |
| 55 | namespace.default.asan.links = runtime,resolv |
Martin Stjernholm | 8a50dad | 2019-04-30 16:11:30 +0100 | [diff] [blame] | 56 | namespace.default.link.runtime.shared_libs = libandroidicu.so |
| 57 | namespace.default.link.runtime.shared_libs += libdexfile_external.so |
| 58 | namespace.default.link.runtime.shared_libs += libdexfiled_external.so |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 59 | namespace.default.link.runtime.shared_libs += libnativebridge.so |
| 60 | namespace.default.link.runtime.shared_libs += libnativehelper.so |
| 61 | namespace.default.link.runtime.shared_libs += libnativeloader.so |
Victor Chang | 785ba2e | 2019-01-15 18:04:56 +0000 | [diff] [blame] | 62 | |
| 63 | # TODO(b/122876336): Remove libpac.so once it's migrated to Webview |
| 64 | namespace.default.link.runtime.shared_libs += libpac.so |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 65 | |
chenbruce | d771740 | 2019-01-29 11:52:41 +0800 | [diff] [blame] | 66 | # When libnetd_resolv.so can't be found in the default namespace, search for it |
| 67 | # in the resolv namespace. Don't allow any other libraries from the resolv namespace |
| 68 | # to be loaded in the default namespace. |
chenbruce | aa87fd5 | 2019-01-24 13:01:21 +0800 | [diff] [blame] | 69 | namespace.default.link.resolv.shared_libs = libnetd_resolv.so |
| 70 | |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 71 | ############################################################################### |
| 72 | # "runtime" APEX namespace |
| 73 | # |
| 74 | # This namespace exposes externally accessible libraries from the Runtime APEX. |
Martin Stjernholm | c57ed29 | 2019-04-25 16:20:32 +0100 | [diff] [blame] | 75 | # Keep in sync with the "runtime" namespace in art/build/apex/ld.config.txt. |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 76 | ############################################################################### |
| 77 | namespace.runtime.isolated = true |
Martin Stjernholm | c57ed29 | 2019-04-25 16:20:32 +0100 | [diff] [blame] | 78 | # Visible to allow links to be created at runtime, e.g. through |
| 79 | # android_link_namespaces in libnativeloader. |
Nicolas Geoffray | a9b4f2b | 2019-01-26 01:06:43 +0000 | [diff] [blame] | 80 | namespace.runtime.visible = true |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 81 | |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 82 | namespace.runtime.search.paths = /apex/com.android.runtime/${LIB} |
| 83 | namespace.runtime.asan.search.paths = /apex/com.android.runtime/${LIB} |
| 84 | namespace.runtime.links = default |
Martin Stjernholm | 609236f | 2019-02-27 21:40:42 +0000 | [diff] [blame] | 85 | # Need allow_all_shared_libs because libart.so can dlopen oat files in |
| 86 | # /system/framework and /data. |
| 87 | # TODO(b/130340935): Use a dynamically created linker namespace similar to |
| 88 | # classloader-namespace for oat files, and tighten this up. |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 89 | namespace.runtime.link.default.allow_all_shared_libs = true |
| 90 | |
| 91 | ############################################################################### |
| 92 | # "media" APEX namespace |
| 93 | # |
| 94 | # This namespace is for libraries within the media APEX. |
| 95 | ############################################################################### |
| 96 | namespace.media.isolated = true |
| 97 | namespace.media.visible = true |
| 98 | |
| 99 | namespace.media.search.paths = /apex/com.android.media/${LIB} |
| 100 | namespace.media.asan.search.paths = /apex/com.android.media/${LIB} |
| 101 | |
Dongwon Kang | 3408eaa | 2019-02-22 00:47:13 -0800 | [diff] [blame] | 102 | namespace.media.permitted.paths = /apex/com.android.media/${LIB}/extractors |
| 103 | |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 104 | namespace.media.links = default |
Dongwon Kang | 5744cc4 | 2019-04-23 14:56:21 -0700 | [diff] [blame] | 105 | namespace.media.link.default.shared_libs = libbinder_ndk.so |
Dongwon Kang | a013e3d | 2019-03-15 14:43:07 -0700 | [diff] [blame] | 106 | namespace.media.link.default.shared_libs += libc.so |
Yifan Hong | 063b6be | 2019-03-29 13:17:35 -0700 | [diff] [blame] | 107 | namespace.media.link.default.shared_libs += libcgrouprc.so |
Dongwon Kang | a013e3d | 2019-03-15 14:43:07 -0700 | [diff] [blame] | 108 | namespace.media.link.default.shared_libs += libdl.so |
| 109 | namespace.media.link.default.shared_libs += liblog.so |
| 110 | namespace.media.link.default.shared_libs += libmediametrics.so |
| 111 | namespace.media.link.default.shared_libs += libmediandk.so |
| 112 | namespace.media.link.default.shared_libs += libm.so |
| 113 | namespace.media.link.default.shared_libs += libvndksupport.so |
| 114 | |
| 115 | namespace.media.link.default.shared_libs += libclang_rt.asan-aarch64-android.so |
| 116 | namespace.media.link.default.shared_libs += libclang_rt.asan-arm-android.so |
| 117 | namespace.media.link.default.shared_libs += libclang_rt.asan-i686-android.so |
| 118 | namespace.media.link.default.shared_libs += libclang_rt.asan-x86_64-android.so |
| 119 | namespace.media.link.default.shared_libs += libclang_rt.hwasan-aarch64-android.so |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 120 | |
| 121 | ############################################################################### |
| 122 | # "conscrypt" APEX namespace |
| 123 | # |
| 124 | # This namespace is for libraries within the conscrypt APEX. |
Martin Stjernholm | c57ed29 | 2019-04-25 16:20:32 +0100 | [diff] [blame] | 125 | # Keep in sync with the "conscrypt" namespace in art/build/apex/ld.config.txt. |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 126 | ############################################################################### |
| 127 | namespace.conscrypt.isolated = true |
| 128 | namespace.conscrypt.visible = true |
| 129 | |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 130 | namespace.conscrypt.search.paths = /apex/com.android.conscrypt/${LIB} |
| 131 | namespace.conscrypt.asan.search.paths = /apex/com.android.conscrypt/${LIB} |
Pete Bentley | 7b967bf | 2019-01-30 18:35:48 +0000 | [diff] [blame] | 132 | namespace.conscrypt.links = runtime,default |
Pete Bentley | cc6c50a | 2019-03-21 17:13:14 +0000 | [diff] [blame] | 133 | namespace.conscrypt.link.runtime.shared_libs = libandroidio.so |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 134 | namespace.conscrypt.link.default.shared_libs = libc.so |
| 135 | namespace.conscrypt.link.default.shared_libs += libm.so |
| 136 | namespace.conscrypt.link.default.shared_libs += libdl.so |
Tom Cherry | fe1f701 | 2019-02-08 11:55:36 -0800 | [diff] [blame] | 137 | namespace.conscrypt.link.default.shared_libs += liblog.so |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 138 | |
| 139 | ############################################################################### |
chenbruce | aa87fd5 | 2019-01-24 13:01:21 +0800 | [diff] [blame] | 140 | # "resolv" APEX namespace |
| 141 | # |
| 142 | # This namespace is for libraries within the resolv APEX. |
| 143 | ############################################################################### |
| 144 | namespace.resolv.isolated = true |
| 145 | namespace.resolv.visible = true |
| 146 | |
| 147 | namespace.resolv.search.paths = /apex/com.android.resolv/${LIB} |
| 148 | namespace.resolv.asan.search.paths = /apex/com.android.resolv/${LIB} |
| 149 | namespace.resolv.links = default |
| 150 | namespace.resolv.link.default.shared_libs = libc.so |
Yifan Hong | 063b6be | 2019-03-29 13:17:35 -0700 | [diff] [blame] | 151 | namespace.resolv.link.default.shared_libs += libcgrouprc.so |
chenbruce | aa87fd5 | 2019-01-24 13:01:21 +0800 | [diff] [blame] | 152 | namespace.resolv.link.default.shared_libs += libm.so |
| 153 | namespace.resolv.link.default.shared_libs += libdl.so |
| 154 | namespace.resolv.link.default.shared_libs += libbinder_ndk.so |
Tom Cherry | fe1f701 | 2019-02-08 11:55:36 -0800 | [diff] [blame] | 155 | namespace.resolv.link.default.shared_libs += liblog.so |
Dongwon Kang | 9dff515 | 2019-02-08 14:00:35 -0800 | [diff] [blame] | 156 | namespace.resolv.link.default.shared_libs += libvndksupport.so |
chenbruce | aa87fd5 | 2019-01-24 13:01:21 +0800 | [diff] [blame] | 157 | |
| 158 | ############################################################################### |
Jiyong Park | d7e6cb2 | 2018-03-20 01:12:31 +0900 | [diff] [blame] | 159 | # Namespace config for binaries under /postinstall. |
| 160 | # Only one default namespace is defined and it has no directories other than |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 161 | # /system/lib and /product/lib in the search paths. This is because linker |
| 162 | # calls realpath on the search paths and this causes selinux denial if the |
| 163 | # paths (/vendor, /odm) are not allowed to the poinstall binaries. |
| 164 | # There is no reason to allow the binaries to access the paths. |
Jiyong Park | d7e6cb2 | 2018-03-20 01:12:31 +0900 | [diff] [blame] | 165 | ############################################################################### |
| 166 | [postinstall] |
| 167 | namespace.default.isolated = false |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 168 | namespace.default.search.paths = /system/${LIB} |
| 169 | namespace.default.search.paths += /product/${LIB} |