blob: 6274051ec43bb68d105b76f8e8631fc32ca55b3d [file] [log] [blame]
Mark Salyzyn12bac902014-02-26 09:50:16 -08001/*
Tom Cherry0281b202020-05-12 13:16:41 -07002 * Copyright (C) 2020 The Android Open Source Project
Mark Salyzyn12bac902014-02-26 09:50:16 -08003 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Tom Cherry04ad4582020-05-01 16:13:18 -070017#pragma once
Mark Salyzyn12bac902014-02-26 09:50:16 -080018
19#include <sys/types.h>
20
Tom Cherry0281b202020-05-12 13:16:41 -070021#include <functional>
Mark Salyzyn9a400aa2015-08-19 13:41:51 -070022
Tom Cherry0281b202020-05-12 13:16:41 -070023#include <log/log.h>
Mark Salyzyn224b86f2016-09-28 15:54:45 -070024#include <sysutils/SocketClient.h>
Mark Salyzyn276d5352014-06-12 11:16:16 -070025
Mark Salyzyn12bac902014-02-26 09:50:16 -080026#include "LogBufferElement.h"
Tom Cherry5ecfbf02020-05-11 16:29:29 -070027
Tom Cherryadf2e442020-05-14 19:25:05 -070028class LogWriter;
29
Tom Cherry5ecfbf02020-05-11 16:29:29 -070030enum class FlushToResult {
31 kSkip,
32 kStop,
33 kWrite,
34};
35
Tom Cherryc49573f2019-06-28 13:37:10 -070036class LogBuffer {
Tom Cherry5ecfbf02020-05-11 16:29:29 -070037 public:
Tom Cherry0281b202020-05-12 13:16:41 -070038 virtual ~LogBuffer() {}
Mark Salyzyn12bac902014-02-26 09:50:16 -080039
Tom Cherry0281b202020-05-12 13:16:41 -070040 virtual void Init() = 0;
41
42 virtual int Log(log_id_t log_id, log_time realtime, uid_t uid, pid_t pid, pid_t tid,
43 const char* msg, uint16_t len) = 0;
Mark Salyzynbec7b2d2017-03-31 10:48:39 -070044 // lastTid is an optional context to help detect if the last previous
45 // valid message was from the same source so we can differentiate chatty
46 // filter types (identical or expired)
Tom Cherryadf2e442020-05-14 19:25:05 -070047 static const uint64_t FLUSH_ERROR = 0;
Tom Cherry0281b202020-05-12 13:16:41 -070048 virtual uint64_t FlushTo(
Tom Cherryadf2e442020-05-14 19:25:05 -070049 LogWriter* writer, uint64_t start,
Tom Cherry0281b202020-05-12 13:16:41 -070050 pid_t* last_tid, // nullable
Tom Cherry0281b202020-05-12 13:16:41 -070051 const std::function<FlushToResult(const LogBufferElement* element)>& filter) = 0;
Mark Salyzyn12bac902014-02-26 09:50:16 -080052
Tom Cherry0281b202020-05-12 13:16:41 -070053 virtual bool Clear(log_id_t id, uid_t uid) = 0;
54 virtual unsigned long GetSize(log_id_t id) = 0;
55 virtual int SetSize(log_id_t id, unsigned long size) = 0;
56};