xref: /aosp_15_r20/system/logging/logd/SerializedLogEntry.h (revision 598139dc91b21518d67c408eaea2644226490971)
1*598139dcSAndroid Build Coastguard Worker /*
2*598139dcSAndroid Build Coastguard Worker  * Copyright (C) 2020 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 <stdint.h>
20*598139dcSAndroid Build Coastguard Worker #include <stdlib.h>
21*598139dcSAndroid Build Coastguard Worker #include <sys/types.h>
22*598139dcSAndroid Build Coastguard Worker 
23*598139dcSAndroid Build Coastguard Worker #include <log/log.h>
24*598139dcSAndroid Build Coastguard Worker #include <log/log_read.h>
25*598139dcSAndroid Build Coastguard Worker 
26*598139dcSAndroid Build Coastguard Worker #include "LogStatistics.h"
27*598139dcSAndroid Build Coastguard Worker #include "LogWriter.h"
28*598139dcSAndroid Build Coastguard Worker 
29*598139dcSAndroid Build Coastguard Worker // These structs are packed into a single chunk of memory for each log type within a
30*598139dcSAndroid Build Coastguard Worker // SerializedLogChunk object.  Their message is contained immediately at the end of the struct.  The
31*598139dcSAndroid Build Coastguard Worker // address of the next log in the buffer is *this + sizeof(SerializedLogEntry) + msg_len_.  If that
32*598139dcSAndroid Build Coastguard Worker // value would overflow the chunk of memory associated with the SerializedLogChunk object, then a
33*598139dcSAndroid Build Coastguard Worker // new SerializedLogChunk must be allocated to contain the next SerializedLogEntry.
34*598139dcSAndroid Build Coastguard Worker class __attribute__((packed)) SerializedLogEntry {
35*598139dcSAndroid Build Coastguard Worker   public:
SerializedLogEntry(uid_t uid,pid_t pid,pid_t tid,uint64_t sequence,log_time realtime,uint16_t len)36*598139dcSAndroid Build Coastguard Worker     SerializedLogEntry(uid_t uid, pid_t pid, pid_t tid, uint64_t sequence, log_time realtime,
37*598139dcSAndroid Build Coastguard Worker                        uint16_t len)
38*598139dcSAndroid Build Coastguard Worker         : uid_(uid),
39*598139dcSAndroid Build Coastguard Worker           pid_(pid),
40*598139dcSAndroid Build Coastguard Worker           tid_(tid),
41*598139dcSAndroid Build Coastguard Worker           sequence_(sequence),
42*598139dcSAndroid Build Coastguard Worker           realtime_(realtime),
43*598139dcSAndroid Build Coastguard Worker           msg_len_(len) {}
44*598139dcSAndroid Build Coastguard Worker     SerializedLogEntry(const SerializedLogEntry& elem) = delete;
45*598139dcSAndroid Build Coastguard Worker     SerializedLogEntry& operator=(const SerializedLogEntry& elem) = delete;
~SerializedLogEntry()46*598139dcSAndroid Build Coastguard Worker     ~SerializedLogEntry() {
47*598139dcSAndroid Build Coastguard Worker         // Never place anything in this destructor.  This class is in place constructed and never
48*598139dcSAndroid Build Coastguard Worker         // destructed.
49*598139dcSAndroid Build Coastguard Worker     }
50*598139dcSAndroid Build Coastguard Worker 
ToLogStatisticsElement(log_id_t log_id)51*598139dcSAndroid Build Coastguard Worker     LogStatisticsElement ToLogStatisticsElement(log_id_t log_id) const {
52*598139dcSAndroid Build Coastguard Worker         return LogStatisticsElement{
53*598139dcSAndroid Build Coastguard Worker                 .uid = uid(),
54*598139dcSAndroid Build Coastguard Worker                 .pid = pid(),
55*598139dcSAndroid Build Coastguard Worker                 .tid = tid(),
56*598139dcSAndroid Build Coastguard Worker                 .tag = IsBinary(log_id) ? MsgToTag(msg(), msg_len()) : 0,
57*598139dcSAndroid Build Coastguard Worker                 .realtime = realtime(),
58*598139dcSAndroid Build Coastguard Worker                 .msg = msg(),
59*598139dcSAndroid Build Coastguard Worker                 .msg_len = msg_len(),
60*598139dcSAndroid Build Coastguard Worker                 .log_id = log_id,
61*598139dcSAndroid Build Coastguard Worker                 .total_len = total_len(),
62*598139dcSAndroid Build Coastguard Worker         };
63*598139dcSAndroid Build Coastguard Worker     }
64*598139dcSAndroid Build Coastguard Worker 
Flush(LogWriter * writer,log_id_t log_id)65*598139dcSAndroid Build Coastguard Worker     bool Flush(LogWriter* writer, log_id_t log_id) const {
66*598139dcSAndroid Build Coastguard Worker         struct logger_entry entry = {};
67*598139dcSAndroid Build Coastguard Worker 
68*598139dcSAndroid Build Coastguard Worker         entry.hdr_size = sizeof(struct logger_entry);
69*598139dcSAndroid Build Coastguard Worker         entry.lid = log_id;
70*598139dcSAndroid Build Coastguard Worker         entry.pid = pid();
71*598139dcSAndroid Build Coastguard Worker         entry.tid = tid();
72*598139dcSAndroid Build Coastguard Worker         entry.uid = uid();
73*598139dcSAndroid Build Coastguard Worker         entry.sec = realtime().tv_sec;
74*598139dcSAndroid Build Coastguard Worker         entry.nsec = realtime().tv_nsec;
75*598139dcSAndroid Build Coastguard Worker         entry.len = msg_len();
76*598139dcSAndroid Build Coastguard Worker 
77*598139dcSAndroid Build Coastguard Worker         return writer->Write(entry, msg());
78*598139dcSAndroid Build Coastguard Worker     }
79*598139dcSAndroid Build Coastguard Worker 
uid()80*598139dcSAndroid Build Coastguard Worker     uid_t uid() const { return uid_; }
pid()81*598139dcSAndroid Build Coastguard Worker     pid_t pid() const { return pid_; }
tid()82*598139dcSAndroid Build Coastguard Worker     pid_t tid() const { return tid_; }
msg_len()83*598139dcSAndroid Build Coastguard Worker     uint16_t msg_len() const { return msg_len_; }
sequence()84*598139dcSAndroid Build Coastguard Worker     uint64_t sequence() const { return sequence_; }
realtime()85*598139dcSAndroid Build Coastguard Worker     log_time realtime() const { return realtime_; }
86*598139dcSAndroid Build Coastguard Worker 
msg()87*598139dcSAndroid Build Coastguard Worker     char* msg() { return reinterpret_cast<char*>(this) + sizeof(*this); }
msg()88*598139dcSAndroid Build Coastguard Worker     const char* msg() const { return reinterpret_cast<const char*>(this) + sizeof(*this); }
total_len()89*598139dcSAndroid Build Coastguard Worker     uint16_t total_len() const { return sizeof(*this) + msg_len_; }
90*598139dcSAndroid Build Coastguard Worker 
91*598139dcSAndroid Build Coastguard Worker   private:
92*598139dcSAndroid Build Coastguard Worker     const uint32_t uid_;
93*598139dcSAndroid Build Coastguard Worker     const uint32_t pid_;
94*598139dcSAndroid Build Coastguard Worker     const uint32_t tid_;
95*598139dcSAndroid Build Coastguard Worker     const uint64_t sequence_;
96*598139dcSAndroid Build Coastguard Worker     const log_time realtime_;
97*598139dcSAndroid Build Coastguard Worker     const uint16_t msg_len_;
98*598139dcSAndroid Build Coastguard Worker };
99