From 0c8360236a46b2178c011bd602c6952dd1482efd Mon Sep 17 00:00:00 2001 From: Tom Cherry Date: Wed, 5 Aug 2020 12:14:45 -0700 Subject: Query log size properties only within logd liblog exposed __android_logger_get_buffer_size() which queries log size properties, but that should not be a generic library function. Logd should be the only process that queries these properties and other processes should query the actual used log sizes from logd via the android_logger_get_log_*_size() functions. Also, always use 1MB for log buffer tests, instead of just on host and various other clean up related to improper types. Test: log buffers are correctly sized Change-Id: I9b7c86bf58e569618737afe9097cf1c4d4e61d95 --- logd/LogSize.cpp | 68 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 logd/LogSize.cpp (limited to 'logd/LogSize.cpp') diff --git a/logd/LogSize.cpp b/logd/LogSize.cpp new file mode 100644 index 000000000..fe829baac --- /dev/null +++ b/logd/LogSize.cpp @@ -0,0 +1,68 @@ +/* + * Copyright 2020 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 + +#include +#include +#include + +#include +#include + +bool IsValidBufferSize(size_t value) { + return kLogBufferMinSize <= value && value <= kLogBufferMaxSize; +} + +static std::optional GetBufferSizeProperty(const std::string& key) { + std::string value = android::base::GetProperty(key, ""); + if (value.empty()) { + return {}; + } + + uint32_t size; + if (!android::base::ParseByteCount(value, &size)) { + return {}; + } + + if (!IsValidBufferSize(size)) { + return {}; + } + + return size; +} + +size_t GetBufferSizeFromProperties(log_id_t log_id) { + std::string buffer_name = android_log_id_to_name(log_id); + std::array properties = { + "persist.logd.size." + buffer_name, + "ro.logd.size." + buffer_name, + "persist.logd.size", + "ro.logd.size", + }; + + for (const auto& property : properties) { + if (auto size = GetBufferSizeProperty(property)) { + return *size; + } + } + + if (android::base::GetBoolProperty("ro.config.low_ram", false)) { + return kLogBufferMinSize; + } + + return kDefaultLogBufferSize; +} -- cgit v1.2.3