1094332d3Sopenharmony_ci/* 2094332d3Sopenharmony_ci * Copyright (c) 2021 Huawei Device Co., Ltd. 3094332d3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4094332d3Sopenharmony_ci * you may not use this file except in compliance with the License. 5094332d3Sopenharmony_ci * You may obtain a copy of the License at 6094332d3Sopenharmony_ci * 7094332d3Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8094332d3Sopenharmony_ci * 9094332d3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10094332d3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11094332d3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12094332d3Sopenharmony_ci * See the License for the specific language governing permissions and 13094332d3Sopenharmony_ci * limitations under the License. 14094332d3Sopenharmony_ci */ 15094332d3Sopenharmony_ci 16094332d3Sopenharmony_ci#include "usb_utils.h" 17094332d3Sopenharmony_ci#include <cstdio> 18094332d3Sopenharmony_ci#include <cstdlib> 19094332d3Sopenharmony_ci#include <cstring> 20094332d3Sopenharmony_ci#include <fstream> 21094332d3Sopenharmony_ci#include <sys/time.h> 22094332d3Sopenharmony_ci 23094332d3Sopenharmony_ciusing namespace std; 24094332d3Sopenharmony_ci 25094332d3Sopenharmony_cibool HasLog(const string &target, double startTs, const string &file) 26094332d3Sopenharmony_ci{ 27094332d3Sopenharmony_ci bool ret = false; 28094332d3Sopenharmony_ci ifstream logFile(file); 29094332d3Sopenharmony_ci string::size_type pos; 30094332d3Sopenharmony_ci string lineStr; 31094332d3Sopenharmony_ci const string flagStr = "[XTSCHECK]"; 32094332d3Sopenharmony_ci const int32_t tsStartPos = 11; 33094332d3Sopenharmony_ci const int32_t tsLength = 17; 34094332d3Sopenharmony_ci while (getline(logFile, lineStr)) { 35094332d3Sopenharmony_ci double logTs; 36094332d3Sopenharmony_ci pos = lineStr.find(flagStr); 37094332d3Sopenharmony_ci if (pos == string::npos) { 38094332d3Sopenharmony_ci lineStr.clear(); 39094332d3Sopenharmony_ci continue; 40094332d3Sopenharmony_ci } 41094332d3Sopenharmony_ci logTs = stod(lineStr.substr(pos + tsStartPos, tsLength)); 42094332d3Sopenharmony_ci if ((logTs - startTs) >= 0) { 43094332d3Sopenharmony_ci if (lineStr.find(target) != string::npos) { 44094332d3Sopenharmony_ci ret = true; 45094332d3Sopenharmony_ci } 46094332d3Sopenharmony_ci } 47094332d3Sopenharmony_ci lineStr.clear(); 48094332d3Sopenharmony_ci } 49094332d3Sopenharmony_ci logFile.close(); 50094332d3Sopenharmony_ci return ret; 51094332d3Sopenharmony_ci} 52094332d3Sopenharmony_ci 53094332d3Sopenharmony_cidouble GetNowTs(void) 54094332d3Sopenharmony_ci{ 55094332d3Sopenharmony_ci const double transUsecNum = 1000000.0; 56094332d3Sopenharmony_ci timeval tv = {0}; 57094332d3Sopenharmony_ci gettimeofday(&tv, nullptr); 58094332d3Sopenharmony_ci return (tv.tv_sec + tv.tv_usec / transUsecNum); 59094332d3Sopenharmony_ci} 60094332d3Sopenharmony_ci 61094332d3Sopenharmony_cichar *ParseSysCmdResult(FILE &result, int32_t line, int32_t word) 62094332d3Sopenharmony_ci{ 63094332d3Sopenharmony_ci char s[1024]; 64094332d3Sopenharmony_ci char *pch = nullptr; 65094332d3Sopenharmony_ci int32_t lineCnt = 1; 66094332d3Sopenharmony_ci int32_t wordCnt = 1; 67094332d3Sopenharmony_ci while (1) { 68094332d3Sopenharmony_ci if (fgets(s, sizeof(s), &result) == nullptr) { 69094332d3Sopenharmony_ci break; 70094332d3Sopenharmony_ci } 71094332d3Sopenharmony_ci pch = strtok(s, " "); 72094332d3Sopenharmony_ci while (pch != nullptr) { 73094332d3Sopenharmony_ci if (lineCnt == line && wordCnt == word) { 74094332d3Sopenharmony_ci return pch; 75094332d3Sopenharmony_ci } 76094332d3Sopenharmony_ci pch = strtok(nullptr, " "); 77094332d3Sopenharmony_ci wordCnt++; 78094332d3Sopenharmony_ci } 79094332d3Sopenharmony_ci lineCnt++; 80094332d3Sopenharmony_ci wordCnt = 1; 81094332d3Sopenharmony_ci } 82094332d3Sopenharmony_ci return pch; 83094332d3Sopenharmony_ci} 84094332d3Sopenharmony_ci 85094332d3Sopenharmony_cistatic void ParseFile(char *pch, struct ParseProcInfo &pinfo) 86094332d3Sopenharmony_ci{ 87094332d3Sopenharmony_ci while (pch != nullptr) { 88094332d3Sopenharmony_ci if (strstr(pch, "VmRSS")) { 89094332d3Sopenharmony_ci pch = strtok(nullptr, " "); 90094332d3Sopenharmony_ci pinfo.ramCur = stod(pch); 91094332d3Sopenharmony_ci pinfo.ramCount += 1; 92094332d3Sopenharmony_ci pinfo.ramTotal += pinfo.ramCur; 93094332d3Sopenharmony_ci if (pinfo.ramCur > pinfo.ramPeak) { 94094332d3Sopenharmony_ci pinfo.ramPeak = pinfo.ramCur; 95094332d3Sopenharmony_ci } 96094332d3Sopenharmony_ci break; 97094332d3Sopenharmony_ci } 98094332d3Sopenharmony_ci if (strstr(pch, "Cpu")) { 99094332d3Sopenharmony_ci pch = strtok(nullptr, " "); 100094332d3Sopenharmony_ci pinfo.cpuCur = stod(pch); 101094332d3Sopenharmony_ci pinfo.cpuCount += 1; 102094332d3Sopenharmony_ci pinfo.cpuTotal += pinfo.cpuCur; 103094332d3Sopenharmony_ci if (pinfo.cpuCur > pinfo.cpuPeak) { 104094332d3Sopenharmony_ci pinfo.cpuPeak = pinfo.cpuCur; 105094332d3Sopenharmony_ci } 106094332d3Sopenharmony_ci break; 107094332d3Sopenharmony_ci } 108094332d3Sopenharmony_ci if (strstr(pch, "Threads")) { 109094332d3Sopenharmony_ci pch = strtok(nullptr, " "); 110094332d3Sopenharmony_ci pinfo.threadCur = stoi(pch); 111094332d3Sopenharmony_ci if (pinfo.threadCur > pinfo.threadPeak) { 112094332d3Sopenharmony_ci pinfo.threadPeak = pinfo.threadCur; 113094332d3Sopenharmony_ci } 114094332d3Sopenharmony_ci break; 115094332d3Sopenharmony_ci } 116094332d3Sopenharmony_ci pch = strtok(nullptr, " "); 117094332d3Sopenharmony_ci } 118094332d3Sopenharmony_ci} 119094332d3Sopenharmony_ci 120094332d3Sopenharmony_civoid CalcProcInfoFromFile(struct ProcInfo &info, const string &file) 121094332d3Sopenharmony_ci{ 122094332d3Sopenharmony_ci char s[100]; 123094332d3Sopenharmony_ci struct ParseProcInfo pinfo = {0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0, 0, 0, 0}; 124094332d3Sopenharmony_ci 125094332d3Sopenharmony_ci FILE *fp = fopen(file.c_str(), "r"); 126094332d3Sopenharmony_ci if (!fp) { 127094332d3Sopenharmony_ci printf("%s:%d file open failed.", __func__, __LINE__); 128094332d3Sopenharmony_ci return; 129094332d3Sopenharmony_ci } 130094332d3Sopenharmony_ci while (1) { 131094332d3Sopenharmony_ci if (fgets(s, sizeof(s), fp) == nullptr) { 132094332d3Sopenharmony_ci break; 133094332d3Sopenharmony_ci } 134094332d3Sopenharmony_ci ParseFile(strtok(s, " \t"), pinfo); 135094332d3Sopenharmony_ci } 136094332d3Sopenharmony_ci 137094332d3Sopenharmony_ci if (pinfo.ramCount == 0 || pinfo.cpuCount == 0) { 138094332d3Sopenharmony_ci (void)fclose(fp); 139094332d3Sopenharmony_ci return; 140094332d3Sopenharmony_ci } 141094332d3Sopenharmony_ci info.ramPeak = pinfo.ramPeak; 142094332d3Sopenharmony_ci info.ramAvg = pinfo.ramTotal / pinfo.ramCount; 143094332d3Sopenharmony_ci info.cpuPeak = pinfo.cpuPeak; 144094332d3Sopenharmony_ci info.cpuAvg = pinfo.cpuTotal / pinfo.cpuCount; 145094332d3Sopenharmony_ci info.threadPeak = pinfo.threadPeak; 146094332d3Sopenharmony_ci 147094332d3Sopenharmony_ci (void)fclose(fp); 148094332d3Sopenharmony_ci return; 149094332d3Sopenharmony_ci} 150094332d3Sopenharmony_ci 151094332d3Sopenharmony_cidouble GetTsFromLog(const string &target, double startTs, const string &file) 152094332d3Sopenharmony_ci{ 153094332d3Sopenharmony_ci double logTs; 154094332d3Sopenharmony_ci ifstream logFile(file); 155094332d3Sopenharmony_ci string lineStr; 156094332d3Sopenharmony_ci const int32_t tsStartPos = 11; 157094332d3Sopenharmony_ci const int32_t tsLength = 17; 158094332d3Sopenharmony_ci while (getline(logFile, lineStr)) { 159094332d3Sopenharmony_ci if (lineStr.find(target) != string::npos) { 160094332d3Sopenharmony_ci logTs = stod(lineStr.substr(tsStartPos, tsLength)); 161094332d3Sopenharmony_ci if ((logTs - startTs) >= 0) { 162094332d3Sopenharmony_ci return logTs; 163094332d3Sopenharmony_ci } 164094332d3Sopenharmony_ci } 165094332d3Sopenharmony_ci lineStr.clear(); 166094332d3Sopenharmony_ci } 167094332d3Sopenharmony_ci logFile.close(); 168094332d3Sopenharmony_ci return 0; 169094332d3Sopenharmony_ci} 170