vold: fix write kbytes handling
Since Android platform codespace doesn't support exception handling, we use strtoll() instead of stoll for direct error handling. Bug: 274369737 Test: check smart idle maintenace service log Change-Id: I57c709b1e329228790e0a883edb64dc023135a24
This commit is contained in:
parent
c1572fe8cf
commit
dd08c52eb8
1 changed files with 6 additions and 1 deletions
|
@ -630,7 +630,12 @@ static int32_t getLifeTimeWrite() {
|
|||
return -1;
|
||||
}
|
||||
|
||||
long long writeBytes = std::stoll(writeKbytesStr);
|
||||
unsigned long long writeBytes = std::strtoull(writeKbytesStr.c_str(), NULL, 0);
|
||||
/* Careful: values > LLONG_MAX can appear in the file due to a kernel bug. */
|
||||
if (writeBytes / KBYTES_IN_SEGMENT > INT32_MAX) {
|
||||
LOG(WARNING) << "Bad lifetime_write_kbytes: " << writeKbytesStr;
|
||||
return -1;
|
||||
}
|
||||
return writeBytes / KBYTES_IN_SEGMENT;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue