Files
device_google_wahoo/health/LearnedCapacityBackupRestore.cpp
Thierry Strudel ed713cf656 health: fix learned capacity backup/restore
The code was only allowing the Learned Capacity to decrease while
QCOM FG learned capacity may actually go up for some reasons.
Ensure we use the FG learned capacity on update and always restore
the saved one on boot.

Bug: 109734601
Change-Id: I21b559c27a5298e8eea39ec502e4f1d6f7a4b053
Signed-off-by: Thierry Strudel <tstrudel@google.com>
2018-06-21 08:12:02 +00:00

108 lines
3.1 KiB
C++

/*
* Copyright (C) 2018 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.
*/
#include "LearnedCapacityBackupRestore.h"
namespace device {
namespace google {
namespace wahoo {
namespace health {
static constexpr char kChgFullFile[] = "sys/class/power_supply/bms/charge_full";
static constexpr char kSysCFPersistFile[] = "/persist/battery/qcom_charge_full";
static constexpr int kBuffSize = 256;
LearnedCapacityBackupRestore::LearnedCapacityBackupRestore() : sw_cap_(0), hw_cap_(0) {}
void LearnedCapacityBackupRestore::Restore() {
ReadFromStorage();
ReadFromSRAM();
if (sw_cap_ == 0) {
// First backup
sw_cap_ = hw_cap_;
SaveToStorage();
} else {
// Always restore backup value
SaveToSRAM();
}
}
void LearnedCapacityBackupRestore::Backup() {
ReadFromSRAM();
if (sw_cap_ != hw_cap_) {
// Always backup the new FG computed learned capacity
sw_cap_ = hw_cap_;
SaveToStorage();
}
}
void LearnedCapacityBackupRestore::ReadFromStorage() {
std::string buffer;
if (!android::base::ReadFileToString(std::string(kSysCFPersistFile), &buffer)) {
LOG(ERROR) << "Cannot read the storage file";
return;
}
if (sscanf(buffer.c_str(), "%d", &sw_cap_) < 1)
LOG(ERROR) << "data format is wrong in the storage file: " << buffer;
else
LOG(INFO) << "Storage data: " << buffer;
}
void LearnedCapacityBackupRestore::SaveToStorage() {
char strData[kBuffSize];
snprintf(strData, kBuffSize, "%d", sw_cap_);
LOG(INFO) << "Save to Storage: " << strData;
if (!android::base::WriteStringToFile(strData, std::string(kSysCFPersistFile)))
LOG(ERROR) << "Write file error: " << strerror(errno);
}
void LearnedCapacityBackupRestore::ReadFromSRAM() {
std::string buffer;
if (!android::base::ReadFileToString(std::string(kChgFullFile), &buffer)) {
LOG(ERROR) << "Read cycle counter error: " << strerror(errno);
return;
}
buffer = android::base::Trim(buffer);
if (sscanf(buffer.c_str(), "%d", &hw_cap_) < 1)
LOG(ERROR) << "Failed to parse SRAM bins: " << buffer;
else
LOG(INFO) << "SRAM data: " << buffer;
}
void LearnedCapacityBackupRestore::SaveToSRAM() {
char strData[kBuffSize];
snprintf(strData, kBuffSize, "%d", hw_cap_);
LOG(INFO) << "Save to SRAM: " << strData;
if (!android::base::WriteStringToFile(strData, std::string(kChgFullFile)))
LOG(ERROR) << "Write data error: " << strerror(errno);
}
} // namespace health
} // namespace wahoo
} // namespace google
} // namespace device