اندروید 9 شامل تغییرات زیر در مشخصات دلیل بوت لودر است.
دلایل بوت
یک بوت لودر از سخت افزار و منابع حافظه منحصر به فرد در دسترس استفاده می کند تا مشخص کند که چرا دستگاه راه اندازی مجدد شده است، سپس با افزودن androidboot.bootreason=<reason>
به خط فرمان هسته Android برای راه اندازی آن، این تصمیم را به اطلاع می رساند. سپس init
این خط فرمان را برای انتشار به ویژگی Android bootloader_boot_reason_prop
ترجمه میکند ( ro.boot.bootreason
). برای دستگاههایی که با Android 12 یا بالاتر راهاندازی میشوند، با استفاده از هسته نسخه 5.10 یا بالاتر، androidboot.bootreason=<reason>
به جای خط فرمان هسته به bootconfig اضافه میشود.
مشخصات دلیل بوت
نسخههای قبلی اندروید یک فرمت دلیل راهاندازی را مشخص میکرد که از فاصله استفاده نمیکرد، همه حروف کوچک بود، الزامات کمی را شامل میشد (مانند گزارش kernel_panic
، watchdog
، cold
/ warm
/ hard
)، و به دلایل منحصربهفرد دیگری اجازه میداد. این مشخصات شل منجر به تکثیر صدها رشته دلیل بوت سفارشی (و گاهی بی معنی) شد که به نوبه خود منجر به وضعیت غیرقابل مدیریت شد. از نسخه فعلی اندروید، شتاب محض محتوای تقریبا غیرقابل تجزیه یا بیمعنی که توسط بوتلودر ارسال شده است، مشکلات انطباق را برای bootloader_boot_reason_prop
ایجاد کرده است.
با انتشار اندروید 9، تیم اندروید تشخیص می دهد که bootloader_boot_reason_prop
قدیمی دارای شتاب قابل توجهی است و نمی توان آن را در زمان اجرا دوباره نوشت. بنابراین، هرگونه پیشرفت در مشخصات دلیل بوت باید از تعامل با توسعه دهندگان بوت لودر و تغییراتی در سیستم موجود باشد. برای این منظور تیم اندروید عبارتند از:
- تعامل با توسعه دهندگان بوت لودر برای تشویق آنها به:
- دلایل متعارف، قابل تجزیه، و قابل تشخیص را برای
bootloader_boot_reason_prop
ارائه دهید. - در لیست
system/core/bootstat/bootstat.cpp
kBootReasonMap
شرکت کنید.
- دلایل متعارف، قابل تجزیه، و قابل تشخیص را برای
- افزودن یک منبع کنترل شده و قابل بازنویسی در زمان اجرا
system_boot_reason_prop
(sys.boot.reason
). مجموعه محدودی از برنامههای سیستم (مانندbootstat
وinit
) میتوانند این ویژگی را بازنویسی کنند، اما به همه برنامهها میتوان حقوق قانونی برای خواندن آن اعطا کرد. - اطلاع دادن به کاربران از دلیل راهاندازی برای اینکه منتظر بمانند تا پس از نصب دادههای کاربر قبل از اعتماد به محتوای موجود در ویژگی دلیل بوت سیستم
system_boot_reason_prop
.
چرا اینقدر دیر؟ در حالی که bootloader_boot_reason_prop
در اوایل راهاندازی در دسترس است، توسط خطمشی امنیتی Android بر اساس نیاز مسدود میشود زیرا اطلاعات نادرست، غیرقابل تجزیه و غیر متعارف را نشان میدهد. در اکثر مواقع، فقط توسعه دهندگانی که دانش عمیقی از سیستم بوت دارند باید به این اطلاعات دسترسی داشته باشند. یک API تصفیهشده، قابل تجزیه و متعارف به دلیل راهاندازی با system_boot_reason_prop
تنها پس از نصب دادههای کاربر میتواند بهطور قابل اعتماد و دقیق انتخاب شود. به طور مشخص:
- قبل از نصب دادههای کاربر،
system_boot_reason_prop
حاوی مقدارbootloader_boot_reason_prop
خواهد بود. - پس از نصب دادههای کاربر،
system_boot_reason_prop
ممکن است برای سازگاری یا گزارش اطلاعات دقیقتر بهروزرسانی شود.
به همین دلیل، اندروید 9 مدت زمانی را که میتوان دلیل راهاندازی را بهطور رسمی دریافت کرد، تمدید میکند، و آن را از دقیق بودن فوری در بوت (با bootloader_boot_reason_prop
) به در دسترس بودن تنها پس از نصب دادههای کاربر (با system_boot_reason_prop
) تغییر میدهد.
منطق بوت استات به یک bootloader_boot_reason_prop
آموزنده تر و سازگارتر بستگی دارد. هنگامی که آن ویژگی از یک قالب قابل پیش بینی استفاده می کند، دقت تمام سناریوهای راه اندازی مجدد و خاموش کردن کنترل شده را بهبود می بخشد، که به نوبه خود دقت و معنای system_boot_reason_prop
را بهبود می بخشد و گسترش می دهد.
فرمت دلیل بوت متعارف
فرمت دلیل بوت متعارف برای bootloader_boot_reason_prop
در اندروید 9 از دستور زیر استفاده می کند:
<reason>,<subreason>,<detail>…
قوانین قالب بندی:
- حروف کوچک
- بدون جای خالی (از زیر خط استفاده کنید)
- همه کاراکترهای قابل چاپ
-
reason
جدا شده با کاما،subreason
، و یک یا چند موردdetail
.- یک
reason
ضروری که نشان دهنده بالاترین اولویت دلیل راه اندازی مجدد یا خاموش شدن دستگاه است. - یک
subreason
اختیاری که نشاندهنده خلاصهای از این است که چرا دستگاه مجبور شد راهاندازی مجدد یا خاموش شود (یا چه کسی دستگاه را راهاندازی یا خاموش کرده است). - یک یا چند مقدار
detail
اختیاری. یکdetail
ممکن است به یک زیرسیستم اشاره کند تا در تعیین اینکه کدام سیستم خاص منجر بهsubreason
شده است کمک کند. شما می توانید مقادیر متعددیdetail
را مشخص کنید، که عموماً باید از یک سلسله مراتب اهمیت پیروی کنند. با این حال، گزارش مقادیر چندگانهdetail
با اهمیت یکسان نیز قابل قبول است.
- یک
یک مقدار خالی برای bootloader_boot_reason_prop
غیرقانونی در نظر گرفته میشود (زیرا این امر به سایر عوامل اجازه میدهد پس از این واقعیت، دلیل بوت را تزریق کنند).
الزامات دلیل
مقدار داده شده برای reason
(اولین بازه، قبل از خاتمه یا کاما) باید از مجموعه زیر باشد که به دلایل هسته، قوی و بلامنت تقسیم می شود:
- مجموعه هسته:
- "
watchdog"
-
"kernel_panic"
- "
- مجموعه قوی:
-
"recovery"
-
"bootloader"
-
- مجموعه بلانت:
-
"cold"
. به طور کلی بازنشانی کامل همه دستگاه ها از جمله حافظه را نشان می دهد. -
"hard"
. به طور کلی نشان می دهد که سخت افزار حالت بازنشانی خود را دارد وramoops
باید محتوای پایدار را حفظ کند. -
"warm"
. به طور کلی نشان میدهد که حافظه و دستگاهها حالتی را حفظ میکنند، و ذخیره پشتیبانramoops
(درایورpstore
در هسته را ببینید) حاوی محتوای پایدار است. -
"shutdown"
-
"reboot"
. به طور کلی به این معنی است که وضعیتramoops
ناشناخته است و وضعیت سخت افزار ناشناخته است. این مقدار مهم است زیرا مقادیرcold
،hard
وwarm
سرنخ هایی را در مورد عمق تنظیم مجدد دستگاه ارائه می دهند.
-
بوت لودرها باید یک مجموعه هسته یا یک reason
تنظیم دقیق ارائه کنند و به شدت تشویق می شوند که اگر بتوان subreason
ارائه کرد. به عنوان مثال، فشار طولانی کلید روشن/خاموش که ممکن است دارای پشتیبان ramoops
باشد یا نباشد، دلیل راهاندازی "reboot,longkey"
را دارد.
هیچ reason
ابتدایی نمی تواند بخشی از هر subreason
یا detail
باشد. با این حال، از آنجایی که دلایل مجموعه هسته را نمیتوان توسط فضای کاربر تولید کرد، "watchdog"
ممکن است پس از یک دلیل تنظیم دقیق، همراه با جزئیات منبع (به عنوان مثال، "reboot,watchdog,service_manager_unresponsive"
یا "reboot,software,watchdog"
).
دلایل بوت نباید به دانش داخلی متخصص برای رمزگشایی نیاز داشته باشد و/یا باید با یک گزارش بصری قابل خواندن توسط انسان باشد. مثالها: "shutdown,vbxd"
(بد)، "shutdown,uv"
(بهتر)، "shutdown,undervoltage"
(ترجیحا).
ترکیب های دلیل-فرع
Android مجموعهای از reason
را در نظر میگیرد - ترکیبهای subreason
که در استفاده معمولی نباید بیش از حد بارگذاری شوند، اما اگر ترکیب دقیقاً شرایط مرتبط را منعکس کند، میتوانند به صورت موردی استفاده شوند. نمونه هایی از ترکیب های رزرو شده عبارتند از:
-
"reboot,userrequested"
-
"shutdown,userrequested"
-
"shutdown,thermal"
(ازthermald
) -
"shutdown,battery"
-
"shutdown,battery,thermal"
(ازBatteryStatsService
) -
"reboot,adb"
-
"reboot,shell"
-
"reboot,bootloader"
-
"reboot,recovery"
برای جزئیات بیشتر، به kBootReasonMap
در system/core/bootstat/bootstat.cpp
و تاریخچه تغییرات git مرتبط در مخزن منبع Android مراجعه کنید.
گزارش دلایل بوت
همه دلایل بوت، چه از بوت لودر یا ثبت شده در دلیل بوت متعارف، باید در قسمت kBootReasonMap
system/core/bootstat/bootstat.cpp
ثبت شوند. لیست kBootReasonMap
ترکیبی از دلایل سازگار و ناسازگار قدیمی است. توسعه دهندگان بوت لودر باید فقط دلایل سازگار جدید را در اینجا ثبت کنند (و نباید دلایل ناسازگار را ثبت کنند مگر اینکه محصول قبلا ارسال شده باشد و قابل تغییر نباشد).
ما قویاً توصیه میکنیم که از ورودیهای موجود و سازگار در system/core/bootstat/bootstat.cpp
استفاده کنید و قبل از استفاده از رشتههای ناسازگار، محدودیتها را رعایت کنید. به عنوان یک دستورالعمل، این است:
- برای گزارش
"kernel_panic"
از بوت لودر، خوب است ، زیراbootstat
ممکن است بتواندramoops
برایkernel_panic signatures
بازرسی کند تا دلایل فرعی را در canonicalsystem_boot_reason_prop
اصلاح کند. - گزارش یک رشته ناسازگار در
kBootReasonMap
(مانند"panic")
از بوت لودر، درست نیست ، زیرا در نهایت توانایی اصلاحreason
از بین می برد.
به عنوان مثال، اگر kBootReasonMap
حاوی "wdog_bark"
باشد، یک توسعه دهنده بوت لودر باید:
- به
"watchdog,bark"
تغییر دهید و به لیست درkBootReasonMap
اضافه کنید. - معنی
"bark"
را برای کسانی که با این فناوری آشنایی ندارند در نظر بگیرید و تعیین کنید که آیاsubreason
معنادارتری در دسترس است یا خیر.
بررسی انطباق دلیل بوت
در حال حاضر، اندروید تست CTS فعالی را ارائه نمیکند که بتواند تمام دلایل احتمالی راهاندازی را که بوتلودر میتواند ارائه کند، بهدقت راهاندازی یا بازرسی کند. شرکا همچنان می توانند برای تعیین سازگاری یک تست غیرفعال را اجرا کنند.
در نتیجه، انطباق بوت لودر، توسعه دهندگان بوت لودر را ملزم می کند که به طور داوطلبانه به روح قوانین و دستورالعمل های شرح داده شده در بالا پایبند باشند. ما از چنین توسعهدهندگانی میخواهیم که به AOSP (به ویژه در system/core/bootstat/bootstat.cpp
) کمک کنند و از این فرصت بهعنوان انجمنی برای بحث در مورد مسائل دلیل بوت استفاده کنند.