From 3698b06acc8da1b00fb414e1c49f4414b3d5286c Mon Sep 17 00:00:00 2001 From: Darren Hsu Date: Fri, 17 Jun 2022 20:30:18 +0800 Subject: [PATCH] powerstats: set AoC clock for timestamp calculations Bug: 233923713 Test: dumpsys android.hardware.power.stats.IPowerStats/default Change-Id: I40c155c78331255ec5a7d9300798cec0a3d219f5 Signed-off-by: Darren Hsu --- powerstats/Gs101CommonDataProviders.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/powerstats/Gs101CommonDataProviders.cpp b/powerstats/Gs101CommonDataProviders.cpp index 13e6b71f..035810b4 100644 --- a/powerstats/Gs101CommonDataProviders.cpp +++ b/powerstats/Gs101CommonDataProviders.cpp @@ -45,6 +45,8 @@ using aidl::android::hardware::power::stats::PowerStatsEnergyConsumer; constexpr char kBootHwSoCRev[] = "ro.boot.hw.soc.rev"; void addAoC(std::shared_ptr p) { + // AoC clock is synced from "libaoc.c" + static const uint64_t AOC_CLOCK = 4096; std::string prefix = "/sys/devices/platform/19000000.aoc/control/"; // Add AoC cores (a32, ff1, hf0, and hf1) @@ -57,7 +59,7 @@ void addAoC(std::shared_ptr p) { std::vector> coreStates = { {"DWN", "off"}, {"RET", "retention"}, {"WFI", "wfi"}}; p->addStateResidencyDataProvider(std::make_unique(coreIds, - coreStates)); + coreStates, AOC_CLOCK)); // Add AoC voltage stats std::vector> voltageIds = { @@ -68,7 +70,7 @@ void addAoC(std::shared_ptr p) { {"UUD", "ultra_underdrive"}, {"UD", "underdrive"}}; p->addStateResidencyDataProvider( - std::make_unique(voltageIds, voltageStates)); + std::make_unique(voltageIds, voltageStates, AOC_CLOCK)); // Add AoC monitor mode std::vector> monitorIds = { @@ -78,7 +80,7 @@ void addAoC(std::shared_ptr p) { {"MON", "mode"}, }; p->addStateResidencyDataProvider( - std::make_unique(monitorIds, monitorStates)); + std::make_unique(monitorIds, monitorStates, AOC_CLOCK)); // Add AoC restart count const GenericStateResidencyDataProvider::StateResidencyConfig restartCountConfig = {