नेटिव क्लाइंट के साथ VHAL का इस्तेमाल करना

VHAL, Java और नेटिव क्लाइंट के साथ काम करता है. Car Service, वीएचएएल के लिए Java क्लाइंट है. कार ऐप्लिकेशन के लिए, वीएचएएल प्रॉपर्टी को ऐक्सेस करने के लिए, सीधे वीएचएएल से कम्यूनिकेट करने के बजाय, Car API (उदाहरण के लिए, CarPropertyManager) का इस्तेमाल करें. दरअसल, SELinux डायरेक्ट ऐक्सेस को ब्लॉक करता है. ज़्यादा जानकारी के लिए, Car API का दस्तावेज़ देखें. इसके लिए, पैकेज इंडेक्स पर जाएं.

Android 13 से शुरू होने वाले नेटिव क्लाइंट के लिए, VHAL से सीधे कनेक्ट करने के बजाय libvhalclient का इस्तेमाल करें. यह एक क्लाइंट लाइब्रेरी है. यह एआईडीएल और एचआईडीएल वीएचएएल को लागू करने के लिए, एक सामान्य इंटरफ़ेस IVhalClient.h उपलब्ध कराती है. यहां दिए गए उदाहरण में, VHAL नेटिव क्लाइंट बनाने और उसका इस्तेमाल करके, वाहन की पहचान करने वाला नंबर (वीआईएन) पाने का तरीका बताया गया है:

#include <IVhalClient.h>
#include <VehicleHalTypes.h>
#include <VehicleUtils.h>

using ::aidl::android::hardware::automotive::vehicle::VehicleProperty;
using ::android::frameworks::automotive::vhal::IVhalClient;
using ::android::hardware::automotive::vehicle::toInt;

int main(int argc, char** argv) {
  auto vhalClient = IVhalClient::tryCreate();
  if (vhalClient == nullptr) {
    // handle error.
    return -1;
  }
  auto result = vhalClient->getValueSync(
      *vhalClient->createHalPropValue(toInt(VehicleProperty::INFO_VIN)));
  // Use result

  return 0;
}

आपको SELinux नीति को कॉन्फ़िगर करना होगा, ताकि आपका नेटिव क्लाइंट VHAL को ऐक्सेस कर सके. उदाहरण के लिए:

# Define my domain
type my_native_daemon, domain;

# Define the exec file type.
type my_native_daemon_exec, exec_type, file_type, system_file_type;

# Initialize domain.
init_daemon_domain(my_native_daemon)

# Allow using hwbinder for HIDL VHAL, not required if AIDL is used.
hwbinder_use(my_native_daemon)
# Allow using binder for AIDL VHAL
binder_use(my_native_daemon)
# Allow my_native_daemon to be a VHAL client.
hal_client_domain(my_native_daemon, hal_vehicle)