/* * Copyright (C) 2015 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.car.hal; import static com.android.car.internal.ExcludeFromCodeCoverageGeneratedReport.BOILERPLATE_CODE; import android.annotation.NonNull; import android.car.builtin.util.Slogf; import android.hardware.automotive.vehicle.VehiclePropError; import com.android.car.internal.ExcludeFromCodeCoverageGeneratedReport; import java.io.PrintWriter; import java.util.ArrayList; import java.util.Collection; import java.util.List; /** * Common interface for all HAL service like sensor HAL. * Each HAL service is connected with XyzService supporting XyzManager, * and will translate HAL data into car api specific format. */ public abstract class HalServiceBase { private static final String MY_TAG = HalServiceBase.class.getSimpleName(); /** For dispatching events. Kept here to avoid alloc every time */ private final ArrayList mDispatchList = new ArrayList<>(1); static final int NOT_SUPPORTED_PROPERTY = -1; public List getDispatchList() { return mDispatchList; } /** initialize */ public abstract void init(); /** release and stop operation */ public abstract void release(); /** * Returns all property IDs this HalService can support. If return value is empty, * {@link #isSupportedProperty(int)} is used to query support for each property. * * Implementers should consider keeping this method package private to avoid exposing the * internal array. */ @NonNull abstract int[] getAllSupportedProperties(); /** * Checks if given {@code propId} is supported. */ public boolean isSupportedProperty(int propId) { for (int supported: getAllSupportedProperties()) { if (propId == supported) { return true; } } return false; } /** * Takes the passed properties. Passed properties are a subset of properties returned from * {@link #getAllSupportedProperties()} and are supported in the current device. * * @param properties properties that are available in this device. This is guaranteed to be * supported by the HalService as the list is filtered with * {@link #getAllSupportedProperties()} or {@link #isSupportedProperty(int)}. * It can be empty if no property is available. */ @ExcludeFromCodeCoverageGeneratedReport(reason = BOILERPLATE_CODE) public void takeProperties(@NonNull Collection properties) { } /** * Handles property changes from HAL. */ @ExcludeFromCodeCoverageGeneratedReport(reason = BOILERPLATE_CODE) public void onHalEvents(List values) { } /** * Handles errors and pass error codes when setting properties. */ @ExcludeFromCodeCoverageGeneratedReport(reason = BOILERPLATE_CODE) public void onPropertySetError(ArrayList errors) { for (int i = 0; i < errors.size(); i++) { VehiclePropError error = errors.get(i); Slogf.d(MY_TAG, getClass().getSimpleName() + ".onPropertySetError(): property=" + error.propId + ", area=" + error.areaId + " , errorCode = " + error.errorCode); } } /** * Dumps HAL service related info to the writer passed as parameter. */ public abstract void dump(PrintWriter writer); /** * Helper class that maintains bi-directional mapping between manager's property * Id (public or system API) and vehicle HAL property Id. * *

This class is supposed to be immutable. Use {@link #create(int[])} factory method to * instantiate this class. */ static class ManagerToHalPropIdMap { private final BidirectionalSparseIntArray mMap; /** * Creates {@link ManagerToHalPropIdMap} for provided [manager prop Id, hal prop Id] pairs. * *

The input array should have an odd number of elements. */ static ManagerToHalPropIdMap create(int... mgrToHalPropIds) { return new ManagerToHalPropIdMap(BidirectionalSparseIntArray.create(mgrToHalPropIds)); } private ManagerToHalPropIdMap(BidirectionalSparseIntArray map) { mMap = map; } int getHalPropId(int managerPropId) { return mMap.getValue(managerPropId, NOT_SUPPORTED_PROPERTY); } int getManagerPropId(int halPropId) { return mMap.getKey(halPropId, NOT_SUPPORTED_PROPERTY); } } }