/* * Copyright 2019 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. */ #define LOG_TAG "bt_shim_storage" #include "main/shim/dumpsys.h" #include #include #include "main/shim/entry.h" #include "main/shim/shim.h" #include "main/shim/stack.h" #include "shim/dumpsys.h" namespace { constexpr char kModuleName[] = "shim::legacy::dumpsys"; static std::unordered_map dumpsys_functions_; } // namespace void bluetooth::shim::RegisterDumpsysFunction(const void* token, DumpsysFunction func) { log::assert_that(dumpsys_functions_.find(token) == dumpsys_functions_.end(), "assert failed: dumpsys_functions_.find(token) == dumpsys_functions_.end()"); dumpsys_functions_.insert({token, func}); } void bluetooth::shim::UnregisterDumpsysFunction(const void* token) { log::assert_that(dumpsys_functions_.find(token) != dumpsys_functions_.end(), "assert failed: dumpsys_functions_.find(token) != dumpsys_functions_.end()"); dumpsys_functions_.erase(token); } void bluetooth::shim::Dump(int fd, const char** args) { if (dumpsys_functions_.empty()) { dprintf(fd, "%s No registered dumpsys shim legacy targets\n", kModuleName); } else { dprintf(fd, "%s Dumping shim legacy targets:%zd\n", kModuleName, dumpsys_functions_.size()); for (auto& dumpsys : dumpsys_functions_) { dumpsys.second(fd); } } std::promise promise; std::future future = promise.get_future(); if (bluetooth::shim::Stack::GetInstance()->CallOnModule( [&promise, fd, args](shim::Dumpsys* mod) { mod->Dump(fd, args, std::move(promise)); })) { log::assert_that(future.wait_for(std::chrono::seconds(1)) == std::future_status::ready, "Timed out waiting for dumpsys to complete"); } else { dprintf(fd, "%s NOTE: gd dumpsys module not loaded or started\n", kModuleName); } }