1020a203aSopenharmony_ci/* 2020a203aSopenharmony_ci * Copyright (C) 2021 Huawei Device Co., Ltd. 3020a203aSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4020a203aSopenharmony_ci * you may not use this file except in compliance with the License. 5020a203aSopenharmony_ci * You may obtain a copy of the License at 6020a203aSopenharmony_ci * 7020a203aSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8020a203aSopenharmony_ci * 9020a203aSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10020a203aSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11020a203aSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12020a203aSopenharmony_ci * See the License for the specific language governing permissions and 13020a203aSopenharmony_ci * limitations under the License. 14020a203aSopenharmony_ci */ 15020a203aSopenharmony_ci#include "binder_catcher.h" 16020a203aSopenharmony_ci 17020a203aSopenharmony_ci#include <fstream> 18020a203aSopenharmony_ci 19020a203aSopenharmony_ci#include "securec.h" 20020a203aSopenharmony_ci 21020a203aSopenharmony_ci#include "common_utils.h" 22020a203aSopenharmony_ci#include "defines.h" 23020a203aSopenharmony_cinamespace OHOS { 24020a203aSopenharmony_cinamespace HiviewDFX { 25020a203aSopenharmony_ciusing namespace OHOS::HiviewDFX::CommonUtils; 26020a203aSopenharmony_ciBinderCatcher::BinderCatcher() : EventLogCatcher() 27020a203aSopenharmony_ci{ 28020a203aSopenharmony_ci name_ = "BinderCatcher"; 29020a203aSopenharmony_ci} 30020a203aSopenharmony_ci 31020a203aSopenharmony_cibool BinderCatcher::Initialize(const std::string& strParam1, int intParam1, int intParam2) 32020a203aSopenharmony_ci{ 33020a203aSopenharmony_ci // this catcher do not need parameters, just return true 34020a203aSopenharmony_ci char buf[BUF_SIZE_512] = {0}; 35020a203aSopenharmony_ci int ret = snprintf_s(buf, BUF_SIZE_512, BUF_SIZE_512 - 1, 36020a203aSopenharmony_ci "BinderCatcher --\n"); 37020a203aSopenharmony_ci if (ret > 0) { 38020a203aSopenharmony_ci description_ = buf; 39020a203aSopenharmony_ci } 40020a203aSopenharmony_ci return true; 41020a203aSopenharmony_ci}; 42020a203aSopenharmony_ci 43020a203aSopenharmony_ciint BinderCatcher::Catch(int fd, int jsonFd) 44020a203aSopenharmony_ci{ 45020a203aSopenharmony_ci std::string line; 46020a203aSopenharmony_ci int originSize = GetFdSize(fd); 47020a203aSopenharmony_ci std::ifstream fin; 48020a203aSopenharmony_ci fin.open("/proc/transaction_proc"); 49020a203aSopenharmony_ci if (!fin.is_open()) { 50020a203aSopenharmony_ci std::string content = "open binder file failed :/proc/transaction_proc\r\n"; 51020a203aSopenharmony_ci FileUtil::SaveStringToFd(fd, content); 52020a203aSopenharmony_ci goto end; 53020a203aSopenharmony_ci } 54020a203aSopenharmony_ci while (getline(fin, line)) { 55020a203aSopenharmony_ci FileUtil::SaveStringToFd(fd, line + "\n"); 56020a203aSopenharmony_ci } 57020a203aSopenharmony_ci fin.close(); 58020a203aSopenharmony_ci 59020a203aSopenharmony_ci end: 60020a203aSopenharmony_ci logSize_ = GetFdSize(fd) - originSize; 61020a203aSopenharmony_ci if (logSize_ <= 0) { 62020a203aSopenharmony_ci FileUtil::SaveStringToFd(fd, "binder content is empty!"); 63020a203aSopenharmony_ci } 64020a203aSopenharmony_ci return logSize_; 65020a203aSopenharmony_ci}; 66020a203aSopenharmony_ci} // namespace HiviewDFX 67020a203aSopenharmony_ci} // namespace OHOS 68