106f6ba60Sopenharmony_ci/* 206f6ba60Sopenharmony_ci * Copyright (c) Huawei Technologies Co., Ltd. 2022. All rights reserved. 306f6ba60Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 406f6ba60Sopenharmony_ci * you may not use this file except in compliance with the License. 506f6ba60Sopenharmony_ci * You may obtain a copy of the License at 606f6ba60Sopenharmony_ci * 706f6ba60Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 806f6ba60Sopenharmony_ci * 906f6ba60Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 1006f6ba60Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 1106f6ba60Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1206f6ba60Sopenharmony_ci * See the License for the specific language governing permissions and 1306f6ba60Sopenharmony_ci * limitations under the License. 1406f6ba60Sopenharmony_ci */ 1506f6ba60Sopenharmony_ci 1606f6ba60Sopenharmony_ci#ifndef BPF_LOG_READER_H 1706f6ba60Sopenharmony_ci#define BPF_LOG_READER_H 1806f6ba60Sopenharmony_ci 1906f6ba60Sopenharmony_ci#include <string> 2006f6ba60Sopenharmony_ci#include <thread> 2106f6ba60Sopenharmony_ci#include <memory> 2206f6ba60Sopenharmony_ci 2306f6ba60Sopenharmony_ci#include "bpf_log.h" 2406f6ba60Sopenharmony_ci 2506f6ba60Sopenharmony_ciclass BPFLogReader { 2606f6ba60Sopenharmony_cipublic: 2706f6ba60Sopenharmony_ci ~BPFLogReader(); 2806f6ba60Sopenharmony_ci static std::unique_ptr<BPFLogReader> MakeUnique(const std::string& logFile = "/data/local/tmp/bpf_log.txt"); 2906f6ba60Sopenharmony_ci inline int Start() 3006f6ba60Sopenharmony_ci { 3106f6ba60Sopenharmony_ci#if defined(BPF_LOGGER_DEBUG) || defined(BPF_LOGGER_INFO) || defined(BPF_LOGGER_WARN) || \ 3206f6ba60Sopenharmony_ci defined(BPF_LOGGER_ERROR) || defined(BPF_LOGGER_FATAL) 3306f6ba60Sopenharmony_ci worker_ = std::thread([this] { this->MoveBPFLog(); }); 3406f6ba60Sopenharmony_ci#endif 3506f6ba60Sopenharmony_ci return 0; 3606f6ba60Sopenharmony_ci } 3706f6ba60Sopenharmony_ci inline int Stop() 3806f6ba60Sopenharmony_ci { 3906f6ba60Sopenharmony_ci stop_ = true; 4006f6ba60Sopenharmony_ci return 0; 4106f6ba60Sopenharmony_ci } 4206f6ba60Sopenharmony_ci 4306f6ba60Sopenharmony_ciprivate: 4406f6ba60Sopenharmony_ci BPFLogReader() = default; 4506f6ba60Sopenharmony_ci int OpenTracePipe(); 4606f6ba60Sopenharmony_ci int EnableTracePipe() const; 4706f6ba60Sopenharmony_ci std::string GetLogFileName() const; 4806f6ba60Sopenharmony_ci int OpenLogFile(const std::string& logFile); 4906f6ba60Sopenharmony_ci int MoveBPFLog(); 5006f6ba60Sopenharmony_ci 5106f6ba60Sopenharmony_ci const std::string confPath_ {"/sys/kernel/debug/tracing/tracing_on"}; 5206f6ba60Sopenharmony_ci const std::string pipePath_ {"/sys/kernel/debug/tracing/trace_pipe"}; 5306f6ba60Sopenharmony_ci 5406f6ba60Sopenharmony_ci bool stop_ {false}; 5506f6ba60Sopenharmony_ci int ifd_ {-1}; 5606f6ba60Sopenharmony_ci int ofd_ {-1}; 5706f6ba60Sopenharmony_ci std::thread worker_; 5806f6ba60Sopenharmony_ci}; 5906f6ba60Sopenharmony_ci#endif // BPF_LOG_READER_H