इस सेक्शन में, फ़्रेमवर्क और डिवाइस के साथ काम करने वाले मैट्रिक के साथ-साथ, कंपैटबिलिटी मैट्रिक स्कीमा के बारे में बताया गया है. मैच करने के नियमों के लिए, मैच करने के नियम देखें.
फ़्रेमवर्क कंपैटबिलिटी मैट्रिक्स (एफ़सीएम)
फ़्रेमवर्क कंपैटबिलिटी मैट्रिक्स (FCM), उस डिवाइस पर फ़्रेमवर्क की ज़रूरी शर्तों के बारे में बताता है जिस पर यह फ़्रेमवर्क काम करता है. फ़्रेमवर्क कंपैटबिलिटी मैट्रिक में, सिस्टम कंपैटबिलिटी मैट्रिक, प्रॉडक्ट कंपैटबिलिटी मैट्रिक, और system_ext कंपैटबिलिटी मैट्रिक शामिल होती है. डिवाइस मेनिफ़ेस्ट में, FCM की ज़रूरी शर्तें पूरी होनी चाहिए. ये शर्तें, बिल्ड के समय, रनटाइम के दौरान, और VTS में लागू होती हैं.
system_ext FCM और प्रॉडक्ट FCM, डिवाइस के हिसाब से FCM (सिस्टम सेगमेंट में इंस्टॉल किया गया) के साथ काम करते हैं.
- डिवाइस के FCM में, सिस्टम पार्टीशन में मौजूद मॉड्यूल की ज़रूरी शर्तें दिखनी चाहिए.
- system_ext FCM में, system_ext पार्टीशन में मौजूद मॉड्यूल की ज़रूरी शर्तें दिखनी चाहिए.
- प्रॉडक्ट एफ़सीएम में, प्रॉडक्ट के बंटवारे में मौजूद मॉड्यूल के हिसाब से ज़रूरी शर्तें दिखनी चाहिए.
सभी एफ़सीएम, सिस्टम, प्रॉडक्ट, और system_ext सेक्शन में फ़्रेमवर्क में OEM के किए गए बदलावों के हिसाब से होने चाहिए. उदाहरण के लिए, अगर प्रॉडक्ट पार्टीशन में इंस्टॉल किया गया कोई ऐप्लिकेशन, एचएएल इंटरफ़ेस के वेंडर एक्सटेंशन का इस्तेमाल करता है, तो एचएएल इंटरफ़ेस की ज़रूरी शर्तों को प्रॉडक्ट एफ़सीएम में बताया जाना चाहिए.
सिस्टम की कंपैटिबिलिटी मैट्रिक्स फ़ाइल का उदाहरण:
<?xml version="1.0" encoding="UTF-8"?> <!-- Comments, Legal notices, etc. here --> <compatibility-matrix version="1.0" type="framework" level="3"> <hal> <name>android.hardware.camera</name> <version>1.0</version> <version>3.1-4</version> <interface> <name>ICameraProvider</name> <instance>default</instance> <regex-instance>[a-z_]+/[0-9]+</regex-instance> </interface> </hal> <hal> <name>android.hardware.nfc</name> <version>1.0</version> <interface> <name>INfc</name> <instance>default</instance> </interface> </hal> <hal optional="true"> <name>android.hardware.graphics.composer</name> <version>2.1</version> <interface> <name>IComposer</name> <instance>default</instance> </interface> </hal> <hal format="aidl" optional="true"> <name>android.hardware.light</name> <version>1-2</version> <interface> <name>ILights</name> <instance>default</instance> </interface> </hal> <hal format="native"> <name>GL</name> <version>1.1</version> <version>3.0</version> </hal> <hal format="native"> <name>EGL</name> <version>1.1</version> </hal> <kernel version="3.18.51"> <!-- common configs --> </kernel> <kernel version="3.18.51"> <!-- arm specific configs --> <condition> <config> <key>CONFIG_ARM</key> <value type="tristate">y</value> </config> <condition> <config> <key>CONFIG_A</key> <value type="string"></value> </config> <config> <key>CONFIG_B</key> <value type="tristate">y</value> </config> </kernel> <kernel version="4.1.22"> <!-- common configs --> <config> <key>CONFIG_A</key> <value type="string">foo</value> </config> <config> <key>CONFIG_B2</key> <value type="int">1024</value> </config> </kernel> <sepolicy> <kernel-sepolicy-version>30</kernel-sepolicy-version> <sepolicy-version>25.0</sepolicy-version> <sepolicy-version>26.0-3</sepolicy-version> </sepolicy> <avb> <vbmeta-version>2.1</vbmeta-version> </avb> <xmlfile format="dtd"> <name>media_profile</name> <version>1.0</version> <path>/system/etc/media_profile_V1_0.dtd</path> </xmlfile> </compatibility-matrix>
ज़्यादा जानकारी के लिए, FCM के लाइफ़साइकल के बारे में लेख पढ़ें.
प्रॉडक्ट की कंपैटबिलिटी मैट्रिक
प्रॉडक्ट एफ़सीएम, प्रॉडक्ट के सेगमेंट में मौजूद फ़्रेमवर्क कंपैटबिलिटी मैट्रिक्स फ़ाइल है. रनटाइम के दौरान, VINTF ऑब्जेक्ट, प्रॉडक्ट FCM को सिस्टम और system_ext के सेगमेंट में मौजूद FCM से जोड़ता है.
प्रॉडक्ट की FCM फ़ाइल का उदाहरण:
<?xml version="1.0" encoding="UTF-8"?> <!-- Comments, Legal notices, etc. here --> <compatibility-matrix version="1.0" type="framework"> <hal> <name>vendor.foo.camera</name> <version>1.0</version> <interface> <name>IBetterCamera</name> <instance>default</instance> </interface> </hal> </compatibility-matrix>
System_ext की कंपैटिबिलिटी मैट्रिक्स
system_ext FCM, system_ext partition में मौजूद फ़्रेमवर्क कंपैटबिलिटी मैट्रिक्स फ़ाइल है. VINTF ऑब्जेक्ट, रनटाइम के दौरान सिस्टम और प्रॉडक्ट के सेगमेंट में, system_ext FCM को FCMs के साथ जोड़ता है. system_ext FCM फ़ाइल का उदाहरण देखने के लिए, प्रॉडक्ट के साथ काम करने की सुविधा का मैट्रिक्स देखें.
डिवाइस के साथ काम करने की जानकारी देने वाला मैट्रिक्स (DCM)
डिवाइस के साथ काम करने की जानकारी देने वाले मैट्रिक में, उन ज़रूरी शर्तों के बारे में बताया जाता है जो डिवाइस को फ़्रेमवर्क से पूरी करनी होती हैं. ये शर्तें, लॉन्च और ओटीए के समय लागू होती हैं.
DCM फ़ाइल का उदाहरण:
<?xml version="1.0" encoding="UTF-8"?> <!-- Comments, Legal notices, etc. here --> <compatibility-matrix version="1.0" type="device"> <hal> <name>android.hidl.manager</name> <version>1.0</version> <interface> <name>IServiceManager</name> <instance>default</instance> </interface> </hal> <hal> <name>android.hidl.memory</name> <version>1.0</version> <interface> <name>IMemory</name> <instance>ashmem</instance> </interface> </hal> <hal> <name>android.hidl.allocator</name> <version>1.0</version> <interface> <name>IAllocator</name> <instance>ashmem</instance> </interface> </hal> <hal> <name>android.framework.sensor</name> <version>1.0</version> <interface> <name>ISensorManager</name> <instance>default</instance> </interface> </hal> <vendor-ndk> <version>27</version> </vendor-ndk> <system-sdk> <version>27</version> </system-sdk> </compatibility-matrix>
कंपैटिबिलिटी मैट्रिक्स स्कीमा
इस सेक्शन में, इन एक्सएमएल टैग के बारे में बताया गया है. Android सोर्स ट्री में मौजूद सोर्स फ़ाइल में, कुछ "ज़रूरी" टैग मौजूद न हो सकते. साथ ही, ये टैग बिल्ड के समय assemble_vintf के ज़रिए लिखे जा सकते हैं. डिवाइस पर, उन फ़ाइलों में "ज़रूरी" टैग मौजूद होने चाहिए जिनसे जुड़े टैग की जानकारी दी गई है.
?xml- ज़रूरी नहीं. यह सिर्फ़ एक्सएमएल पार्स करने वाले टूल को जानकारी देता है.
compatibility-matrix.version- ज़रूरी है. इस काम करने की सुविधा वाले मैट्रिक का मेटा-वर्शन. इस एलिमेंट से, काम करने की सुविधा वाले मैट्रिक्स में मौजूद एलिमेंट के बारे में पता चलता है. यह एक्सएमएल वर्शन से जुड़ा नहीं है.
compatibility-matrix.type- ज़रूरी है. इस कम्पैटिबिलिटी मैट्रिक का टाइप:
"device": डिवाइस के साथ काम करने की जानकारी देने वाली मैट्रिक्स."framework": फ़्रेमवर्क के साथ काम करने की मैट्रिक्स.
manifest.level- फ़्रेमवर्क की कंपैटबिलिटी मैट्रिक्स के लिए ज़रूरी है. Android 12 और इसके बाद के वर्शन में,
प्रॉडक्ट और system_ext पार्टीशन में फ़्रेमवर्क के साथ काम करने की मैट्रिक्स फ़ाइलों में अनुमति है.
इस फ़ाइल के फ़्रेमवर्क कंपैटिबिलिटी मैट्रिक वर्शन (एफ़सीएम वर्शन) के बारे में बताता है. डिवाइस के हिसाब से कंपैटबिलिटी फ़्रेमवर्क मैट्रिक्स (जैसे कि
DEVICE_FRAMEWORK_COMPATIBILITY_MATRIX_FILE) में इसकी जानकारी न दें. compatibility-matrix.hal- यह ज़रूरी नहीं है और इसे दोहराया जा सकता है. इस एट्रिब्यूट में, एक ऐसे एचएएल (एचआईडीएल या नेटिव) की सूची दी जाती है जिसे कंपैटिबिलिटी मैट्रिक्स (फ़्रेमवर्क या डिवाइस) के मालिक को मौजूद रखना ज़रूरी है. एचएएल एंट्री को
<name>एलिमेंट से अलग किया जाता है; एक ही नाम वाली कई एचएएल एंट्री हो सकती हैं (इसका मतलब "और" शर्त से है). compatibility-matrix.hal.format- ज़रूरी नहीं. वैल्यू इनमें से कोई एक हो सकती है:
"hidl": HIDL HALs. यह डिफ़ॉल्ट विकल्प है."aidl": AIDL HALs. यह सिर्फ़ काम करने की क्षमता वाली मैट्रिक के मेटा-वर्शन 2.0 पर मान्य है."native": नेटिव एचएएल.
compatibility-matrix.hal.optional(Android 15 या उससे पहले के वर्शन)- एट्रिब्यूट की वैल्यू देना ज़रूरी नहीं है. यह डिफ़ॉल्ट रूप से 'गलत' पर सेट होता है. इससे पता चलता है कि कम्पैटिबिलिटी मैट्रिक्स (फ़्रेमवर्क या डिवाइस) के मालिक के लिए, यह एचएएल वैकल्पिक है या नहीं. अगर किसी
<hal>एंट्री को ज़रूरी नहीं के तौर पर मार्क किया गया है, तो इसका मतलब है कि मालिक, अगर यह एचएएल मौजूद है, तो इसका इस्तेमाल कर सकता है. हालांकि, इसके मौजूद होने की ज़रूरत नहीं है. - चेतावनी: Android 15 के बाद, इस एट्रिब्यूट का इस्तेमाल नहीं किया जा सकता और इसका कोई असर नहीं पड़ता. अगर किसी एचएएल को इंस्टॉल करना ज़रूरी है, तो इस ज़रूरी शर्त को टेस्ट में लागू किया जाना चाहिए.
compatibility-matrix.hal.name- ज़रूरी है. इस एचएएल का पूरा पैकेज नाम. उदाहरण:
android.hardware.camera(HIDL या AIDL HAL)GLES(नेटिव एचएएल, सिर्फ़ नाम की ज़रूरत है)
compatibility-matrix.hal.version-
वर्शन की रेंज की सूची (HAL मैच देखें), जो बताती है कि काम करने की शर्तों के मैट्रिक्स (फ़्रेमवर्क या डिवाइस) के मालिक को किन वर्शन की उम्मीद है.
HIDL और नेटिव एचएएल के लिए ज़रूरी है. डुप्लीकेट के बिना दोहराया जा सकता है. फ़ॉर्मैट इनमें से कोई एक है:MAJOR.MINOR_MIN-MINOR_MAXMAJOR.MINOR(MAJOR.MINOR-MINORके बराबर)
एआईडीएल एचएएल के लिए, यह ज़रूरी है कि Android 11 और उससे पहले के वर्शन वाले डिवाइसों पर यह मौजूद न हो. यह विकल्प, नए वर्शन वाले डिवाइसों पर ज़रूरी नहीं है. अगर यह जानकारी दी गई है, तो फ़ॉर्मैट इनमें से कोई एक होगा:VERSION_MIN-VERSION_MAXVERSION(VERSION-VERSIONके बराबर)
1होगी. compatibility-matrix.hal.interface- ज़रूरी नहीं, दोहराया जा सकता है. इस एचएएल के ज़रूरी इंटरफ़ेस की सूची.
compatibility-matrix.hal.interface.name- ज़रूरी है. इंटरफ़ेस का नाम.
compatibility-matrix.hal.interface.instance- ज़रूरी नहीं, दोहराया जा सकता है. इस इंटरफ़ेस के ज़रूरी इंस्टेंस की सूची.
compatibility-matrix.hal.interface.regex-instance- ज़रूरी नहीं, दोहराया जा सकता है. इस इंटरफ़ेस पर, इंस्टेंस के नाम के लिए ज़रूरी पैटर्न की सूची. एक्सटेंडेड रेगुलर एक्सप्रेशन फ़ॉर्मैट का इस्तेमाल करें.
compatibility-matrix.kernel- ज़रूरी नहीं, दोहराया जा सकता है. उन कर्नेल कॉन्फ़िगरेशन की सूची दें जिनकी ज़रूरत फ़्रेमवर्क को हर कर्नेल वर्शन पर होती है.
एक ही<version>के साथ कई<kernel>मौजूद हो सकते हैं, ताकि "और" रिलेशनशिप का पता चल सके. हर<kernel>, ज़रूरी शर्तों का एक "फ़्रैगमेंट" होता है. यह सिर्फ़ तब चालू होता है, जब<conditions>पूरी हो गई हों. compatibility-matrix.kernel.version- ज़रूरी है. कर्नेल वर्शन. फ़ॉर्मैट
VERSION.MAJOR_REVISION.MINOR_REVISIONहै. वर्शन और मेजर रिविज़न पूरी तरह से मेल खाने चाहिए. माइनर रिविज़न से, फ़्रेमवर्क के लिए ज़रूरी केर्नेल के कम से कम LTS वर्शन के बारे में पता चलता है. compatibility-matrix.kernel.condition- ज़रूरी नहीं. हर वर्शन के पहले
<kernel>के लिए, यह मौजूद नहीं होना चाहिए. शर्तों की सूची तय करता है. शर्तें पूरी होने पर, इस<kernel>फ़्रैगमेंट में बताई गई ज़रूरी शर्तें चालू हो जाती हैं. compatibility-matrix.kernel.config- ज़रूरी नहीं, दोहराया जा सकता है. इस सूची में
CONFIGऐसे आइटम होते हैं जिन्हें इस कर्नेल वर्शन के लिए मैच करना ज़रूरी है. हरCONFIGआइटम, एक की-वैल्यू पेयर होता है. कॉन्फ़िगरेशन आइटम को की से अलग किया जाता है. compatibility-matrix.kernel.config.key- ज़रूरी है.
CONFIGआइटम का मुख्य नाम.CONFIG_से शुरू होता है. compatibility-matrix.kernel.config.value- ज़रूरी है.
CONFIGआइटम की वैल्यू. फ़ॉर्मैट, टाइप के हिसाब से होता है:string. कोटेशन हटा दिए जाते हैं.int. दशमलव और हेक्साडेसिमल (0xया0X)से शुरू होना चाहिए) वैल्यू स्वीकार की जाती हैं. इसे 64-बिट पूर्णांक के तौर पर इंटरप्रेट किया जाता है; ओवरफ़्लो होने पर, इसे छोटा कर दिया जाता है. (पार्सर -264 + 1 से लेकर 264 - 1 तक की वैल्यू स्वीकार करता है. 65वां बिट काट दिया जाता है. ज़्यादा जानकारी के लिए, strtoull के मैन पेज पर जाएं.)range. फ़ॉर्मैट[int]-[int]है, जैसे कि10-20. हेक्साडेसिमल वैल्यू स्वीकार की जाती हैं. साथ ही, ये वैल्यू0xया0Xसे शुरू होनी चाहिए. दोनों सीमाएं, बिना हस्ताक्षर वाला 64-बिट वाला पूर्णांक होनी चाहिए.tristate. मान्य वैल्यूy,m, औरnहैं.
compatibility-matrix.kernel.config.value.type- ज़रूरी है.
CONFIGआइटम की वैल्यू का टाइप, इनमें से कोई एक:stringintrangetristate
compatibility-matrix.sepolicy- ज़रूरी है. इसमें sepolicy से जुड़ी सभी एंट्री शामिल होती हैं. इसका इस्तेमाल सिर्फ़ फ़्रेमवर्क के साथ काम करने वाले मैट्रिक के लिए किया जाता है.
compatibility-matrix.sepolicy.sepolicy-version- ज़रूरी है, दोहराया जा सकता है. sepolicy वर्शन की ज़रूरी शर्तों के बारे में बताता है.
manifest.sepolicy.versionके लिए इस्तेमाल किया जाता है. किसी एलिमेंट के हर इंस्टेंस से, sepolicy के वर्शन की एक रेंज तय होती है. compatibility-matrix.sepolicy.kernel-sepolicy-version- ज़रूरी है. यह
policydbके उस वर्शन के बारे में बताता है जिस पर फ़्रेमवर्क काम करता है. compatibility-matrix.avb.vbmeta-version- ज़रूरी नहीं; इसका इस्तेमाल सिर्फ़ फ़्रेमवर्क के साथ काम करने वाले मैट्रिक्स के लिए किया जाता है.
system.imgपर हस्ताक्षर करने के लिए इस्तेमाल किए गए AVB वर्शन के बारे में बताता है. Android 10 में काम नहीं करता. compatibility-matrix.vendor-ndk- ज़रूरी नहीं है. इसका इस्तेमाल सिर्फ़ डिवाइस के साथ काम करने वाले मैट्रिक्स के लिए किया जाता है. VNDK वेंडर स्नैपशॉट की ज़रूरत के बारे में बताता है. अगर यह पैरामीटर मौजूद नहीं है, तो सिस्टम इमेज पर VNDK की कोई ज़रूरी शर्त नहीं बनाई जाती.
compatibility-matrix.vendor-ndk.version- ज़रूरी है. एक पॉज़िटिव इंटिजर, जो वेंडर इमेज के लिए ज़रूरी VNDK वर्शन के बारे में बताता है.
compatibility-matrix.vendor-ndk.library- ज़रूरी नहीं, दोहराया जा सकता है. वेंडर इमेज के लिए ज़रूरी VNDK लाइब्रेरी का सेट तय करता है.
manifest.vendor-ndk.libraryके जैसे सिमेंटिक. compatibility-matrix.system-sdk.version- ज़रूरी नहीं, दोहराया जा सकता है; इसका इस्तेमाल सिर्फ़ डिवाइस के साथ काम करने की जानकारी देने वाले मैट्रिक्स में किया जाता है. इससे, सिस्टम के SDK टूल के वर्शन के लिए, वेंडर ऐप्लिकेशन की ज़रूरी शर्तों के बारे में पता चलता है. अगर यह एट्रिब्यूट मौजूद नहीं है, तो सिस्टम इमेज के लिए सिस्टम SDK की ज़रूरत नहीं होती.