Android 11 में सॉफ़्ट रीस्टार्ट की सुविधा काम करती है. यह सुविधा, उपयोगकर्ता स्पेस में प्रोसेस को रनटाइम के दौरान रीस्टार्ट करती है. इसका इस्तेमाल उन अपडेट को लागू करने के लिए किया जाता है जिनके लिए रीबूट करना ज़रूरी होता है. उदाहरण के लिए, APEX पैकेज के अपडेट. फ़िलहाल, सॉफ़्ट रीस्टार्ट की सुविधा सिर्फ़ उन प्रोसेस के लिए उपलब्ध है जो userdata के माउंट होने के बाद शुरू हुई हैं.
सॉफ़्ट रीस्टार्ट का अनुरोध इन तरीकों से किया जाता है:
PowerManagerपर कॉल करके,PowerManager.reboot(PowerManager.REBOOT_USERSPACE)शेल से,
adb shell svc power reboot userspaceयाadb reboot userspaceका इस्तेमाल करके
सॉफ़्ट रीस्टार्ट के बाद, क्रेडेंशियल एन्क्रिप्ट (सुरक्षित) किया गया स्टोरेज अनलॉक रहता है.
अगर कोई डिवाइस सॉफ़्ट रीस्टार्ट की सुविधा के साथ काम करता है, तो PowerManager.isRebootingUserspace() एपीआई तरीके से true मिलता है. साथ ही, सिस्टम प्रॉपर्टी init.userspace_reboot.is_supported की वैल्यू 1 के बराबर होती है.
अगर डिवाइस पर सॉफ़्ट रीस्टार्ट की सुविधा काम नहीं करती है, तो PowerManager.reboot(PowerManager.REBOOT_USERSPACE), adb reboot
userspace, और adb shell svc power reboot userspace पर कॉल नहीं किया जा सकता.
सॉफ़्ट रीस्टार्ट एक्ज़ीक्यूशन
PowerManager या शेल के ज़रिए सॉफ़्ट रीस्टार्ट का अनुरोध करने के बाद, init ये काम करता है:
sys.powerctl=reboot,userspaceमिलता है.यह सॉफ़्ट रीस्टार्ट को मॉनिटर करने के लिए, एक अलग
UserspaceRebootWatchdogThread()प्रोसेस को फ़ोर्क करता है.यह
userspace-reboot-requestedऐक्शन को ट्रिगर करता है. इससे सिस्टम की उन सभी प्रॉपर्टी को रीसेट किया जाता है जो सॉफ़्ट रीस्टार्ट पर असर डाल सकती हैं. जिन प्रॉपर्टी पर असर पड़ा है:sys.usb.configsys.usb.statesys.boot_completeddev.bootcompletesys.init.updatable_crashingsys.init.updatable_crashing_process_nameapexd.statussys.user.0.ce_availablesys.shutdown.requestedservice.bootanim.exit
बूट सीक्वेंस के दौरान, ऊपर दी गई प्रॉपर्टी को फिर से सेट किया जाना चाहिए. अगर ज़रूरी हो, तो अन्य प्रॉपर्टी रीसेट की जा सकती हैं. उदाहरण के लिए,
rootdir/init.rcमेंon userspace-reboot-requestedकार्रवाई देखें.DoUserspaceRebootफ़ंक्शन को चलाता है. यह फ़ंक्शन ये कार्रवाइयां करता है:- यह कुकी,
userdataके माउंट होने के बाद शुरू की गई प्रोसेस कोSIGTERMभेजती है और उनके बंद होने का इंतज़ार करती है. - समयसीमा खत्म होने के बाद, यह कुकी
SIGKILLभेजती है, ताकि चल रही सभी प्रोसेस बंद की जा सकें. /system/bin/vdc volume resetको कॉल करता है.- यह zRAM बैकिंग डिवाइस को अनमाउंट करता है.
- इससे चालू APEX पैकेज अनमाउंट किए जाते हैं.
- यह बूटस्ट्रैप माउंट नेमस्पेस पर वापस स्विच करता है.
userspace-reboot-resumeकार्रवाई को ट्रिगर करता है.
- यह कुकी,
अगर सॉफ़्ट रीस्टार्ट से पहले फ़ाइल सिस्टम चेकपॉइंटिंग का अनुरोध किया गया था, तो userdata को userspace-reboot-fs-remount कार्रवाई के दौरान चेकपॉइंटिंग मोड में फिर से माउंट किया जाता है. ज़्यादा जानकारी के लिए, नीचे दिया गया सेक्शन देखें. sys.boot_completed property को 1 पर सेट करने के बाद, सॉफ़्ट रीस्टार्ट माना जाता है. सॉफ़्ट रीस्टार्ट के बाद, डिसप्ले बंद रहता है. इसे चालू करने के लिए, उपयोगकर्ता को साफ़ तौर पर इंटरैक्ट करना होता है.
फ़ाइल सिस्टम की जांच करना
अगर सॉफ़्ट रीस्टार्ट से पहले फ़ाइल सिस्टम के चेकपॉइंट का अनुरोध किया गया था, तो सॉफ़्ट रीस्टार्ट के दौरान userdata को चेकपॉइंटिंग मोड में फिर से माउंट किया जाता है.
रीमाउंटिंग लॉजिक को fs_mgr_remount_userdata_into_checkpointing फ़ंक्शन में लागू किया जाता है. साथ ही, यह चेकपॉइंटिंग के तरीकों के हिसाब से अलग-अलग होता है. खास तौर पर, जब
userdata इन सुविधाओं के साथ काम करता है:
फ़ाइल सिस्टम लेवल पर चेकपॉइंटिंग (उदाहरण के लिए,
f2fs),userdataकोcheckpoint=disableविकल्प के साथ फिर से माउंट किया जाता है.ब्लॉक लेवल चेकपॉइंटिंग (उदाहरण के लिए,
ext4) के बाद,/dataको अनमाउंट कर दिया जाता है. साथ ही, जिन पैरंट डिवाइस मैपर डिवाइसों पर इसे माउंट किया गया था उन्हें मिटा दिया जाता है. इसके बाद,userdataको उसी कोड पाथ का इस्तेमाल करके माउंट किया जाता है जिसका इस्तेमाल सामान्य चेकपॉइंटिंग बूट में किया जाता है.
अगर क्रेडेंशियल-एन्क्रिप्ट (सीई) और डिवाइस-एन्क्रिप्ट (डीई) कुंजियों को मैनेज करने के लिए, फ़ाइल सिस्टम लेवल की कीरिंग का इस्तेमाल किया जाता है, तो userdata को अनमाउंट करने के बाद कुंजियां मिट जाती हैं. पासकोड को वापस लाने की अनुमति देने के लिए, फ़ाइल सिस्टम कीरिंग में पासकोड इंस्टॉल करते समय, vold सेशन-लेवल कीरिंग में भी fscrypt-provisioning टाइप का वही पासकोड इंस्टॉल करता है. init_user0 को कॉल करने पर, vold फ़ाइल सिस्टम कीरिंग में कुंजियां फिर से इंस्टॉल करता है.
हार्ड रीबूट पर वापस जाएं
यह पक्का करने के लिए कि सॉफ़्ट रीस्टार्ट करने से डिवाइस इस्तेमाल न किया जा सके, Android 11 में हार्ड रीबूट का फ़ॉलबैक शामिल है. यह तब ट्रिगर होता है, जब इनमें से कोई एक शर्त पूरी होती है:
- जब कोई डिवाइस, तय समयसीमा के अंदर सॉफ़्ट रीस्टार्ट (यानी कि
sys.init.userspace_reboot.in_progress=1) शुरू नहीं कर पाता. - कोई प्रोसेस, दिए गए टाइम आउट में बंद नहीं होती है.
/system/bin/vdc volume resetकार्रवाई पूरी नहीं होती.- zRAM डिवाइस को अनमाउंट नहीं किया जा सका.
- चालू एपीईएक्स पैकेज को गलत तरीके से अनमाउंट किया जाता है.
- चेकपॉइंटिंग मोड में
userdataको फिर से माउंट करने की कोशिश करने पर गड़बड़ी होती है. - जब कोई डिवाइस दिए गए टाइम आउट में बूट नहीं हो पाता (यानी कि
sys.boot_completed=1).
हर डिवाइस के लिए कॉन्फ़िगरेशन
सॉफ़्ट रीस्टार्ट के कुछ पहलुओं को इन प्रॉपर्टी की वैल्यू बदलकर ट्यून किया जा सकता है:
init.userspace_reboot.is_supportedयह कंट्रोल करता है कि कोई डिवाइस कब सॉफ़्ट रीस्टार्ट कर सकता है. अगर इस प्रॉपर्टी की वैल्यूfalse,0है या इसे सेट नहीं किया गया है, तो रीस्टार्ट करने के अनुरोध अस्वीकार कर दिए जाते हैं.init.userspace_reboot.sigkill.timeoutmillis, उन प्रोसेस के लिए टाइम आउट को कंट्रोल करता है जिन्हें बंद करने के लिएSIGKILLसिग्नल मिला है. टाइम आउट की वैल्यू मिलीसेकंड में होती है. अगर दी गई समयावधि में कोई प्रोसेस बंद नहीं होती है, तो हार्ड रीबूट की सुविधा चालू हो जाती है.init.userspace_reboot.sigterm.timeoutmillis, उन प्रोसेस के लिए टाइम आउट को कंट्रोल करता है जिन्हें बंद करने के लिएSIGTERMसिग्नल मिला है. टाइम आउट की अवधि मिलीसेकंड में होती है. जिन प्रोसेस को तय समय में खत्म नहीं किया जा सका उन्हेंSIGKILLसिग्नल मिलता है.init.userspace_reboot.started.timeoutmillis, सॉफ़्ट रीस्टार्ट शुरू होने के लिए मिलीसेकंड में टाइम आउट को कंट्रोल करता है. इसका मतलब है किsys.init.userspace_reboot.in_progress=1. अगर कोई डिवाइस दिए गए टाइम आउट में सॉफ़्ट रीस्टार्ट शुरू नहीं कर पाता है, तो हार्ड रीबूट शुरू हो जाता है.init.userspace_reboot.userdata_remount.timeoutmillis,userdataको अनमाउंट करने के लिए, टाइम आउट को मिलीसेकंड में कंट्रोल करता है. अगर कोई डिवाइस तय समय में अनमाउंट नहीं होता है, तो हार्ड रीबूट ट्रिगर हो जाता है.userdatainit.userspace_reboot.watchdog.timeoutmillis, डिवाइस के बूट होने के लिए टाइम आउट को कंट्रोल करता है. इसका मतलब है किsys.boot_completed=1. अगर कोई डिवाइस दिए गए टाइम आउट में बूट नहीं होता है, तो हार्ड रीबूट का फ़ॉलबैक ट्रिगर हो जाता है.
सॉफ़्ट रीस्टार्ट के दौरान ऐनिमेशन को पसंद के मुताबिक बनाएं
सॉफ़्ट रीस्टार्ट के रेफ़रंस इंप्लीमेंटेशन में, सॉफ़्ट रीस्टार्ट के दौरान दिखने वाले ऐनिमेशन को पसंद के मुताबिक बनाने की सुविधा शामिल होती है.
userspace-reboot-fs-remount कार्रवाई के आखिर में, init bootanim सेवा शुरू करता है. यह सेवा, यहां दी गई क्रम के हिसाब से ऐनिमेशन फ़ाइलों को ढूंढती है. साथ ही, जो फ़ाइल सबसे पहले मिलती है उसे चलाती है:
/product/media/userspace-reboot.zip/oem/media/userspace-reboot.zip/system/media/userspace-reboot.zip
अगर किसी खास एनिमेशन फ़ाइल के लिए सॉफ्ट रीस्टार्ट करने का विकल्प नहीं चुना जाता है, तो bootanim में डिफ़ॉल्ट android एनिमेशन दिखता है.
जांच करना
Android 11 में, सॉफ़्ट रीस्टार्ट को लागू करने का रेफ़रंस शामिल है. इसके अलावा, UserspaceRebootHostTest में सीटीएस टेस्ट का इस्तेमाल करके, सॉफ़्ट रीस्टार्ट की पुष्टि की जा सकती है.