xref: /aosp_15_r20/system/logging/logd/LogKlog.h (revision 598139dc91b21518d67c408eaea2644226490971)
1*598139dcSAndroid Build Coastguard Worker /*
2*598139dcSAndroid Build Coastguard Worker  * Copyright (C) 2014 The Android Open Source Project
3*598139dcSAndroid Build Coastguard Worker  *
4*598139dcSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*598139dcSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*598139dcSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*598139dcSAndroid Build Coastguard Worker  *
8*598139dcSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*598139dcSAndroid Build Coastguard Worker  *
10*598139dcSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*598139dcSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*598139dcSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*598139dcSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*598139dcSAndroid Build Coastguard Worker  * limitations under the License.
15*598139dcSAndroid Build Coastguard Worker  */
16*598139dcSAndroid Build Coastguard Worker 
17*598139dcSAndroid Build Coastguard Worker #pragma once
18*598139dcSAndroid Build Coastguard Worker 
19*598139dcSAndroid Build Coastguard Worker #include <private/android_logger.h>
20*598139dcSAndroid Build Coastguard Worker #include <sysutils/SocketListener.h>
21*598139dcSAndroid Build Coastguard Worker 
22*598139dcSAndroid Build Coastguard Worker #include "LogBuffer.h"
23*598139dcSAndroid Build Coastguard Worker #include "LogStatistics.h"
24*598139dcSAndroid Build Coastguard Worker 
25*598139dcSAndroid Build Coastguard Worker class LogKlog : public SocketListener {
26*598139dcSAndroid Build Coastguard Worker     LogBuffer* logbuf;
27*598139dcSAndroid Build Coastguard Worker     const log_time signature;
28*598139dcSAndroid Build Coastguard Worker     // Set once thread is started, separates KLOG_ACTION_READ_ALL
29*598139dcSAndroid Build Coastguard Worker     // and KLOG_ACTION_READ phases.
30*598139dcSAndroid Build Coastguard Worker     bool initialized;
31*598139dcSAndroid Build Coastguard Worker     // set if we are also running auditd, to filter out audit reports from
32*598139dcSAndroid Build Coastguard Worker     // our copy of the kernel log
33*598139dcSAndroid Build Coastguard Worker     bool auditd;
34*598139dcSAndroid Build Coastguard Worker 
35*598139dcSAndroid Build Coastguard Worker     static log_time correction;
36*598139dcSAndroid Build Coastguard Worker 
37*598139dcSAndroid Build Coastguard Worker   public:
38*598139dcSAndroid Build Coastguard Worker     LogKlog(LogBuffer* buf, int fdWrite, int fdRead, bool auditd, LogStatistics* stats);
39*598139dcSAndroid Build Coastguard Worker     int log(const char* buf, ssize_t len);
40*598139dcSAndroid Build Coastguard Worker 
convertMonotonicToReal(log_time & real)41*598139dcSAndroid Build Coastguard Worker     static void convertMonotonicToReal(log_time& real) { real += correction; }
42*598139dcSAndroid Build Coastguard Worker 
43*598139dcSAndroid Build Coastguard Worker   protected:
44*598139dcSAndroid Build Coastguard Worker     log_time sniffTime(const char*& buf, ssize_t len, bool reverse);
45*598139dcSAndroid Build Coastguard Worker     pid_t sniffPid(const char*& buf, ssize_t len);
46*598139dcSAndroid Build Coastguard Worker     void calculateCorrection(const log_time& monotonic, const char* real_string, ssize_t len);
47*598139dcSAndroid Build Coastguard Worker     virtual bool onDataAvailable(SocketClient* cli);
48*598139dcSAndroid Build Coastguard Worker 
49*598139dcSAndroid Build Coastguard Worker   private:
50*598139dcSAndroid Build Coastguard Worker     LogStatistics* stats_;
51*598139dcSAndroid Build Coastguard Worker };
52