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 | |
Jiyong Park | 450cff4 | 2017-04-05 14:24:14 +0900 | [diff] [blame] | 17 | [legacy] |
| 18 | namespace.default.isolated = false |
Jiyong Park | 2498e1b | 2017-12-12 22:11:47 +0900 | [diff] [blame] | 19 | |
| 20 | namespace.default.search.paths = /system/${LIB} |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 21 | namespace.default.search.paths += /product/${LIB} |
Jiyong Park | 2498e1b | 2017-12-12 22:11:47 +0900 | [diff] [blame] | 22 | namespace.default.search.paths += /vendor/${LIB} |
| 23 | namespace.default.search.paths += /odm/${LIB} |
| 24 | |
| 25 | namespace.default.asan.search.paths = /data/asan/system/${LIB} |
| 26 | namespace.default.asan.search.paths += /system/${LIB} |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 27 | namespace.default.asan.search.paths += /data/asan/product/${LIB} |
| 28 | namespace.default.asan.search.paths += /product/${LIB} |
Jiyong Park | 2498e1b | 2017-12-12 22:11:47 +0900 | [diff] [blame] | 29 | namespace.default.asan.search.paths += /data/asan/vendor/${LIB} |
| 30 | namespace.default.asan.search.paths += /vendor/${LIB} |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 31 | namespace.default.asan.search.paths += /data/asan/odm/${LIB} |
| 32 | namespace.default.asan.search.paths += /odm/${LIB} |
Jiyong Park | d7e6cb2 | 2018-03-20 01:12:31 +0900 | [diff] [blame] | 33 | |
| 34 | ############################################################################### |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 35 | # APEX related namespaces. |
| 36 | ############################################################################### |
| 37 | |
| 38 | additional.namespaces = runtime,conscrypt,media |
| 39 | namespace.default.asan.permitted.paths += /apex/com.android.resolv/${LIB} |
| 40 | |
| 41 | # Keep in sync with ld.config.txt in the com.android.runtime APEX. |
| 42 | namespace.default.links = runtime |
| 43 | namespace.default.asan.links = runtime |
| 44 | # Visible because some libraries are dlopen'ed, e.g. libopenjdk is dlopen'ed by |
| 45 | # libart. |
| 46 | namespace.default.visible = true |
| 47 | namespace.default.link.runtime.shared_libs = libart.so:libartd.so |
| 48 | namespace.default.link.runtime.shared_libs += libdexfile_external.so |
| 49 | namespace.default.link.runtime.shared_libs += libnativebridge.so |
| 50 | namespace.default.link.runtime.shared_libs += libnativehelper.so |
| 51 | namespace.default.link.runtime.shared_libs += libnativeloader.so |
| 52 | |
| 53 | ############################################################################### |
| 54 | # "runtime" APEX namespace |
| 55 | # |
| 56 | # This namespace exposes externally accessible libraries from the Runtime APEX. |
| 57 | ############################################################################### |
| 58 | namespace.runtime.isolated = true |
| 59 | |
| 60 | # Keep in sync with ld.config.txt in the com.android.runtime APEX. |
| 61 | namespace.runtime.search.paths = /apex/com.android.runtime/${LIB} |
| 62 | namespace.runtime.asan.search.paths = /apex/com.android.runtime/${LIB} |
| 63 | namespace.runtime.links = default |
| 64 | # TODO(b/119867084): Restrict to Bionic dlopen dependencies and PALette library |
| 65 | # when it exists. |
| 66 | namespace.runtime.link.default.allow_all_shared_libs = true |
| 67 | |
| 68 | ############################################################################### |
| 69 | # "media" APEX namespace |
| 70 | # |
| 71 | # This namespace is for libraries within the media APEX. |
| 72 | ############################################################################### |
| 73 | namespace.media.isolated = true |
| 74 | namespace.media.visible = true |
| 75 | |
| 76 | namespace.media.search.paths = /apex/com.android.media/${LIB} |
| 77 | namespace.media.asan.search.paths = /apex/com.android.media/${LIB} |
| 78 | |
| 79 | namespace.media.links = default |
| 80 | namespace.media.link.default.shared_libs = %LLNDK_LIBRARIES% |
| 81 | namespace.media.link.default.shared_libs += libandroid.so |
| 82 | namespace.media.link.default.shared_libs += libbinder_ndk.so |
Dongwon Kang | 0095e35 | 2019-01-25 09:26:17 -0800 | [diff] [blame^] | 83 | namespace.media.link.default.shared_libs += libmediametrics.so |
Nicolas Geoffray | ad12560 | 2019-01-24 21:20:20 +0000 | [diff] [blame] | 84 | namespace.media.link.default.shared_libs += %SANITIZER_RUNTIME_LIBRARIES% |
| 85 | |
| 86 | ############################################################################### |
| 87 | # "conscrypt" APEX namespace |
| 88 | # |
| 89 | # This namespace is for libraries within the conscrypt APEX. |
| 90 | ############################################################################### |
| 91 | namespace.conscrypt.isolated = true |
| 92 | namespace.conscrypt.visible = true |
| 93 | |
| 94 | # Keep in sync with ld.config.txt in the com.android.runtime APEX. |
| 95 | namespace.conscrypt.search.paths = /apex/com.android.conscrypt/${LIB} |
| 96 | namespace.conscrypt.asan.search.paths = /apex/com.android.conscrypt/${LIB} |
| 97 | namespace.conscrypt.links = default |
| 98 | namespace.conscrypt.link.default.shared_libs = libc.so |
| 99 | namespace.conscrypt.link.default.shared_libs += libm.so |
| 100 | namespace.conscrypt.link.default.shared_libs += libdl.so |
| 101 | |
| 102 | ############################################################################### |
Jiyong Park | d7e6cb2 | 2018-03-20 01:12:31 +0900 | [diff] [blame] | 103 | # Namespace config for binaries under /postinstall. |
| 104 | # 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] | 105 | # /system/lib and /product/lib in the search paths. This is because linker |
| 106 | # calls realpath on the search paths and this causes selinux denial if the |
| 107 | # paths (/vendor, /odm) are not allowed to the poinstall binaries. |
| 108 | # There is no reason to allow the binaries to access the paths. |
Jiyong Park | d7e6cb2 | 2018-03-20 01:12:31 +0900 | [diff] [blame] | 109 | ############################################################################### |
| 110 | [postinstall] |
| 111 | namespace.default.isolated = false |
changho.shin | 715b1aa | 2018-11-28 15:15:16 +0900 | [diff] [blame] | 112 | namespace.default.search.paths = /system/${LIB} |
| 113 | namespace.default.search.paths += /product/${LIB} |