diff options
Diffstat (limited to 'health/aidl/default/main.cpp')
-rw-r--r-- | health/aidl/default/main.cpp | 33 |
1 files changed, 31 insertions, 2 deletions
diff --git a/health/aidl/default/main.cpp b/health/aidl/default/main.cpp index 014ae34f69..76c6ba0a8f 100644 --- a/health/aidl/default/main.cpp +++ b/health/aidl/default/main.cpp @@ -19,17 +19,46 @@ #include <health-impl/Health.h> #include <health/utils.h> +#ifndef CHARGER_FORCE_NO_UI +#define CHARGER_FORCE_NO_UI 0 +#endif + +#if !CHARGER_FORCE_NO_UI +#include <health-impl/ChargerUtils.h> +#endif + using aidl::android::hardware::health::HalHealthLoop; using aidl::android::hardware::health::Health; +#if !CHARGER_FORCE_NO_UI +using aidl::android::hardware::health::charger::ChargerCallback; +using aidl::android::hardware::health::charger::ChargerModeMain; +#endif + static constexpr const char* gInstanceName = "default"; +static constexpr std::string_view gChargerArg{"--charger"}; -int main() { - // TODO(b/203246116): handle charger +int main(int argc, char** argv) { // make a default health service auto config = std::make_unique<healthd_config>(); ::android::hardware::health::InitHealthdConfig(config.get()); auto binder = ndk::SharedRefBase::make<Health>(gInstanceName, std::move(config)); + + if (argc >= 2 && argv[1] == gChargerArg) { + android::base::InitLogging(argv, &android::base::KernelLogger); + +#if !CHARGER_FORCE_NO_UI + // If charger shouldn't have UI for your device, simply drop the line below + // for your service implementation. This corresponds to + // ro.charger.no_ui=true + return ChargerModeMain(binder, std::make_shared<ChargerCallback>(binder)); +#endif + + LOG(INFO) << "Starting charger mode without UI."; + } else { + LOG(INFO) << "Starting health HAL."; + } + auto hal_health_loop = std::make_shared<HalHealthLoop>(binder, binder); return hal_health_loop->StartLoop(); } |