Linker dinamis menangani dua tantangan dalam desain Treble VNDK:
- Pustaka bersama SP-HAL dan dependensinya, termasuk pustaka VNDK-SP, dimuat ke dalam proses kerangka kerja. Harus ada beberapa mekanisme untuk mencegah konflik simbol.
-
dlopen()
danandroid_dlopen_ext()
dapat memperkenalkan beberapa dependensi runtime yang tidak terlihat pada waktu build dan mungkin sulit dideteksi menggunakan analisis statis.
Kedua tantangan ini dapat diselesaikan dengan mekanisme namespace linker . Mekanisme ini disediakan oleh linker dinamis. Itu dapat mengisolasi perpustakaan bersama di ruang nama tautan yang berbeda sehingga perpustakaan dengan nama perpustakaan yang sama tetapi dengan simbol yang berbeda tidak akan bentrok.
Di sisi lain, mekanisme namespace linker memberikan fleksibilitas sehingga beberapa perpustakaan bersama dapat diekspor oleh namespace linker dan digunakan oleh namespace linker lain. Pustaka bersama yang diekspor ini dapat menjadi antarmuka pemrograman aplikasi yang bersifat publik untuk program lain sambil menyembunyikan detail implementasinya di dalam ruang nama tautannya.
Misalnya, /system/lib[64]/libcutils.so
dan /system/lib[64]/vndk-sp-${VER}/libcutils.so
adalah dua pustaka bersama. Kedua perpustakaan ini dapat memiliki simbol yang berbeda. Mereka dimuat ke ruang nama penghubung yang berbeda sehingga modul kerangka kerja dapat bergantung pada /system/lib[64]/libcutils.so
dan perpustakaan bersama SP-HAL dapat bergantung pada /system/lib[64]/vndk-sp-${VER}/libcutils.so
.
Di sisi lain, /system/lib[64]/libc.so
adalah contoh perpustakaan umum yang diekspor oleh namespace linker dan diimpor ke banyak namespace linker. Dependensi /system/lib[64]/libc.so
, seperti libnetd_client.so
, dimuat ke dalam namespace tempat /system/lib[64]/libc.so
berada. Ruang nama lain tidak akan memiliki akses ke dependensi tersebut. Mekanisme ini merangkum detail implementasi sambil menyediakan antarmuka publik.
Bagaimana cara kerjanya?
Penaut dinamis bertanggung jawab untuk memuat pustaka bersama yang ditentukan dalam entri DT_NEEDED
atau pustaka bersama yang ditentukan oleh argumen dlopen()
atau android_dlopen_ext()
. Dalam kedua kasus tersebut, dynamic linker menemukan namespace linker tempat pemanggil berada dan mencoba memuat dependensi ke dalam namespace linker yang sama. Jika penaut dinamis tidak dapat memuat pustaka bersama ke dalam ruang nama penaut yang ditentukan, penaut akan meminta ruang nama penaut tertaut untuk pustaka bersama yang diekspor.
Format file konfigurasi
Format file konfigurasi didasarkan pada format file INI. File konfigurasi tipikal terlihat seperti ini:
dir.system = /system/bin dir.system = /system/xbin dir.vendor = /vendor/bin [system] additional.namespaces = sphal,vndk namespace.default.isolated = true namespace.default.search.paths = /system/${LIB} namespace.default.permitted.paths = /system/${LIB}/hw namespace.default.asan.search.paths = /data/asan/system/${LIB}:/system/${LIB} namespace.default.asan.permitted.paths = /data/asan/system/${LIB}/hw:/system/${LIB}/hw namespace.sphal.isolated = true namespace.sphal.visible = true namespace.sphal.search.paths = /odm/${LIB}:/vendor/${LIB} namespace.sphal.permitted.paths = /odm/${LIB}:/vendor/${LIB} namespace.sphal.asan.search.paths = /data/asan/odm/${LIB}:/odm/${LIB} namespace.sphal.asan.search.paths += /data/asan/vendor/${LIB}:/vendor/${LIB} namespace.sphal.asan.permitted.paths = /data/asan/odm/${LIB}:/odm/${LIB} namespace.sphal.asan.permitted.paths += /data/asan/vendor/${LIB}:/vendor/${LIB} namespace.sphal.links = default,vndk namespace.sphal.link.default.shared_libs = libc.so:libm.so namespace.sphal.link.vndk.shared_libs = libbase.so:libcutils.so namespace.vndk.isolated = true namespace.vndk.search.paths = /system/${LIB}/vndk-sp-29 namespace.vndk.permitted.paths = /system/${LIB}/vndk-sp-29 namespace.vndk.links = default namespace.vndk.link.default.shared_libs = libc.so:libm.so [vendor] namespace.default.isolated = false namespace.default.search.paths = /vendor/${LIB}:/system/${LIB}
File konfigurasi meliputi:
- Beberapa properti pemetaan direktori-bagian di awal untuk linker dinamis untuk memilih bagian yang efektif.
- Beberapa bagian konfigurasi ruang nama tautan:
- Setiap bagian berisi beberapa ruang nama (simpul grafik) dan beberapa tautan mundur antara ruang nama (busur grafik).
- Setiap namespace memiliki isolasi, jalur pencarian, jalur yang diizinkan, dan pengaturan visibilitasnya sendiri.
Tabel di bawah ini menjelaskan arti dari setiap properti secara rinci.
Properti pemetaan bagian direktori
Properti | Keterangan | Contoh |
---|---|---|
| Jalur ke direktori tempat bagian Setiap properti memetakan executable di bawah direktori ke bagian konfigurasi namespace linker. Mungkin ada dua (atau lebih) properti yang memiliki | Ini menunjukkan bahwa konfigurasi yang ditentukan di bagian Konfigurasi yang ditentukan di bagian |
Sifat relasi
Properti | Keterangan | Contoh |
---|---|---|
additional. namespaces | Daftar ruang nama tambahan yang dipisahkan koma (selain ruang nama | Ini menunjukkan bahwa ada tiga ruang nama ( |
namespace. name . links | Daftar ruang nama cadangan yang dipisahkan koma. Jika pustaka bersama tidak dapat ditemukan di ruang nama saat ini, penaut dinamis mencoba memuat pustaka bersama dari ruang nama cadangan. Namespace yang ditentukan di awal daftar memiliki prioritas lebih tinggi. | Jika pustaka bersama atau yang dapat dieksekusi meminta pustaka bersama yang tidak dapat dimuat ke ruang nama Dan kemudian, jika pustaka bersama tidak dapat dimuat dari namespace Terakhir, jika semua upaya gagal, tautan dinamis mengembalikan kesalahan. |
namespace. name . link. other . shared_libs | Daftar pustaka bersama yang dipisahkan titik dua yang dapat dicari di ruang nama Properti ini tidak dapat digunakan dengan | Ini menunjukkan bahwa tautan mundur hanya menerima |
namespace. name . link. other . allow_all_shared_libs | Nilai boolean yang menunjukkan apakah semua pustaka bersama dapat dicari di namespace Properti ini tidak dapat digunakan dengan | Ini menunjukkan bahwa semua nama perpustakaan dapat berjalan melalui tautan mundur dari |
Properti ruang nama
Properti | Keterangan | Contoh |
---|---|---|
namespace. name . isolated | Nilai boolean yang menunjukkan apakah penaut dinamis harus memeriksa di mana perpustakaan bersama berada. Jika Jika | Ini menunjukkan bahwa hanya perpustakaan bersama di |
namespace. name . search.paths | Daftar direktori yang dipisahkan titik dua untuk mencari pustaka bersama. Direktori yang ditentukan dalam Saat Misalnya, jika | Ini menunjukkan bahwa penaut dinamis mencari |
namespace. name . asan.search.paths | Daftar direktori yang dipisahkan titik dua untuk mencari pustaka bersama saat AddressSanitizer (ASan) diaktifkan. | Ini menunjukkan bahwa ketika ASan diaktifkan, penaut dinamis mencari |
namespace. name . permitted.paths | Daftar direktori yang dipisahkan titik dua (termasuk subdirektori) tempat tautan dinamis dapat memuat pustaka bersama (selain Pustaka bersama yang berada di bawah subdirektori Jika | Ini menunjukkan bahwa pustaka bersama di bawah Misalnya, tanpa |
namespace. name . asan.permitted.paths | Daftar direktori yang dipisahkan titik dua tempat tautan dinamis dapat memuat pustaka bersama saat ASan diaktifkan. | Ini menunjukkan bahwa ketika ASan diaktifkan, pustaka bersama di bawah |
namespace. name . visible | Nilai boolean yang menunjukkan apakah program (selain Jika Jika | Ini menunjukkan bahwa |
Pembuatan namespace penautan
Di Android 11, konfigurasi penaut dibuat saat runtime di bawah /linkerconfig
alih-alih menggunakan file teks biasa di ${android-src}/system/core/rootdir/etc
. Konfigurasi dibuat saat boot berdasarkan lingkungan runtime, yang mencakup item berikut:
- Jika perangkat mendukung VNDK
- Versi VNDK target partisi vendor
- Versi VNDK partisi produk
- Modul APEX yang terpasang
Konfigurasi linker dibuat dengan menyelesaikan dependensi antara ruang nama linker. Misalnya, jika ada pembaruan pada modul APEX yang menyertakan pembaruan ketergantungan, konfigurasi penaut dihasilkan yang mencerminkan perubahan ini. Detail lebih lanjut untuk membuat konfigurasi tautan dapat ditemukan di ${android-src}/system/linkerconfig
.
Isolasi namespace linker
Ada tiga jenis konfigurasi. Bergantung pada nilai PRODUCT_TREBLE_LINKER_NAMESPACES
dan BOARD_VNDK_VERSION
di BoardConfig.mk
, konfigurasi yang sesuai dibuat saat boot.
PRODUCT_TREBLE_ LINKER_NAMESPACES | BOARD_VNDK_ VERSION | Konfigurasi yang dipilih | Persyaratan VTS |
---|---|---|---|
true | current | VNDK | Wajib untuk perangkat yang diluncurkan dengan Android 9 atau lebih tinggi |
Kosong | VNDK Lite | Wajib untuk perangkat yang diluncurkan dengan Android 8.x | |
false | Kosong | Legacy | Untuk perangkat non-Treble |
Konfigurasi VNDK Lite mengisolasi pustaka bersama SP-HAL dan VNDK-SP. Di Android 8.0, ini harus berupa file konfigurasi untuk penaut dinamis jika PRODUCT_TREBLE_LINKER_NAMESPACES
bernilai true
.
Konfigurasi VNDK juga mengisolasi pustaka bersama SP-HAL dan VNDK-SP. Selain itu, konfigurasi ini menyediakan isolasi linker dinamis penuh. Ini memastikan bahwa modul di partisi sistem tidak akan bergantung pada pustaka bersama di partisi vendor dan sebaliknya.
Di Android 8.1 atau lebih tinggi, konfigurasi VNDK adalah konfigurasi default dan sangat disarankan untuk mengaktifkan isolasi linker dinamis penuh dengan menyetel BOARD_VNDK_VERSION
ke current
.
Konfigurasi VNDK
Konfigurasi VNDK mengisolasi dependensi pustaka bersama antara partisi sistem dan partisi vendor. Dibandingkan dengan konfigurasi yang disebutkan pada subbagian sebelumnya, perbedaannya diuraikan sebagai berikut:
Proses kerangka
-
default
,vndk
,sphal
, danrs
namespaces dibuat. - Semua ruang nama diisolasi.
- Pustaka bersama sistem dimuat ke dalam namespace
default
. - SP-HAL dimuat ke dalam ruang nama
sphal
. - Pustaka bersama VNDK-SP dimuat ke dalam namespace
vndk
.
-
Proses vendor
-
default
,vndk
, dan ruang namasystem
dibuat. - Namespace
default
diisolasi. - Pustaka bersama vendor dimuat ke dalam namespace
default
. - Pustaka bersama VNDK dan VNDK-SP dimuat ke dalam ruang nama
vndk
. - LL-NDK dan dependensinya dimuat ke dalam namespace
system
.
-
Hubungan antara ruang nama penghubung diilustrasikan di bawah ini.
Pada gambar di atas, LL-NDK dan VNDK-SP adalah singkatan dari shared library berikut:
- LL-NDK
-
libEGL.so
-
libGLESv1_CM.so
-
libGLESv2.so
-
libGLESv3.so
-
libandroid_net.so
-
libc.so
-
libdl.so
-
liblog.so
-
libm.so
-
libnativewindow.so
-
libneuralnetworks.so
-
libsync.so
-
libvndksupport.so
-
libvulkan.so
-
- VNDK-SP
-
android.hardware.graphics.common@1.0.so
-
android.hardware.graphics.mapper@2.0.so
-
android.hardware.renderscript@1.0.so
-
android.hidl.memory@1.0.so
-
libRSCpuRef.so
-
libRSDriver.so
-
libRS_internal.so
-
libbase.so
-
libbcinfo.so
-
libc++.so
-
libcutils.so
-
libhardware.so
-
libhidlbase.so
-
libhidlmemory.so
-
libhidltransport.so
-
libhwbinder.so
-
libion.so
-
libutils.so
-
libz.so
-
Anda dapat menemukan detail lebih lanjut di /linkerconfig/ld.config.txt
dari perangkat.
Konfigurasi VNDK Lite
Mulai Android 8.0, penaut dinamis dikonfigurasi untuk mengisolasi pustaka bersama SP-HAL dan VNDK-SP sehingga simbolnya tidak bertentangan dengan pustaka bersama kerangka kerja lainnya. Hubungan antara ruang nama linker ditunjukkan di bawah ini.
LL-NDK dan VNDK-SP adalah singkatan dari shared library berikut:
- LL-NDK
-
libEGL.so
-
libGLESv1_CM.so
-
libGLESv2.so
-
libc.so
-
libdl.so
-
liblog.so
-
libm.so
-
libnativewindow.so
-
libstdc++.so
(tidak dalam konfigurasi) -
libsync.so
-
libvndksupport.so
-
libz.so
(dipindahkan ke VNDK-SP dalam konfigurasi)
-
- VNDK-SP
-
android.hardware.graphics.common@1.0.so
-
android.hardware.graphics.mapper@2.0.so
-
android.hardware.renderscript@1.0.so
-
android.hidl.memory@1.0.so
-
libbase.so
-
libc++.so
-
libcutils.so
-
libhardware.so
-
libhidlbase.so
-
libhidlmemory.so
-
libhidltransport.so
-
libhwbinder.so
-
libion.so
-
libutils.so
-
Tabel di bawah ini mencantumkan konfigurasi ruang nama untuk proses kerangka kerja, yang dikutip dari bagian [system]
dalam konfigurasi VNDK Lite.
ruang nama | Properti | Nilai |
---|---|---|
default | search.paths | /system/${LIB} /odm/${LIB} /vendor/${LIB} /product/${LIB} |
isolated | false | |
sphal | search.paths | /odm/${LIB} /vendor/${LIB} |
permitted.paths | /odm/${LIB} /vendor/${LIB} | |
isolated | true | |
visible | true | |
links | default,vndk,rs | |
link.default.shared_libs | LL-NDK | |
link.vndk.shared_libs | VNDK-SP | |
link.rs.shared_libs | libRS_internal.so | |
vndk (untuk VNDK-SP) | search.paths | /odm/${LIB}/vndk-sp /vendor/${LIB}/vndk-sp /system/${LIB}/vndk-sp-${VER} |
permitted.paths | /odm/${LIB}/hw /odm/${LIB}/egl /vendor/${LIB}/hw /vendor/${LIB}/egl /system/${LIB}/vndk-sp-${VER}/hw | |
isolated | true | |
visible | true | |
links | default | |
link.default.shared_libs | LL-NDK | |
rs (untuk RenderScript) | search.paths | /odm/${LIB}/vndk-sp /vendor/${LIB}/vndk-sp /system/${LIB}/vndk-sp-${VER} /odm/${LIB} /vendor/${LIB} |
permitted.paths | /odm/${LIB} /vendor/${LIB} /data (untuk kernel RS yang dikompilasi) | |
isolated | true | |
visible | true | |
links | default,vndk | |
link.default.shared_libs | LL-NDKlibmediandk.so libft2.so | |
link.vndk.shared_libs | VNDK-SP |
Tabel di bawah ini menyajikan konfigurasi ruang nama untuk proses vendor, yang dikutip dari bagian [vendor]
dalam konfigurasi VNDK Lite.
ruang nama | Properti | Nilai |
---|---|---|
default | search.paths | /odm/${LIB} /odm/${LIB}/vndk /odm/${LIB}/vndk-sp /vendor/${LIB} /vendor/${LIB}/vndk /vendor/${LIB}/vndk-sp /system/${LIB}/vndk-${VER} /system/${LIB}/vndk-sp-${VER} /system/${LIB} (tidak digunakan lagi)/product/${LIB} (tidak digunakan lagi) |
isolated | false |
Rincian lebih lanjut dapat ditemukan di /linkerconfig/ld.config.txt
dari perangkat.
Sejarah dokumen
Perubahan Android 11
- Di Android 11, file
ld.config.*.txt
statis dihapus dari basis kode dan LinkerConfig membuatnya dalam waktu proses.
Android 9 perubahan
- Di Android 9, ruang nama penaut
vndk
ditambahkan ke proses vendor dan pustaka bersama VNDK diisolasi dari ruang nama penaut default. - Ganti
PRODUCT_FULL_TREBLE
denganPRODUCT_TREBLE_LINKER_NAMESPACES
yang lebih spesifik. - Android 9 mengubah nama file konfigurasi dynamic linker berikut.
Android 8.x Android 9 Keterangan ld.config.txt.in
ld.config.txt
Untuk perangkat dengan isolasi namespace linker runtime ld.config.txt
ld.config.vndk_lite.txt
Untuk perangkat dengan isolasi namespace linker VNDK-SP ld.config.legacy.txt
ld.config.legacy.txt
Untuk perangkat lama yang menjalankan Android 7.x atau lebih rendah - Hapus
android.hardware.graphics.allocator@2.0.so
. -
product
dan partisiodm
ditambahkan.