Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 31cc64aa authored by Yifan Hong's avatar Yifan Hong
Browse files

healthd connect to health@1.0 hal

This is the original code path (BatteryService
-> healthd -> health 1.0 HAL). This ensures
upgrade-ability for old devices to P.

This is a partial revert of
287c41ff, with
some modifications to the original healthd_board_*
functions for healthd.

Bug: 65990106
Test: VTS test for healthd and health service
Change-Id: If1c65e64e2fd6750369d52c8051ca6aa2b57ef27
parent cded900b
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -102,6 +102,7 @@ cc_binary {
        "libhwbinder",
        "liblog",
        "libutils",
        "android.hardware.health@1.0",
        "android.hardware.health@2.0",
    ],

+67 −5
Original line number Diff line number Diff line
@@ -14,13 +14,75 @@
 * limitations under the License.
 */

#define LOG_TAG "healthd"
#include <android-base/logging.h>

#include <android/hardware/health/1.0/IHealth.h>
#include <android/hardware/health/1.0/types.h>
#include <hal_conversion.h>
#include <healthd/healthd.h>
#include <hidl/HidlTransportSupport.h>

using android::OK;
using android::NAME_NOT_FOUND;
using android::hardware::health::V1_0::HealthConfig;
using android::hardware::health::V1_0::HealthInfo;
using android::hardware::health::V1_0::Result;
using android::hardware::health::V1_0::hal_conversion::convertFromHealthConfig;
using android::hardware::health::V1_0::hal_conversion::convertToHealthConfig;
using android::hardware::health::V1_0::hal_conversion::convertFromHealthInfo;
using android::hardware::health::V1_0::hal_conversion::convertToHealthInfo;

using IHealthLegacy = android::hardware::health::V1_0::IHealth;

static android::sp<IHealthLegacy> gHealth_1_0;

static int healthd_board_get_energy_counter(int64_t* energy) {
    if (gHealth_1_0 == nullptr) {
        return NAME_NOT_FOUND;
    }

    Result result = Result::NOT_SUPPORTED;
    gHealth_1_0->energyCounter([energy, &result](Result ret, int64_t energyOut) {
        result = ret;
        *energy = energyOut;
    });

    return result == Result::SUCCESS ? OK : NAME_NOT_FOUND;
}

void healthd_board_init(struct healthd_config* config) {
    gHealth_1_0 = IHealthLegacy::getService();

    if (gHealth_1_0 == nullptr) {
        return;
    }

void healthd_board_init(struct healthd_config*) {
    // use defaults
    HealthConfig halConfig{};
    convertToHealthConfig(config, halConfig);
    gHealth_1_0->init(halConfig, [config](const auto& halConfigOut) {
        convertFromHealthConfig(halConfigOut, config);
        // always redirect energy counter queries
        config->energyCounter = healthd_board_get_energy_counter;
    });
    LOG(INFO) << LOG_TAG << ": redirecting calls to 1.0 health HAL";
}

int healthd_board_battery_update(struct android::BatteryProperties*) {
    // return 0 to log periodic polled battery status to kernel log
    return 0;
// TODO(b/68724651): Move this function into healthd_mode_service_2_0_battery_update
// with logthis returned.
int healthd_board_battery_update(struct android::BatteryProperties* props) {
    int logthis = 0;

    if (gHealth_1_0 == nullptr) {
        return logthis;
    }

    HealthInfo info;
    convertToHealthInfo(props, info);
    gHealth_1_0->update(info, [props, &logthis](int32_t ret, const auto& infoOut) {
        logthis = ret;
        convertFromHealthInfo(infoOut, props);
    });

    return logthis;
}