वेंडर नेटिव डेवलपमेंट किट (वीएनडीके), लाइब्रेरी का एक सेट है. इसका इस्तेमाल, वेंडर या प्रॉडक्ट पार्टिशन में मौजूद अन्य लाइब्रेरी या बाइनरी करती हैं. ऐसा dlopen के लिए रनटाइम पर किया जाता है.
बंद की गई सेवाएं/सुविधाएं
वेंडर एनडीके को Android 8.0 में पेश किया गया था, ताकि फ़्रेमवर्क और वेंडर कोड के बीच एपीआई उपलब्ध कराए जा सकें. VNDK का इस्तेमाल कई सालों से किया जा रहा है. हालांकि, इसमें कुछ कमियां हैं:- स्टोरेज
- एक वीएनडीके एपेक्स पैकेज में सभी वीएनडीके लाइब्रेरी शामिल होती हैं. भले ही, उनका इस्तेमाल डिवाइस से किया गया हो या नहीं.
- GSI में, वेंडर इमेज के कई वर्शन के साथ काम करने के लिए, VNDK APEX के कई वर्शन होते हैं.
- अपडेट किए जाने की क्षमता
- प्लैटफ़ॉर्म अपडेट से अलग, VNDK APEX को अपडेट करना मुश्किल है.
- वेंडर इमेज को अक्सर ओवर द एयर (OTA) अपडेट किया जाता है. इससे सिस्टम इमेज में VNDK को पैकेज करने के फ़ायदे कम हो जाते हैं.
वीएनडीके के बंद होने के बारे में जानकारी
सभी वीएनडीके लाइब्रेरी को वीएनडीके एपेक्स में पैकेज किया जाता है. साथ ही, इन्हें सिस्टम (-ext) इमेज में इंस्टॉल किया जाता है. वीएनडीके के बंद होने के बाद, वीएनडीके की पुरानी लाइब्रेरी को वेंडर (या प्रॉडक्ट) इमेज में इंस्टॉल किया जाता है. ऐसा ही वेंडर के लिए उपलब्ध अन्य लाइब्रेरी के साथ भी किया जाता है. VNDK के बंद होने के साथ-साथ, इन सुविधाओं को भी हटा दिया गया है:- Android 15 के लिए वीएनडीके एपेक्स
- अगर वेंडर या प्रॉडक्ट पार्टिशन को Android 15 के लिए बनाया गया है, तो टारगेट वीएनडीके के वर्शन की जानकारी देने वाली सिस्टम प्रॉपर्टी हटा दी जाती हैं:
ro.vndk.version
ro.product.vndk.version
- वीएनडीके ऑप्टिमाइज़ेशन उपलब्ध नहीं होंगे, क्योंकि कोई वीएनडीके नहीं है:
- Android Go डिवाइसों के लिए
TARGET_VNDK_USING_CORE_VARIANT
use_vndk_as_stable
for Vendor APEXes
- Android Go डिवाइसों के लिए
- वेंडर स्नैपशॉट, जो VNDK पर बहुत ज़्यादा निर्भर करता है
बंद होने से जुड़े अपवाद
VNDK के बंद होने से, इन सुविधाओं में कोई बदलाव नहीं होगा:- VNDK APEX, VNDK वर्शन 14 या इससे पहले के वर्शन के साथ काम करते हैं. ये मौजूदा वेंडर इमेज के साथ काम करने के लिए ज़रूरी हैं.
- एलएल-एनडीके, वीएनडीके का हिस्सा नहीं है.
वीएनडीके क्यों ज़रूरी है?
AOSP में, सिर्फ़ फ़्रेमवर्क अपडेट करने की सुविधा मिलती है. इसमें सिस्टम पार्टीशन को नए फ़्रेमवर्क वर्शन पर अपग्रेड किया जा सकता है. हालांकि, वेंडर पार्टीशन में कोई बदलाव नहीं होता. अलग-अलग समय पर बनाए जाने के बावजूद, हर पार्टीशन में मौजूद बाइनरी एक-दूसरे के साथ काम कर सकती हैं.
सिर्फ़ फ़्रेमवर्क से जुड़े अपडेट में ये समस्याएं शामिल हैं:
- फ़्रेमवर्क मॉड्यूल और वेंडर मॉड्यूल के बीच डिपेंडेंसी. Android 8.0 से पहले, वेंडर और सिस्टम पार्टीशन में मौजूद मॉड्यूल एक-दूसरे से लिंक हो सकते थे. हालांकि, वेंडर मॉड्यूल की डिपेंडेंसी की वजह से, फ़्रेमवर्क मॉड्यूल के डेवलपमेंट पर अनचाहे प्रतिबंध लग गए.
- AOSP लाइब्रेरी के एक्सटेंशन. Android के लिए, यह ज़रूरी है कि सभी Android डिवाइस, सिस्टम पार्टिशन को स्टैंडर्ड सामान्य सिस्टम इमेज (जीएसआई) से बदलने पर सीटीएस पास करें. हालांकि, वेंडर परफ़ॉर्मेंस को बेहतर बनाने या HIDL लागू करने के लिए अतिरिक्त सुविधाएं जोड़ने के लिए, AOSP लाइब्रेरी को बढ़ाते हैं. ऐसे में, स्टैंडर्ड जीएसआई के साथ सिस्टम पार्टीशन को फ़्लैश करने से, वेंडर के HIDL लागू करने की प्रोसेस में रुकावट आ सकती है. इस तरह की समस्याओं को रोकने के बारे में दिशा-निर्देशों के लिए, वीएनडीके एक्सटेंशन देखें.
इन चुनौतियों से निपटने के लिए, Android में कई सुविधाएं शामिल हैं. जैसे, VNDK (इस सेक्शन में इसके बारे में बताया गया है), HIDL, hwbinder, डिवाइस ट्री ओवरले, और sepolicy ओवरले.
वीएनडीके के लिए खास शर्तें
VNDK से जुड़े दस्तावेज़ों में, यहां दी गई शब्दावली का इस्तेमाल किया जाता है:- मॉड्यूल का मतलब, शेयर की गई लाइब्रेरी या एक्ज़ीक्यूटेबल से है. मॉड्यूल, बिल्ड-टाइम डिपेंडेंसी बनाते हैं.
- प्रोसेस, ऑपरेटिंग सिस्टम के ऐसे टास्क होते हैं जो एक्ज़ीक्यूटेबल से जनरेट होते हैं. प्रोसेस, रन-टाइम डिपेंडेंसी बनाती हैं.
- फ़्रेमवर्क के लिए ज़रूरी शर्तें पूरी करने वाले शब्द,
system
पार्टीशन से जुड़े होते हैं: - फ़्रेमवर्क एक्ज़ीक्यूटेबल का मतलब
/system/bin
या/system/xbin
में मौजूद एक्ज़ीक्यूटेबल से है. - फ़्रेमवर्क शेयर की गई लाइब्रेरी का मतलब,
/system/lib[64]
में मौजूद शेयर की गई लाइब्रेरी से है. - फ़्रेमवर्क मॉड्यूल का मतलब, फ़्रेमवर्क की शेयर की गई लाइब्रेरी और फ़्रेमवर्क के एक्ज़ीक्यूटेबल, दोनों से है.
- फ़्रेमवर्क प्रोसेस, फ़्रेमवर्क के एक्ज़ीक्यूटेबल से जनरेट होने वाली प्रोसेस होती हैं. जैसे,
/system/bin/app_process
. - वेंडर के लिए ज़रूरी शर्तें,
vendor
पार्टीशन से जुड़ी होती हैं: - वेंडर के एक्ज़ीक्यूटेबल का मतलब
/vendor/bin
में मौजूद एक्ज़ीक्यूटेबल से है - वेंडर की शेयर की गई लाइब्रेरी का मतलब,
/vendor/lib[64]
में मौजूद शेयर की गई लाइब्रेरी से है. - वेंडर मॉड्यूल का मतलब, वेंडर के एक्ज़ीक्यूटेबल और वेंडर की शेयर की गई लाइब्रेरी, दोनों से है.
- वेंडर प्रोसेस, वेंडर एक्ज़ीक्यूटेबल से जनरेट होने वाली प्रोसेस होती हैं. जैसे,
/vendor/bin/android.hardware.camera.provider@2.4-service
.
वीएनडीके के कॉन्सेप्ट
Android 8.0 और इसके बाद के वर्शन में, फ़्रेमवर्क प्रोसेस, वेंडर की शेयर की गई लाइब्रेरी लोड नहीं करती हैं. साथ ही, वेंडर की सभी प्रोसेस, वेंडर की शेयर की गई लाइब्रेरी और फ़्रेमवर्क की शेयर की गई लाइब्रेरी का कुछ हिस्सा ही लोड करती हैं. इसके अलावा, फ़्रेमवर्क प्रोसेस और वेंडर प्रोसेस के बीच होने वाले कम्यूनिकेशन को HIDL और हार्डवेयर बाइंडर कंट्रोल करते हैं.
इस तरह के वर्ल्ड में, यह संभावना शामिल है कि फ़्रेमवर्क की शेयर की गई लाइब्रेरी से स्टेबल और सार्वजनिक एपीआई, वेंडर मॉड्यूल डेवलपर के लिए काफ़ी न हों. हालांकि, एपीआई Android के वर्शन के हिसाब से बदल सकते हैं. इसलिए, यह ज़रूरी है कि फ़्रेमवर्क की शेयर की गई लाइब्रेरी का कुछ हिस्सा, वेंडर प्रोसेस के लिए ऐक्सेस किया जा सके. इसके अलावा, परफ़ॉर्मेंस से जुड़ी ज़रूरी शर्तों की वजह से कुछ समझौते करने पड़ सकते हैं. इसलिए, रिस्पॉन्स टाइम के हिसाब से ज़रूरी कुछ एचएएल को अलग तरीके से मैनेज किया जाना चाहिए.
यहां दिए गए सेक्शन में, इस बारे में ज़्यादा जानकारी दी गई है कि वीएनडीके, वेंडर और सेम-प्रोसेस एचएएल (एसपी-एचएएल) के लिए, फ़्रेमवर्क की शेयर की गई लाइब्रेरी को कैसे मैनेज करता है.
वेंडर के लिए फ़्रेमवर्क की शेयर की गई लाइब्रेरी
इस सेक्शन में, शेयर की गई उन लाइब्रेरी को कैटगरी में बांटने की शर्तों के बारे में बताया गया है जिन्हें वेंडर प्रोसेस ऐक्सेस कर सकती हैं. Android के अलग-अलग वर्शन पर वेंडर मॉड्यूल को सपोर्ट करने के दो तरीके हैं:
- फ़्रेमवर्क की शेयर की गई लाइब्रेरी के एबीआइ/एपीआई को स्थिर करें. नए फ़्रेमवर्क मॉड्यूल और पुराने वेंडर मॉड्यूल, दोनों एक ही शेयर की गई लाइब्रेरी का इस्तेमाल कर सकते हैं. इससे मेमोरी फ़ुटप्रिंट और स्टोरेज का साइज़ कम हो जाता है. शेयर की गई यूनीक लाइब्रेरी से, दो बार लोड होने की कई समस्याओं से भी बचा जा सकता है. हालांकि, स्टेबल एबीआइ/एपीआई को बनाए रखने के लिए डेवलपमेंट की लागत ज़्यादा होती है. साथ ही, शेयर की गई हर फ़्रेमवर्क लाइब्रेरी से एक्सपोर्ट किए गए सभी एबीआइ/एपीआई को स्टेबल करना मुश्किल होता है.
- शेयर की गई पुरानी फ़्रेमवर्क लाइब्रेरी कॉपी करें. इसमें साइड चैनलों पर पाबंदी लगाई गई है. साइड चैनल का मतलब है कि फ़्रेमवर्क मॉड्यूल और वेंडर मॉड्यूल के बीच कम्यूनिकेट करने के सभी तरीके. इनमें ये शामिल हैं: बाइंडर, सॉकेट, पाइप, शेयर की गई मेमोरी, शेयर की गई फ़ाइल, और सिस्टम प्रॉपर्टी. हालांकि, इनके अलावा और भी तरीके शामिल हो सकते हैं. जब तक कम्यूनिकेशन प्रोटोकॉल फ़्रीज़ और स्टेबल न हो जाए, तब तक कोई कम्यूनिकेशन नहीं होना चाहिए. उदाहरण के लिए, hwbinder के ज़रिए HIDL. शेयर की गई लाइब्रेरी को दो बार लोड करने से भी समस्याएं हो सकती हैं. उदाहरण के लिए, अगर नई लाइब्रेरी से बनाए गए किसी ऑब्जेक्ट को पुरानी लाइब्रेरी के फ़ंक्शन में पास किया जाता है, तो गड़बड़ी हो सकती है. ऐसा इसलिए, क्योंकि ये लाइब्रेरी ऑब्जेक्ट की अलग-अलग तरह से व्याख्या कर सकती हैं.
शेयर की गई लाइब्रेरी की विशेषताओं के आधार पर, अलग-अलग तरीकों का इस्तेमाल किया जाता है. इसलिए, फ़्रेमवर्क की शेयर की गई लाइब्रेरी को तीन उप-कैटगरी में बांटा गया है:
- एलएल-एनडीके लाइब्रेरी, फ़्रेमवर्क की शेयर की गई लाइब्रेरी होती हैं. ये स्टेबल होती हैं. इनके डेवलपर, एपीआई/एबीआई को स्थिर बनाए रखने के लिए प्रतिबद्ध हैं.
- LL-NDK में ये लाइब्रेरी शामिल हैं:
libEGL.so
,libGLESv1_CM.so
,libGLESv2.so
,libGLESv3.so
,libandroid_net.so
,libc.so
,libdl.so
,liblog.so
,libm.so
,libnativewindow.so
,libneuralnetworks.so
,libsync.so
,libvndksupport.so
, औरlibvulkan.so
,
- LL-NDK में ये लाइब्रेरी शामिल हैं:
- वीएनडीके के तौर पर इस्तेमाल की जा सकने वाली लाइब्रेरी (वीएनडीके), फ़्रेमवर्क के साथ शेयर की गई लाइब्रेरी होती हैं. इन्हें दो बार कॉपी किया जा सकता है. फ़्रेमवर्क मॉड्यूल और वेंडर मॉड्यूल, अपनी कॉपी से लिंक किए जा सकते हैं. शेयर की गई फ़्रेमवर्क लाइब्रेरी को वीएनडीके लाइब्रेरी के तौर पर सिर्फ़ तब इस्तेमाल किया जा सकता है, जब वह इन शर्तों को पूरा करती हो:
- यह फ़्रेमवर्क को आईपीसी नहीं भेजता/उससे आईपीसी नहीं पाता.
- यह एआरटी वर्चुअल मशीन से जुड़ा नहीं है.
- यह ऐसे फ़ाइल फ़ॉर्मैट वाली फ़ाइलों/पार्टिशन को नहीं पढ़ता/लिखता है जो स्टेबल नहीं हैं.
- इसके पास कोई खास सॉफ़्टवेयर लाइसेंस नहीं है. इसके लिए, कानूनी समीक्षाओं की ज़रूरत होती है.
- कोड के मालिक को, वेंडर के इस्तेमाल पर कोई आपत्ति नहीं है.
- सिर्फ़ फ़्रेमवर्क वाली लाइब्रेरी (एफ़डब्ल्यूके-ओनली), फ़्रेमवर्क शेयर की गई लाइब्रेरी होती हैं. ये ऊपर बताई गई कैटगरी में शामिल नहीं होती हैं. इन लाइब्रेरी का इस्तेमाल किया जाता है:
- इन्हें फ़्रेमवर्क के इंटरनल इंप्लिमेंटेशन की जानकारी माना जाता है.
- इसे वेंडर मॉड्यूल से ऐक्सेस नहीं किया जाना चाहिए.
- इनमें एबीआइ/एपीआई स्टेबल नहीं होते हैं. साथ ही, एपीआई/एबीआइ के साथ काम करने की कोई गारंटी नहीं होती है.
- कॉपी नहीं किए जाते.
सेम-प्रोसेस एचएएल (एसपी-एचएएल)
सेम-प्रोसेस एचएएल (एसपी-एचएएल), पहले से तय किए गए एचएएल का एक सेट होता है. इन्हें वेंडर शेयर की गई लाइब्रेरी के तौर पर लागू किया जाता है और फ़्रेमवर्क प्रोसेस में लोड किया जाता है. एसपी-एचएएल को लिंकर नेमस्पेस से अलग किया जाता है. यह शेयर की गई लाइब्रेरी को दिखने वाली लाइब्रेरी और सिंबल को कंट्रोल करता है. एसपी-एचएएल सिर्फ़ एलएल-एनडीके और वीएनडीके-एसपी पर निर्भर होने चाहिए.
VNDK-SP, वीएनडीके लाइब्रेरी का पहले से तय किया गया सबसेट है. VNDK-SP लाइब्रेरी की बारीकी से समीक्षा की जाती है, ताकि यह पक्का किया जा सके कि फ़्रेमवर्क प्रोसेस में VNDK-SP लाइब्रेरी को दो बार लोड करने से कोई समस्या न हो. एसपी-एचएएल और वीएनडीके-एसपी, दोनों को Google ने तय किया है.
एसपी-एचएएल के तौर पर इन लाइब्रेरी को मंज़ूरी मिली है:
libGLESv1_CM_${driver}.so
libGLESv2_${driver}.so
libGLESv3_${driver}.so
libEGL_${driver}.so
vulkan.${driver}.so
android.hardware.renderscript@1.0-impl.so
android.hardware.graphics.mapper@2.0-impl.so
VNDK-SP लाइब्रेरी, vndk: { support_system_process: true }
को अपनी Android.bp फ़ाइलों में तय करती हैं. अगर vndk: {private:true}
भी तय किया गया है, तो इन लाइब्रेरी को vndk: {private:true}
कहा जाता है. ये एसपी-एचएएल को नहीं दिखती हैं.VNDK-SP-Private
यहां सिर्फ़ फ़्रेमवर्क वाली लाइब्रेरी दी गई हैं, जिनमें आरएस से जुड़ी समस्याएं हैं (FWK-ONLY-RS):
libft2.so
(Renderscript)libmediandk.so
(Renderscript)
वीएनडीके वर्शनिंग
वीएनडीके की शेयर की गई लाइब्रेरी के वर्शन होते हैं:
ro.vndk.version
सिस्टम प्रॉपर्टी,/vendor/default.prop
में अपने-आप जुड़ जाती है.- वीएनडीके और वीएनडीके-एसपी शेयर की गई लाइब्रेरी, वीएनडीके ऐपेक्स
com.android.vndk.v${ro.vndk.version}
के तौर पर इंस्टॉल की जाती हैं और/apex/com.android.vndk.v${ro.vndk.version}
पर माउंट की जाती हैं.
ro.vndk.version
की वैल्यू, नीचे दिए गए एल्गोरिदम के हिसाब से चुनी जाती है:
- अगर
BOARD_VNDK_VERSION
, इसके बराबर नहीं हैcurrent
, तोBOARD_VNDK_VERSION
का इस्तेमाल करें. - अगर
BOARD_VNDK_VERSION
,current
के बराबर है, तो: - अगर
PLATFORM_VERSION_CODENAME
REL
है, तोPLATFORM_SDK_VERSION
का इस्तेमाल करें. उदाहरण के लिए,28
. - इसके अलावा,
PLATFORM_VERSION_CODENAME
का इस्तेमाल करें. उदाहरण के लिए,P
.
Vendor Test Suite (VTS)
Android Vendor Test Suite (VTS) के लिए, ro.vndk.version
प्रॉपर्टी में वैल्यू होना ज़रूरी है. नए डिवाइसों और अपग्रेड किए गए डिवाइसों, दोनों के लिए ro.vndk.version
तय करना ज़रूरी है. कुछ वीएनडीके टेस्ट केस (जैसे, VtsVndkFilesTest
और VtsVndkDependencyTest
), ro.vndk.version
प्रॉपर्टी पर निर्भर करते हैं. ऐसा इसलिए, ताकि वे वीएनडीके की ज़रूरी लाइब्रेरी के डेटा सेट लोड कर सकें.