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