اندازه صفحه 16 کیلوبایت

اندازه صفحه، جزئیاتی است که در آن یک سیستم عامل حافظه را مدیریت می کند. اکثر پردازنده‌های مرکزی امروزه از اندازه صفحه 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 و بالاتر راه‌اندازی می‌شوند تأیید می‌کند.