mirror of
https://github.com/Evolution-X/hardware_interfaces
synced 2026-02-01 16:50:18 +00:00
Add SubHal header for Sensors HAL 2.1
Bug: 149758467 Test: compile Change-Id: Id10d20e5d24571572565ac5d968f265ef7d7070f
This commit is contained in:
@@ -28,6 +28,7 @@ cc_binary {
|
||||
shared_libs: [
|
||||
"android.hardware.sensors@2.0",
|
||||
"android.hardware.sensors@2.0-ScopedWakelock",
|
||||
"android.hardware.sensors@2.1",
|
||||
"libbase",
|
||||
"libcutils",
|
||||
"libfmq",
|
||||
|
||||
@@ -16,11 +16,12 @@
|
||||
cc_defaults {
|
||||
name: "android.hardware.sensors@2.X-multihal-defaults",
|
||||
header_libs: [
|
||||
"android.hardware.sensors@2.0-multihal.header",
|
||||
"android.hardware.sensors@2.X-multihal.header",
|
||||
],
|
||||
shared_libs: [
|
||||
"android.hardware.sensors@1.0",
|
||||
"android.hardware.sensors@2.0",
|
||||
"android.hardware.sensors@2.1",
|
||||
"libbase",
|
||||
"libcutils",
|
||||
"libfmq",
|
||||
@@ -32,9 +33,24 @@ cc_defaults {
|
||||
cflags: ["-DLOG_TAG=\"SensorsMultiHal\""],
|
||||
}
|
||||
|
||||
// Header target for sub-HALs that implement the Multi-HAL 2.0 interface
|
||||
cc_library_headers {
|
||||
name: "android.hardware.sensors@2.0-multihal.header",
|
||||
vendor_available: true,
|
||||
export_include_dirs: ["include/V2_0"],
|
||||
}
|
||||
|
||||
// Header target for sub-HALs that implement the Multi-HAL 2.1 interface
|
||||
cc_library_headers {
|
||||
name: "android.hardware.sensors@2.1-multihal.header",
|
||||
vendor_available: true,
|
||||
export_include_dirs: ["include/V2_1"],
|
||||
}
|
||||
|
||||
// Header target for Multi-HAL so it can reference both 2.0/2.1 headers
|
||||
cc_library_headers {
|
||||
name: "android.hardware.sensors@2.X-multihal.header",
|
||||
vendor_available: true,
|
||||
export_include_dirs: ["include"],
|
||||
}
|
||||
|
||||
@@ -49,7 +65,7 @@ cc_library_static {
|
||||
],
|
||||
vendor_available: true,
|
||||
export_header_lib_headers: [
|
||||
"android.hardware.sensors@2.0-multihal.header",
|
||||
"android.hardware.sensors@2.X-multihal.header",
|
||||
],
|
||||
}
|
||||
|
||||
@@ -62,6 +78,9 @@ cc_library_shared {
|
||||
srcs: [
|
||||
"ScopedWakelock.cpp",
|
||||
],
|
||||
header_libs: [
|
||||
"android.hardware.sensors@2.0-multihal.header",
|
||||
],
|
||||
vendor_available: true,
|
||||
export_header_lib_headers: [
|
||||
"android.hardware.sensors@2.0-multihal.header",
|
||||
@@ -78,6 +97,9 @@ cc_test_library {
|
||||
"ScopedWakelock.cpp",
|
||||
],
|
||||
vendor_available: true,
|
||||
header_libs: [
|
||||
"android.hardware.sensors@2.0-multihal.header",
|
||||
],
|
||||
export_header_lib_headers: [
|
||||
"android.hardware.sensors@2.0-multihal.header",
|
||||
],
|
||||
|
||||
@@ -16,8 +16,6 @@
|
||||
|
||||
#include "HalProxy.h"
|
||||
|
||||
#include "SubHal.h"
|
||||
|
||||
#include <android/hardware/sensors/2.0/types.h>
|
||||
|
||||
#include <android-base/file.h>
|
||||
|
||||
@@ -14,7 +14,7 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "ScopedWakelock.h"
|
||||
#include "V2_0/ScopedWakelock.h"
|
||||
|
||||
namespace android {
|
||||
namespace hardware {
|
||||
|
||||
@@ -16,8 +16,9 @@
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "ScopedWakelock.h"
|
||||
#include "SubHal.h"
|
||||
#include "V2_0/ScopedWakelock.h"
|
||||
#include "V2_0/SubHal.h"
|
||||
#include "V2_1/SubHal.h"
|
||||
|
||||
#include <android/hardware/sensors/2.0/ISensors.h>
|
||||
#include <android/hardware/sensors/2.0/types.h>
|
||||
|
||||
@@ -159,7 +159,7 @@ using ::android::hardware::sensors::V2_0::implementation::ISensorsSubHal;
|
||||
* library. This function will only be invoked once at initialization time.
|
||||
*
|
||||
* NOTE: The supported sensors HAL version must match SUB_HAL_2_0_VERSION exactly or the HalProxy
|
||||
* will fail to initialize.
|
||||
* will fail to initialize.
|
||||
*
|
||||
* @param uint32_t when this function returns, this parameter must contain the HAL version that
|
||||
* this sub-HAL supports. To support this version of multi-HAL, this must be set to
|
||||
180
sensors/common/default/2.X/multihal/include/V2_1/SubHal.h
Normal file
180
sensors/common/default/2.X/multihal/include/V2_1/SubHal.h
Normal file
@@ -0,0 +1,180 @@
|
||||
/*
|
||||
* Copyright (C) 2020 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.
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "V2_0/ScopedWakelock.h"
|
||||
|
||||
#include <android/hardware/sensors/2.1/ISensors.h>
|
||||
#include <android/hardware/sensors/2.1/types.h>
|
||||
|
||||
#include <vector>
|
||||
|
||||
// Indicates the current version of the multiHAL interface formatted as (HAL major version) << 24 |
|
||||
// (HAL minor version) << 16 | (multiHAL version)
|
||||
#define SUB_HAL_2_1_VERSION 0x02010000
|
||||
|
||||
namespace android {
|
||||
namespace hardware {
|
||||
namespace sensors {
|
||||
namespace V2_1 {
|
||||
namespace implementation {
|
||||
|
||||
/**
|
||||
* Interface that contains several callbacks into the HalProxy class to communicate dynamic sensor
|
||||
* changes and sensor events to the framework and acquire wake locks. The HalProxy will ensure
|
||||
* callbacks occurring at the same time from multiple sub-HALs are synchronized in a safe, efficient
|
||||
* manner.
|
||||
*/
|
||||
class IHalProxyCallback : public ISensorsCallback {
|
||||
public:
|
||||
using ScopedWakelock = V2_0::implementation::ScopedWakelock;
|
||||
|
||||
/**
|
||||
* Thread-safe callback used to post events to the HalProxy. Sub-HALs should invoke this
|
||||
* whenever new sensor events need to be delivered to the sensors framework. Once invoked, the
|
||||
* HalProxy will attempt to send events to the sensors framework using a blocking write with a
|
||||
* 5 second timeout. This write may be done asynchronously if the queue used to communicate
|
||||
* with the framework is full to avoid blocking sub-HALs for the length of the timeout. If the
|
||||
* write fails, the events will be dropped and any wake locks held will be released.
|
||||
*
|
||||
* The provided ScopedWakelock must be locked if the events are from wakeup sensors. If it's
|
||||
* not locked accordingly, the HalProxy will crash as this indicates the sub-HAL isn't compliant
|
||||
* with the sensors HAL specification. Additionally, since ScopedWakelock isn't copyable,
|
||||
* the HalProxy will take ownership of the wake lock given when this method is invoked. Once the
|
||||
* method returns, the HalProxy will handle holding the wake lock, if necessary, until the
|
||||
* framework has successfully processed any wakeup events.
|
||||
*
|
||||
* No return type is used for this callback to avoid sub-HALs trying to resend events when
|
||||
* writes fail. Writes should only fail when the framework is under inordinate stress which will
|
||||
* likely result in a framework restart so retrying will likely only result in overloading the
|
||||
* HalProxy. Sub-HALs should always assume that the write was a success and perform any
|
||||
* necessary cleanup. Additionally, the HalProxy will ensure it logs any errors (through ADB and
|
||||
* bug reports) it encounters during delivery to ensure it's obvious that a failure occurred.
|
||||
*
|
||||
* @param events the events that should be sent to the sensors framework
|
||||
* @param wakelock ScopedWakelock that should be locked to send events from wake sensors and
|
||||
* unlocked otherwise.
|
||||
*/
|
||||
virtual void postEvents(const std::vector<V2_1::Event>& events, ScopedWakelock wakelock) = 0;
|
||||
|
||||
/**
|
||||
* Initializes a ScopedWakelock on the stack that, when locked, will increment the reference
|
||||
* count for the sub-HAL's wake lock managed inside the HalProxy. See the ScopedWakelock class
|
||||
* definition for how it should be used.
|
||||
*
|
||||
* @param lock whether the ScopedWakelock should be locked before it's returned.
|
||||
* @return the created ScopedWakelock
|
||||
*/
|
||||
virtual ScopedWakelock createScopedWakelock(bool lock) = 0;
|
||||
};
|
||||
|
||||
/**
|
||||
* ISensorsSubHal is an interface that sub-HALs must implement in order to be compliant with
|
||||
* multihal and in order for the HalProxy to successfully load and communicate with the sub-HAL.
|
||||
*
|
||||
* Any vendor wishing to implement this interface and support multihal will need to create a
|
||||
* dynamic library that exposes sensorsHalGetSubHal (defined below). This library will be loaded by
|
||||
* the HalProxy when the sensors HAL is initialized and then the HalProxy will retrieve the vendor's
|
||||
* implementation of sensorsHalGetSubHal.
|
||||
*
|
||||
* With the exception of the initialize method, ISensorsSubHal will implement the ISensors.hal spec.
|
||||
* Any sensor handles given to the HalProxy, either through getSensorsList() or the
|
||||
* onDynamicSensors(Dis)Connected callbacks, will be translated to avoid clashing with other sub-HAL
|
||||
* handles. To achieve this, the HalProxy will use the upper byte to store the sub-HAL index and
|
||||
* sub-HALs can continue to use the lower 3 bytes of the handle.
|
||||
*/
|
||||
class ISensorsSubHal : public ISensors {
|
||||
public:
|
||||
// The ISensors version of initialize isn't used for multihal. Instead, sub-HALs must implement
|
||||
// the version below to allow communciation logic to centralized in the HalProxy
|
||||
Return<V1_0::Result> initialize_2_1(
|
||||
const ::android::hardware::MQDescriptorSync<V2_1::Event>& /* eventQueueDescriptor */,
|
||||
const ::android::hardware::MQDescriptorSync<uint32_t>& /* wakeLockDescriptor */,
|
||||
const sp<ISensorsCallback>& /* sensorsCallback */) final {
|
||||
return V1_0::Result::INVALID_OPERATION;
|
||||
}
|
||||
|
||||
Return<V1_0::Result> initialize(
|
||||
const ::android::hardware::MQDescriptorSync<V1_0::Event>& /* eventQueueDescriptor */,
|
||||
const ::android::hardware::MQDescriptorSync<uint32_t>& /* wakeLockDescriptor */,
|
||||
const sp<V2_0::ISensorsCallback>& /* sensorsCallback */) final {
|
||||
return V1_0::Result::INVALID_OPERATION;
|
||||
}
|
||||
|
||||
// Several HAL 2.0 methods won't be invoked on HAL 2.1 so they are stubbed out below.
|
||||
Return<void> getSensorsList(getSensorsList_cb /* _hidl_cb */) final { return Void(); }
|
||||
|
||||
Return<V1_0::Result> injectSensorData(const V1_0::Event& /* event */) final {
|
||||
return V1_0::Result::INVALID_OPERATION;
|
||||
}
|
||||
|
||||
/**
|
||||
* Method defined in ::android::hidl::base::V1_0::IBase.
|
||||
*
|
||||
* This method should write debug information to hidl_handle that is useful for debugging
|
||||
* issues. Suggestions include:
|
||||
* - Sensor info including handle values and any other state available in the SensorInfo class
|
||||
* - List of active sensors and their current sampling period and reporting latency
|
||||
* - Information about pending flush requests
|
||||
* - Current operating mode
|
||||
* - Currently registered direct channel info
|
||||
* - A history of any of the above
|
||||
*/
|
||||
virtual Return<void> debug(const hidl_handle& fd, const hidl_vec<hidl_string>& args) = 0;
|
||||
|
||||
/**
|
||||
* @return A human-readable name for use in wake locks and logging.
|
||||
*/
|
||||
virtual const std::string getName() = 0;
|
||||
|
||||
/**
|
||||
* This is the first method invoked on the sub-HAL after it's allocated through
|
||||
* sensorsHalGetSubHal() by the HalProxy. Sub-HALs should use this to initialize any state and
|
||||
* retain the callback given in order to communicate with the HalProxy. Method will be called
|
||||
* anytime the sensors framework restarts. Therefore, this method will be responsible for
|
||||
* reseting the state of the subhal and cleaning up and reallocating any previously allocated
|
||||
* data. Initialize should ensure that the subhal has reset its operation mode to NORMAL state
|
||||
* as well.
|
||||
*
|
||||
* @param halProxyCallback callback used to inform the HalProxy when a dynamic sensor's state
|
||||
* changes, new sensor events should be sent to the framework, and when a new ScopedWakelock
|
||||
* should be created.
|
||||
* @return result OK on success
|
||||
*/
|
||||
virtual Return<V1_0::Result> initialize(const sp<IHalProxyCallback>& halProxyCallback) = 0;
|
||||
};
|
||||
|
||||
} // namespace implementation
|
||||
} // namespace V2_1
|
||||
} // namespace sensors
|
||||
} // namespace hardware
|
||||
} // namespace android
|
||||
|
||||
/**
|
||||
* Function that must be exported so the HalProxy class can invoke it on the sub-HAL dynamic
|
||||
* library. This function will only be invoked once at initialization time.
|
||||
*
|
||||
* NOTE: The supported sensors HAL version must match SUB_HAL_2_1_VERSION or the HalProxy
|
||||
* will fail to initialize.
|
||||
*
|
||||
* @param uint32_t when this function returns, this parameter must contain the HAL version that
|
||||
* this sub-HAL supports. This must be set to SUB_HAL_2_1_VERSION.
|
||||
* @return A statically allocated, valid ISensorsSubHal implementation.
|
||||
*/
|
||||
__attribute__((visibility(
|
||||
"default"))) extern "C" ::android::hardware::sensors::V2_1::implementation::ISensorsSubHal*
|
||||
sensorsHalGetSubHal_2_1(uint32_t* version);
|
||||
@@ -26,6 +26,7 @@ cc_defaults {
|
||||
"android.hardware.sensors@1.0",
|
||||
"android.hardware.sensors@2.0",
|
||||
"android.hardware.sensors@2.0-ScopedWakelock",
|
||||
"android.hardware.sensors@2.1",
|
||||
"libcutils",
|
||||
"libfmq",
|
||||
"libhardware",
|
||||
@@ -85,6 +86,8 @@ cc_test {
|
||||
shared_libs: [
|
||||
"android.hardware.sensors@1.0",
|
||||
"android.hardware.sensors@2.0",
|
||||
"android.hardware.sensors@2.0-ScopedWakelock",
|
||||
"android.hardware.sensors@2.1",
|
||||
"libbase",
|
||||
"libcutils",
|
||||
"libfmq",
|
||||
|
||||
@@ -19,8 +19,8 @@
|
||||
#include <fmq/MessageQueue.h>
|
||||
|
||||
#include "HalProxy.h"
|
||||
#include "ScopedWakelock.h"
|
||||
#include "SensorsSubHal.h"
|
||||
#include "V2_0/ScopedWakelock.h"
|
||||
|
||||
#include <chrono>
|
||||
#include <set>
|
||||
|
||||
@@ -16,7 +16,7 @@
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "SubHal.h"
|
||||
#include "V2_0/SubHal.h"
|
||||
|
||||
#include "Sensor.h"
|
||||
|
||||
|
||||
Reference in New Issue
Block a user