اندازه صفحه، جزئیاتی است که در آن یک سیستم عامل حافظه را مدیریت می کند. اکثر پردازندههای مرکزی امروزه از اندازه صفحه 4 کیلوبایت پشتیبانی میکنند و بنابراین سیستمعامل اندروید و برنامهها در طول تاریخ ساخته و بهینهسازی شدهاند تا با اندازه صفحه 4 کیلوبایت اجرا شوند. CPU های ARM از اندازه صفحه بزرگتر 16 کیلوبایت پشتیبانی می کنند و با شروع اندروید 15، AOSP از ساخت اندروید با اندازه صفحه 16 کیلوبایت نیز پشتیبانی می کند. این گزینه از حافظه اضافی استفاده می کند اما عملکرد سیستم را بهبود می بخشد. از اندروید 15، این گزینه بهطور پیشفرض فعال نیست، اما بهعنوان یک حالت توسعهدهنده یا یک گزینه توسعهدهنده برای OEMها و توسعهدهندگان برنامهها در دسترس است تا در آینده برای تغییر به حالت 16 کیلوبایتی در همه جا آماده شوند.
اندازه صفحه 16 کیلوبایت را فعال کنید
صفحات 16 کیلوبایتی فقط در اهداف arm64
با هسته های 16 کیلوبایتی پشتیبانی می شوند. با این حال، گزینه ای برای شبیه سازی فضای کاربری 16 کیلوبایتی در x86_64
برای Cuttlefish نیز وجود دارد.
برای اهداف arm64
، اگر از Kleaf برای ساخت هسته خود استفاده می کنید، --page_size=16k
هسته را در حالت 16 کیلوبایتی می سازد. اگر مستقیماً از پیکربندی هسته لینوکس استفاده میکنید، میتوانید صفحات 16 کیلوبایتی را با تنظیم CONFIG_ARM64_16K_PAGES
به جای CONFIG_ARM64_4K_PAGES
انتخاب کنید.
برای فعال کردن پشتیبانی از اندازه صفحه 16 کیلوبایت در فضای کاربران اندروید، گزینه های ساخت زیر را روی محصول خود تنظیم کنید:
-
PRODUCT_NO_BIONIC_PAGE_SIZE_MACRO := true
تعریفPAGE_SIZE
حذف می کند و باعث می شود که اجزاء اندازه صفحه را در زمان اجرا تعیین کنند. -
PRODUCT_MAX_PAGE_SIZE_SUPPORTED := 16384
که تضمین می کند فایل های پلتفرم ELF با تراز 16 کیلوبایتی ساخته شده اند. این اندازه بزرگتر از حد مورد نیاز برای سازگاری در آینده است. با تراز ELF 16 کیلوبایتی، هسته می تواند اندازه صفحه 4 کیلوبایت/16 کیلوبایت را پشتیبانی کند.
پرچمهای ساخت را تأیید کنید
پس از انتخاب هدف lunch
، بررسی کنید که پرچمهای ساخت به درستی در محیط تنظیم شده باشند:
$ source build/envsetup.sh
$ lunch target
$ get_build_var TARGET_MAX_PAGE_SIZE_SUPPORTED
16384
$ get_build_var TARGET_NO_BIONIC_PAGE_SIZE_MACRO
true
اگر دو دستور قبلی به ترتیب 16384
و true
را برگردانند، پرچم های ساخت شما به درستی تنظیم شده اند.
ساخت کتابخانه های مشترک با تراز ELF 16 کیلوبایت
برای ساخت کتابخانه های مشترک که بخشی از پروژه اندروید هستند، تنظیمات قبلی در Enable 16 KB اندازه صفحه کافی است:
-
PRODUCT_NO_BIONIC_PAGE_SIZE_MACRO := true
-
PRODUCT_MAX_PAGE_SIZE_SUPPORTED := 16384
برای ساخت کتابخانه های مشترک که بخشی از پروژه اندروید نیستند، باید این پرچم پیوند دهنده را پاس کنید:
-Wl,-z,max-page-size=16384
باینری ها و پیش ساخته ها را برای تراز ELF 16 کیلوبایتی بررسی کنید
بهترین راه برای تأیید رفتار تراز و زمان اجرا، آزمایش و اجرا بر روی یک هسته کامپایل شده 16 کیلوبایتی است. با این حال، برای اینکه زودتر برخی از مسائل را تشخیص دهید:
با شروع Android W (AOSP آزمایشی)، میتوانید
PRODUCT_CHECK_PREBUILT_MAX_PAGE_SIZE := true
در زمان ساخت تنظیم کنید. ازignore_max_page_size: true
درAndroid.bp
وLOCAL_IGNORE_MAX_PAGE_SIZE := true
درAndroid.mk
استفاده کنید تا موقتاً آنها را نادیده بگیرید. این تنظیمات همه پیش ساختهها را تأیید میکنند و به شما امکان میدهند تشخیص دهید که چه زمانی یکی بهروزرسانی میشود اما 16 کیلوبایت تراز نیست.میتوانید
atest elf_alignment_test
را اجرا کنید که تراز فایلهای ELF روی دستگاه را در دستگاههایی که با Android 15 و بالاتر راهاندازی میشوند تأیید میکند.