वेंडर और ओडीएम के DLKM सेक्शन

Android 11 में, जेनरिक कर्नेल इमेज और वेंडर बूट पार्टीशन का कॉन्सेप्ट जोड़ा गया है. वेंडर बूट पार्टीशन में, GKI के साथ काम करने वाले कर्नेल मॉड्यूल सेव किए जाते हैं. साथ ही, इसे पहले चरण के init से लोड किया जाता है. Android 11 के रिलीज़ होने से पहले के कर्नेल मॉड्यूल, वेंडर और ओडीएम पार्टिशन में भी सेव किए जाते हैं. साथ ही, वे वेंडर प्रोसेस से लोड किए जाते हैं.

Android 11 या उसके बाद के वर्शन के लिए, कर्नेल और सभी कर्नेल मॉड्यूल को बाकी सभी पार्टीशन से अलग से अपडेट किया जा सकता है. वेंडर सेगमेंट में सेव किए गए कर्नेल मॉड्यूल के अपडेट चालू करने के लिए, वेंडर सेगमेंट को अपडेट किए बिना, वेंडर सेगमेंट के सभी मॉड्यूल को वेंडर DLKM (डाइनैमिक तौर पर लोड किया जा सकने वाला कर्नेल मॉड्यूल) नाम के नए सेगमेंट में ले जाएं. इसके बाद, इस सेगमेंट को अलग से अपडेट किया जा सकता है. इसी तरह, ODM सेगमेंट में सेव किए गए सभी कर्नेल मॉड्यूल को ODM DLKM नाम के नए सेगमेंट में ले जाया जा सकता है. इस पार्टीशन को अलग से भी अपडेट किया जा सकता है.

पार्टीशन की जगह

vendor_dlkm और odm_dlkm सेक्शन, सुपर सेक्शन में एक और डाइनैमिक सेक्शन के तौर पर मौजूद हैं.

/vendor/lib/modules में मौजूद vendor_dlkm कॉन्टेंट

  • वेंडर के कर्नेल मॉड्यूल
  • modprobe कॉन्फ़िगरेशन फ़ाइलें
  • modules.load फ़ाइल

/odm/lib/modules में odm_dlkm कॉन्टेंट

  • ओडीएम कर्नेल मॉड्यूल
  • modprobe कॉन्फ़िगरेशन फ़ाइलें
  • modules.load फ़ाइल

कर्नेल मॉड्यूल कॉन्फ़िगरेशन फ़ाइलों के बारे में ज़्यादा जानकारी के लिए, कर्नेल मॉड्यूल के लिए सहायता देखें.

सहायता पाना

vendor_dlkm और odm_dlkm बनाने की प्रोसेस, अन्य डाइनैमिक पार्टिशन बनाने की प्रोसेस से मिलती-जुलती है.

vendor_dlkm बिल्ड का उदाहरण

vendor_dlkm को यहां दिए गए उदाहरणों के मुताबिक बनाएं.

BoardConfig.mk

BOARD_USES_VENDOR_DLKMIMAGE := true
BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE := ext4
TARGET_COPY_OUT_VENDOR_DLKM := vendor_dlkm
BOARD_<GROUP_NAME>_PARTITION_LIST += vendor_dlkm

<GROUP_NAME> की जगह, अपडेट ग्रुप का सही नाम डालें. अपडेट ग्रुप वह ग्रुप होना चाहिए जिसमें वेंडर का पार्टीशन है.

A/B और वर्चुअल A/B डिवाइसों के लिए, device.mk

AB_OTA_PARTITIONS += vendor_dlkm

fstab

fstab में vendor_dlkm के लिए, यह एंट्री जोड़ें. डिवाइस के हिसाब से फ़्लैग बदलें. उदाहरण के लिए, CL CF में vendor_dlkm जोड़ें का इस्तेमाल करें.

vendor_dlkm /vendor_dlkm ext4 noatime,ro,errors=panic wait,logical,first_stage_mount,slotselect,avb

odm_dlkm बिल्ड का उदाहरण

odm_dlkm को यहां दिए गए उदाहरणों के मुताबिक बनाएं.

BoardConfig.mk

BOARD_USES_ODM_DLKIMAGE := true
BOARD_ODM_DLKIMAGE_FILE_SYSTEM_TYPE := ext4
TARGET_COPY_OUT_ODM_DLKM := odm_dlkm
BOARD_<group_name>_PARTITION_LIST += odm_dlkm

A/B और वर्चुअल A/B डिवाइसों के लिए, device.mk

AB_OTA_PARTITIONS += odm_dlkm

fstab

fstab में odm_dlkm के लिए, यह एंट्री जोड़ें. डिवाइस के हिसाब से फ़्लैग बदलें. उदाहरण के लिए, CL CF में odm_dlkm जोड़ें का इस्तेमाल करें.

odm_dlkm /odm_dlkm ext4 noatime,ro,errors=panic wait,logical,first_stage_mount,slotselect,avb

किसी पार्टीशन में कर्नेल मॉड्यूल कॉपी करना

vendor_dlkm पार्टीशन में कॉपी करने के लिए, उन कर्नेल मॉड्यूल को चुनें और BOARD_VENDOR_KERNEL_MODULES में उनकी सूची बनाएं.

अगर आपको modules.load के कॉन्टेंट को बदलना है, तो BOARD_VENDOR_KERNEL_MODULES_LOAD में इसकी जानकारी दी जा सकती है.

बिल्ड के समय, BOARD_VENDOR_KERNEL_MODULES में दिए गए मॉड्यूल, $ANDROID_PRODUCT_OUT/vendor_dlkm/lib/modules में इंस्टॉल किए जाते हैं. /vendor/lib/modules पर एक सिंबल लिंक बनाया गया है, जो /vendor_dlkm/lib/modules पर ले जाता है.

इसी तरह, odm_dlkm partition में कॉपी करने के लिए, उन कर्नेल मॉड्यूल को चुनें और उन्हें BOARD_ODM_KERNEL_MODULES में लिस्ट करें. प्लैटफ़ॉर्म बिल्ड, मॉड्यूल पर depmod चलाता है और depmod आउटपुट फ़ाइलों को इमेज में कॉपी करता है. बिल्ड करने पर, modules.load फ़ाइल बनती है और उसे इमेज में सेव किया जाता है. इस फ़ाइल में, BOARD_ODM_KERNEL_MODULES में दिए गए सभी मॉड्यूल शामिल होते हैं.

अगर आपको modules.load के कॉन्टेंट को बदलना है, तो BOARD_ODM_KERNEL_MODULES_LOAD में इसकी जानकारी दी जा सकती है.

बिल्ड के समय, BOARD_ODM_KERNEL_MODULES में दिए गए मॉड्यूल, $ANDROID_PRODUCT_OUT/odm_dlkm/lib/modules में इंस्टॉल हो जाते हैं. /odm/lib/modules पर एक सिम्बॉलिक लिंक बनाया गया है, जो /odm_dlkm/lib/modules पर ले जाता है.

वेंडर और ओडीएम कर्नेल मॉड्यूल के लिए, /vendor/lib/modules और /odm/lib/modules का हमेशा इस्तेमाल करें.

/vendor_dlkm/lib/modules का कभी इस्तेमाल न करें. जिन डिवाइसों में vendor_dlkm पार्टिशन नहीं है उनमें BOARD_VENDOR_KERNEL_MODULES को सीधे /vendor/lib/modules पर इंस्टॉल किया जाता है. यह समस्या है, क्योंकि /vendor_dlkm/lib/modules मौजूद नहीं है.

/odm_dlkm/lib/modules का कभी इस्तेमाल न करें. जिन डिवाइसों में odm_dlkm पार्टीशन नहीं है उन पर BOARD_ODM_KERNEL_MODULES को सीधे /odm/lib/modules में इंस्टॉल किया जाता है. यह समस्या पैदा होती है, क्योंकि /odm_dlkm/lib/modules मौजूद नहीं है.

पार्टीशन को माउंट करना और मॉड्यूल लोड करना

first_stage_init के दौरान, vendor_dlkm और odm_dlkm पार्टिशन को क्रमशः /vendor_dlkm और /odm_dlkm डायरेक्ट्री में माउंट किया जाता है. ऐसा होने पर, /vendor/lib/modules और /odm/lib/modules पर सिमलینک उपलब्ध हो जाते हैं.

इसके बाद, कोई वेंडर प्रोसेस (जैसे कि .rc स्क्रिप्ट), modules.load में बताए गए क्रम के आधार पर, कर्नेल मॉड्यूल लोड कर सकती है. ज़रूरत पड़ने पर, वेंडर प्रोसेस बाद में भी मॉड्यूल लोड कर सकती है.

वेंडर-बूट पार्टीशन (जिसमें वेंडर का RAMDisk होता है) बनाने के बारे में दस्तावेज़ पाने के लिए, कर्नल मॉड्यूल के लिए सहायता देखें.