1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- /* Copyright (c) 2019 The Linux Foundation. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are
- * met:
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * Redistributions in binary form must reproduce the above
- * copyright notice, this list of conditions and the following
- * disclaimer in the documentation and/or other materials provided
- * with the distribution.
- * * Neither the name of The Linux Foundation, nor the names of its
- * contributors may be used to endorse or promote products derived
- * from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
- * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
- * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
- * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
- * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
- * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
- * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
- * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- */
- #ifndef LOG_BUFFER_H
- #define LOG_BUFFER_H
- #include "SkipList.h"
- #include "log_util.h"
- #include <loc_cfg.h>
- #include <loc_pla.h>
- #include <string>
- #include <sstream>
- #include <ostream>
- #include <fstream>
- #include <time.h>
- #include <mutex>
- #include <signal.h>
- #include <thread>
- #include <functional>
- //default error level time depth threshold,
- #define TIME_DEPTH_THRESHOLD_MINIMAL_IN_SEC 60
- //default maximum log buffer size
- #define MAXIMUM_NUM_IN_LIST 50
- //file path of dumped log buffer
- #define LOG_BUFFER_FILE_PATH "/data/vendor/location/"
- namespace loc_util {
- class ConfigsInLevel{
- public:
- uint32_t mTimeDepthThres;
- uint32_t mMaxNumThres;
- int mCurrentSize;
- ConfigsInLevel(uint32_t time, int num, int size):
- mTimeDepthThres(time), mMaxNumThres(num), mCurrentSize(size) {}
- };
- class LogBuffer {
- private:
- static LogBuffer* mInstance;
- static struct sigaction mOriSigAction[NSIG];
- static struct sigaction mNewSigAction;
- static mutex sLock;
- SkipList<pair<uint64_t, string>> mLogList;
- vector<ConfigsInLevel> mConfigVec;
- mutex mLock;
- const vector<string> mLevelMap {"E", "W", "I", "D", "V"};
- public:
- static LogBuffer* getInstance();
- void append(string& data, int level, uint64_t timestamp);
- void dump(std::function<void(stringstream&)> log, int level = -1);
- void dumpToAdbLogcat();
- void dumpToLogFile(string filePath);
- void flush();
- private:
- LogBuffer();
- void registerSignalHandler();
- static void signalHandler(const int code, siginfo_t *const si, void *const sc);
- };
- }
- #endif
|