रेफ़रंस के तौर पर लागू करना

हम एआईडीएल वीएचएएल के लिए, रेफ़रंस इंप्लीमेंटेशन उपलब्ध कराते हैं. मुख्य सेवा थ्रेड को VehicleService.cpp पर लागू किया जाता है. वीएचएएल इंटरफ़ेस को DefaultVehicleHal.cpp पर लागू किया गया है.

रेफ़रंस के तौर पर लागू किया गया यह तरीका, दो लेयर वाले आर्किटेक्चर पर आधारित है. ऊपरी लेयर पर, DefaultVehicleHal, वीएचएएल एआईडीएल इंटरफ़ेस लागू करता है. साथ ही, सभी हार्डवेयर डिवाइसों के लिए वीएचएएल लॉजिक उपलब्ध कराता है. नीचे वाली लेयर पर, FakeVehicleHardware, IVehicleHardware इंटरफ़ेस लागू करता है. यह क्लास, असली हार्डवेयर या वाहन बस के साथ इंटरैक्ट करने के VHAL लॉजिक का सिम्युलेशन करती है. साथ ही, यह डिवाइस के हिसाब से काम करती है. वेंडर चाहें, तो इसी आर्किटेक्चर को अपना सकते हैं. साथ ही, वे उसी DefaultVehicleHal क्लास का फिर से इस्तेमाल कर सकते हैं. इसके अलावा, वे DefaultVehicleHal को लागू करने का अपना तरीका भी उपलब्ध करा सकते हैं.IVehicleHardware

वीएचएएल को रेफ़रंस के तौर पर लागू करना
पहली इमेज. वीएचएएल को रेफ़रंस के तौर पर लागू करना

DefaultVehicleHal में यह लॉजिक शामिल होता है. इसे सामान्य माना जाता है और यह किसी भी VHAL इस्तेमाल पर लागू हो सकता है.

  • यह IVehicle इंटरफ़ेस लागू करता है.
  • यह सामान्य इनपुट की जांच करता है. इसमें डुप्लीकेट आईडी की जांच भी शामिल है.
  • यह हर बाइंडर क्लाइंट के लिए, हर ऑपरेशन के लिए क्लाइंट ऑब्जेक्ट (उदाहरण के लिए, GetValuesClient) असाइन करता है. साथ ही, हर ऑब्जेक्ट को ग्लोबल पूल में जोड़ता है.
  • यह कुकी, एसिंक कॉलबैक लॉजिक को मैनेज करती है. जैसे, किसी अनुरोध को अनुरोधों के पूल में जोड़ना. जब हमें नतीजे मिलते हैं, तो यह कुकी उन अनुरोधों को पूरा करती है जो अब भी प्रोसेस किए जा रहे हैं. अगर प्रोसेस किए जा रहे किसी अनुरोध का समय खत्म हो जाता है, तो यह कुकी गड़बड़ी का मैसेज दिखाती है.
  • यह कुकी, LargeParcelable को क्रमबद्ध और क्रम से हटाती है. इसके बारे में जानने के लिए, ParcelableUtils.h देखें.
  • यह कुकी, सदस्यता मैनेज करती है. इसके बारे में जानने के लिए, SubscriptionManager.h देखें.
  • यह कुकी अनुमतियों की जांच करती है. (checkReadPermission और checkWritePermission फ़ंक्शन देखें).
  • यह समय-समय पर IVehicleHardware.checkHealth को कॉल करता है और हार्टबीट सिग्नल भेजता है. checkHealth फ़ंक्शन देखें.

IVehicleHardware एक सामान्य इंटरफ़ेस है. इसका इस्तेमाल, वीएचएएल के हार्डवेयर के हिसाब से लागू किए गए फ़ंक्शन को दिखाने के लिए किया जाता है. IVehicleHardware के लिए रेफ़रंस इंप्लीमेंटेशन FakeVehicleHardware है. यह प्रॉपर्टी की वैल्यू को सेव करने के लिए, इन-मेमोरी मैप का इस्तेमाल करता है. साथ ही, यह किसी असली वाहन बस से कम्यूनिकेट नहीं करता. इसे एम्युलेटर पर चलाने के लिए बनाया गया है. साथ ही, यह किसी खास हार्डवेयर पर निर्भर नहीं करता. वेंडर को इसका इस्तेमाल बिना किसी बदलाव के नहीं करना चाहिए. साथ ही, उन्हें वाहन की बस के हिसाब से लॉजिक जोड़ना चाहिए.

Android 14 से, FakeVehicleHardware डिवाइस के /vendor/etc/automotive/vhalconfig/ फ़ोल्डर से, शुरू होने के दौरान रन-टाइम पर काम करने वाली प्रॉपर्टी कॉन्फ़िगरेशन को पढ़ता है. इस फ़ोल्डर में JSON-स्टाइल वाली कॉन्फ़िगरेशन फ़ाइल होती है. कॉन्फ़िगरेशन फ़ाइल के फ़ॉर्मैट और कॉन्फ़िगरेशन फ़ाइल के कॉन्टेंट के बारे में जानने के लिए, रेफ़रंस वीएचएएल की README फ़ाइल देखें.

FakeVehicleHardware, टेस्टिंग के लिए कॉन्फ़िगरेशन फ़ाइल को बदलने की सुविधा भी देता है. अगर सिस्टम प्रॉपर्टी persist.vendor.vhal_init_value_override सेट है, तो यह डिवाइस पर मौजूद /vendor/etc/automotive/vhaloverride/ फ़ोल्डर से कॉन्फ़िगरेशन फ़ाइल का इस्तेमाल करके, मौजूदा कॉन्फ़िगरेशन को बदल देता है. इस प्रॉपर्टी को, बिल्ड टाइम पर या VHAL शुरू होने से पहले बूट के दौरान सेट किया जाना चाहिए. वेंडर, इसी तरह के तरीके का इस्तेमाल कर सकता है, ताकि VHAL के साथ काम करने वाली प्रॉपर्टी कॉन्फ़िगरेशन को हार्ड-कोड न किया जाए. साथ ही, इसे शुरू होने के समय डाइनैमिक तरीके से तय किया जा सके. वीएचएएल के शुरू होने के बाद, वाहन की प्रॉपर्टी कॉन्फ़िगरेशन की सूची में बदलाव नहीं किया जाना चाहिए.

Android 16 से, GRPCVehicleHardware एक और रेफ़रंस IVehicleHardware लागू करने की सुविधा देता है. इस तरीके में यह माना जाता है कि रिमोट मशीन या वीएम पर कोई अलग सर्वर चल रहा है. इस सर्वर में, प्रॉपर्टी को मैनेज करने की सुविधा मौजूद है. AAOS डिवाइसों पर चलने वाला वीएचएएल, प्रॉक्सी के तौर पर काम करता है. यह रिमोट सर्वर को अनुरोध भेजता है. ज़्यादा जानकारी के लिए, grpc देखें.