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

Commit 348f9808 authored by Hridya Valsaraju's avatar Hridya Valsaraju Committed by android-build-merger
Browse files

Merge "Initialize healthd_mode_ops in recovery default Health HAL impl." am: c5b3b006

am: 8984ea43

Change-Id: Id279cd80637c26babdb07dac5c7ac6864116af97
parents 84f84880 8984ea43
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -142,7 +142,7 @@ Return<void> Health::getChargeStatus(getChargeStatus_cb _hidl_cb) {
Return<Result> Health::update() {
    if (!healthd_mode_ops || !healthd_mode_ops->battery_update) {
        LOG(WARNING) << "health@2.0: update: not initialized. "
                     << "update() should not be called in charger / recovery.";
                     << "update() should not be called in charger";
        return Result::UNKNOWN;
    }

+24 −1
Original line number Diff line number Diff line
@@ -46,9 +46,32 @@ int healthd_board_battery_update(struct android::BatteryProperties*) {
    return 0;
}

void healthd_mode_default_impl_init(struct healthd_config*) {
    // noop
}

int healthd_mode_default_impl_preparetowait(void) {
    return -1;
}

void healthd_mode_default_impl_heartbeat(void) {
    // noop
}

void healthd_mode_default_impl_battery_update(struct android::BatteryProperties*) {
    // noop
}

static struct healthd_mode_ops healthd_mode_default_impl_ops = {
    .init = healthd_mode_default_impl_init,
    .preparetowait = healthd_mode_default_impl_preparetowait,
    .heartbeat = healthd_mode_default_impl_heartbeat,
    .battery_update = healthd_mode_default_impl_battery_update,
};

extern "C" IHealth* HIDL_FETCH_IHealth(const char* name) {
    const static std::string providedInstance{"backup"};

    healthd_mode_ops = &healthd_mode_default_impl_ops;
    if (providedInstance == name) {
        // use defaults
        // Health class stores static instance