mirror of
https://github.com/Evolution-X/hardware_interfaces
synced 2026-02-01 05:49:27 +00:00
Merge "Add android.hardware.health AIDL HAL V3." into main
This commit is contained in:
@@ -265,7 +265,7 @@
|
||||
</hal>
|
||||
<hal format="aidl" optional="true">
|
||||
<name>android.hardware.health</name>
|
||||
<version>1-2</version>
|
||||
<version>3</version>
|
||||
<interface>
|
||||
<name>IHealth</name>
|
||||
<instance>default</instance>
|
||||
|
||||
@@ -48,7 +48,7 @@ aidl_interface {
|
||||
},
|
||||
|
||||
],
|
||||
frozen: true,
|
||||
frozen: false,
|
||||
|
||||
}
|
||||
|
||||
@@ -80,7 +80,7 @@ cc_library {
|
||||
name: "android.hardware.health-translate-ndk",
|
||||
defaults: ["android.hardware.health-translate-ndk_defaults"],
|
||||
shared_libs: [
|
||||
"android.hardware.health-V2-ndk",
|
||||
"android.hardware.health-V3-ndk",
|
||||
],
|
||||
}
|
||||
|
||||
@@ -97,7 +97,7 @@ java_library {
|
||||
name: "android.hardware.health-translate-java",
|
||||
srcs: ["android/hardware/health/Translate.java"],
|
||||
libs: [
|
||||
"android.hardware.health-V2-java",
|
||||
"android.hardware.health-V3-java",
|
||||
"android.hardware.health-V2.0-java",
|
||||
"android.hardware.health-V2.1-java",
|
||||
],
|
||||
|
||||
@@ -37,4 +37,6 @@ parcelable BatteryHealthData {
|
||||
long batteryManufacturingDateSeconds;
|
||||
long batteryFirstUsageSeconds;
|
||||
long batteryStateOfHealth;
|
||||
@nullable String batterySerialNumber;
|
||||
android.hardware.health.BatteryPartStatus batteryPartStatus = android.hardware.health.BatteryPartStatus.UNSUPPORTED;
|
||||
}
|
||||
|
||||
@@ -0,0 +1,40 @@
|
||||
/*
|
||||
* Copyright (C) 2023 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.
|
||||
*/
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
// THIS FILE IS IMMUTABLE. DO NOT EDIT IN ANY CASE. //
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
// This file is a snapshot of an AIDL file. Do not edit it manually. There are
|
||||
// two cases:
|
||||
// 1). this is a frozen version file - do not edit this in any case.
|
||||
// 2). this is a 'current' file. If you make a backwards compatible change to
|
||||
// the interface (from the latest frozen version), the build system will
|
||||
// prompt you to update this file with `m <name>-update-api`.
|
||||
//
|
||||
// You must not make a backward incompatible change to any AIDL file built
|
||||
// with the aidl_interface module type with versions property set. The module
|
||||
// type is used to build AIDL files in a way that they can be used across
|
||||
// independently updatable components of the system. If a device is shipped
|
||||
// with such a backward incompatible change, it has a high risk of breaking
|
||||
// later when a module using the interface is updated, e.g., Mainline modules.
|
||||
|
||||
package android.hardware.health;
|
||||
@Backing(type="int") @VintfStability
|
||||
enum BatteryPartStatus {
|
||||
UNSUPPORTED,
|
||||
ORIGINAL,
|
||||
REPLACED,
|
||||
}
|
||||
@@ -16,6 +16,8 @@
|
||||
|
||||
package android.hardware.health;
|
||||
|
||||
import android.hardware.health.BatteryPartStatus;
|
||||
|
||||
/*
|
||||
* Battery health data
|
||||
*/
|
||||
@@ -36,4 +38,14 @@ parcelable BatteryHealthData {
|
||||
* Otherwise, value must be in the range 0 to 100.
|
||||
*/
|
||||
long batteryStateOfHealth;
|
||||
/**
|
||||
* Serial number of the battery. Null if not supported. If supported, a string of at least 6
|
||||
* alphanumeric characters. Characters may either be upper or lower case, but for comparison
|
||||
* and uniqueness purposes, must be treated as case-insensitive.
|
||||
*/
|
||||
@nullable String batterySerialNumber;
|
||||
/**
|
||||
* Indicator for part originality of the battery.
|
||||
*/
|
||||
BatteryPartStatus batteryPartStatus = BatteryPartStatus.UNSUPPORTED;
|
||||
}
|
||||
|
||||
39
health/aidl/android/hardware/health/BatteryPartStatus.aidl
Normal file
39
health/aidl/android/hardware/health/BatteryPartStatus.aidl
Normal file
@@ -0,0 +1,39 @@
|
||||
/*
|
||||
* Copyright (C) 2023 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 android.hardware.health;
|
||||
|
||||
/**
|
||||
* Possible values for BatteryPartStatus.
|
||||
* Note: These are currently in sync with BatteryManager and must not
|
||||
* be extended / altered.
|
||||
*/
|
||||
@VintfStability
|
||||
@Backing(type="int")
|
||||
enum BatteryPartStatus {
|
||||
/**
|
||||
* Device cannot differentiate an original battery from a replaced battery.
|
||||
*/
|
||||
UNSUPPORTED = 0,
|
||||
/**
|
||||
* Device has the original battery it was manufactured with.
|
||||
*/
|
||||
ORIGINAL = 1,
|
||||
/**
|
||||
* Device has a replaced battery.
|
||||
*/
|
||||
REPLACED = 2,
|
||||
}
|
||||
@@ -29,7 +29,7 @@ cc_defaults {
|
||||
"libcutils",
|
||||
"liblog",
|
||||
"libutils",
|
||||
"android.hardware.health-V2-ndk",
|
||||
"android.hardware.health-V3-ndk",
|
||||
|
||||
// TODO(b/177269435): remove when BatteryMonitor works with AIDL HealthInfo.
|
||||
"libhidlbase",
|
||||
@@ -48,7 +48,7 @@ cc_defaults {
|
||||
name: "libhealth_aidl_charger_defaults",
|
||||
shared_libs: [
|
||||
// common
|
||||
"android.hardware.health-V2-ndk",
|
||||
"android.hardware.health-V3-ndk",
|
||||
"libbase",
|
||||
"libcutils",
|
||||
"liblog",
|
||||
@@ -195,7 +195,7 @@ cc_fuzz {
|
||||
"service_fuzzer_defaults",
|
||||
],
|
||||
static_libs: [
|
||||
"android.hardware.health-V2-ndk",
|
||||
"android.hardware.health-V3-ndk",
|
||||
"libbase",
|
||||
"liblog",
|
||||
"fuzz_libhealth_aidl_impl",
|
||||
|
||||
@@ -153,6 +153,8 @@ ndk::ScopedAStatus Health::getBatteryHealthData(BatteryHealthData* out) {
|
||||
!res.isOk()) {
|
||||
LOG(WARNING) << "Cannot get Battery_state_of_health: " << res.getDescription();
|
||||
}
|
||||
out->batterySerialNumber = std::nullopt;
|
||||
out->batteryPartStatus = BatteryPartStatus::UNSUPPORTED;
|
||||
return ndk::ScopedAStatus::ok();
|
||||
}
|
||||
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
<manifest version="1.0" type="device">
|
||||
<hal format="aidl">
|
||||
<name>android.hardware.health</name>
|
||||
<version>2</version>
|
||||
<version>3</version>
|
||||
<fqname>IHealth/default</fqname>
|
||||
</hal>
|
||||
</manifest>
|
||||
|
||||
@@ -39,7 +39,7 @@ cc_test {
|
||||
"libbinder_ndk",
|
||||
],
|
||||
static_libs: [
|
||||
"android.hardware.health-V2-ndk",
|
||||
"android.hardware.health-V3-ndk",
|
||||
"libgmock",
|
||||
],
|
||||
header_libs: [
|
||||
|
||||
@@ -84,6 +84,21 @@ Matcher<T> IsValidEnum() {
|
||||
return AnyOfArray(enum_range<T>().begin(), enum_range<T>().end());
|
||||
}
|
||||
|
||||
MATCHER(IsValidSerialNumber, "") {
|
||||
if (!arg) {
|
||||
return true;
|
||||
}
|
||||
if (arg->size() < 6) {
|
||||
return false;
|
||||
}
|
||||
for (const auto& c : *arg) {
|
||||
if (!isalnum(c)) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
class HealthAidl : public testing::TestWithParam<std::string> {
|
||||
public:
|
||||
void SetUp() override {
|
||||
@@ -270,7 +285,7 @@ TEST_P(HealthAidl, setChargingPolicy) {
|
||||
ASSERT_THAT(static_cast<int>(value), AnyOf(Eq(1), Eq(4)));
|
||||
}
|
||||
|
||||
MATCHER(IsValidHealthData, "") {
|
||||
MATCHER_P(IsValidHealthData, version, "") {
|
||||
*result_listener << "value is " << arg.toString() << ".";
|
||||
if (!ExplainMatchResult(Ge(-1), arg.batteryManufacturingDateSeconds, result_listener)) {
|
||||
*result_listener << " for batteryManufacturingDateSeconds.";
|
||||
@@ -284,6 +299,15 @@ MATCHER(IsValidHealthData, "") {
|
||||
*result_listener << " for batteryStateOfHealth.";
|
||||
return false;
|
||||
}
|
||||
if (!ExplainMatchResult(IsValidSerialNumber(), arg.batterySerialNumber, result_listener)) {
|
||||
*result_listener << " for batterySerialNumber.";
|
||||
return false;
|
||||
}
|
||||
if (!ExplainMatchResult(IsValidEnum<BatteryPartStatus>(), arg.batteryPartStatus,
|
||||
result_listener)) {
|
||||
*result_listener << " for batteryPartStatus.";
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
@@ -303,7 +327,7 @@ TEST_P(HealthAidl, getBatteryHealthData) {
|
||||
status = health->getBatteryHealthData(&value);
|
||||
ASSERT_THAT(status, AnyOf(IsOk(), ExceptionIs(EX_UNSUPPORTED_OPERATION)));
|
||||
if (!status.isOk()) return;
|
||||
ASSERT_THAT(value, IsValidHealthData());
|
||||
ASSERT_THAT(value, IsValidHealthData(version));
|
||||
}
|
||||
|
||||
MATCHER(IsValidStorageInfo, "") {
|
||||
|
||||
@@ -34,7 +34,7 @@ cc_defaults {
|
||||
"-Werror",
|
||||
],
|
||||
static_libs: [
|
||||
"android.hardware.health-V2-ndk",
|
||||
"android.hardware.health-V3-ndk",
|
||||
"android.hardware.health-translate-ndk",
|
||||
"android.hardware.health@1.0",
|
||||
"android.hardware.health@2.0",
|
||||
|
||||
@@ -230,6 +230,7 @@ ScopedAStatus HealthShim::getChargingPolicy(BatteryChargingPolicy* out) {
|
||||
ScopedAStatus HealthShim::getBatteryHealthData(BatteryHealthData* out) {
|
||||
out->batteryManufacturingDateSeconds = 0;
|
||||
out->batteryFirstUsageSeconds = 0;
|
||||
out->batteryPartStatus = BatteryPartStatus::UNSUPPORTED;
|
||||
return ResultToStatus(Result::NOT_SUPPORTED);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user