Tom Cherry | 1a796bc | 2020-05-13 09:28:37 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2020 The Android Open Source Project |
| 3 | * |
| 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 | |
| 17 | #pragma once |
| 18 | |
| 19 | #include <sys/types.h> |
| 20 | |
Tom Cherry | 1a796bc | 2020-05-13 09:28:37 -0700 | [diff] [blame] | 21 | #include "LogWriter.h" |
Tom Cherry | b6cb992 | 2020-06-24 13:51:04 -0700 | [diff] [blame] | 22 | #include "SerializedData.h" |
Tom Cherry | 1a796bc | 2020-05-13 09:28:37 -0700 | [diff] [blame] | 23 | #include "SerializedLogEntry.h" |
| 24 | |
| 25 | class SerializedLogChunk { |
| 26 | public: |
Tom Cherry | 9b4246d | 2020-06-17 11:40:55 -0700 | [diff] [blame] | 27 | explicit SerializedLogChunk(size_t size) : contents_(size) {} |
Tom Cherry | b6cb992 | 2020-06-24 13:51:04 -0700 | [diff] [blame] | 28 | SerializedLogChunk(SerializedLogChunk&& other) noexcept = default; |
Tom Cherry | 1a796bc | 2020-05-13 09:28:37 -0700 | [diff] [blame] | 29 | ~SerializedLogChunk(); |
| 30 | |
| 31 | void Compress(); |
| 32 | void IncReaderRefCount(); |
| 33 | // Decrease the reader ref count and compress the log if appropriate. `compress` should only be |
| 34 | // set to false in the case that the log buffer will be deleted afterwards. |
| 35 | void DecReaderRefCount(bool compress); |
| 36 | |
| 37 | // Must have no readers referencing this. Return true if there are no logs left in this chunk. |
| 38 | bool ClearUidLogs(uid_t uid, log_id_t log_id, LogStatistics* stats); |
| 39 | |
| 40 | bool CanLog(size_t len); |
| 41 | SerializedLogEntry* Log(uint64_t sequence, log_time realtime, uid_t uid, pid_t pid, pid_t tid, |
| 42 | const char* msg, uint16_t len); |
| 43 | |
| 44 | // If this buffer has been compressed, we only consider its compressed size when accounting for |
| 45 | // memory consumption for pruning. This is since the uncompressed log is only by used by |
| 46 | // readers, and thus not a representation of how much these logs cost to keep in memory. |
| 47 | size_t PruneSize() const { return compressed_log_.size() ?: contents_.size(); } |
| 48 | |
| 49 | void FinishWriting() { |
| 50 | writer_active_ = false; |
| 51 | if (reader_ref_count_ == 0) { |
| 52 | Compress(); |
| 53 | } |
| 54 | } |
| 55 | |
| 56 | const SerializedLogEntry* log_entry(int offset) const { |
| 57 | return reinterpret_cast<const SerializedLogEntry*>(data() + offset); |
| 58 | } |
| 59 | const uint8_t* data() const { return contents_.data(); } |
| 60 | int write_offset() const { return write_offset_; } |
| 61 | uint64_t highest_sequence_number() const { return highest_sequence_number_; } |
| 62 | |
Tom Cherry | b07e339 | 2020-06-24 11:47:49 -0700 | [diff] [blame] | 63 | // Exposed for testing |
| 64 | uint32_t reader_ref_count() const { return reader_ref_count_; } |
| 65 | |
Tom Cherry | 1a796bc | 2020-05-13 09:28:37 -0700 | [diff] [blame] | 66 | private: |
| 67 | // The decompressed contents of this log buffer. Deallocated when the ref_count reaches 0 and |
| 68 | // writer_active_ is false. |
Tom Cherry | b6cb992 | 2020-06-24 13:51:04 -0700 | [diff] [blame] | 69 | SerializedData contents_; |
Tom Cherry | 1a796bc | 2020-05-13 09:28:37 -0700 | [diff] [blame] | 70 | int write_offset_ = 0; |
| 71 | uint32_t reader_ref_count_ = 0; |
| 72 | bool writer_active_ = true; |
| 73 | uint64_t highest_sequence_number_ = 1; |
Tom Cherry | b6cb992 | 2020-06-24 13:51:04 -0700 | [diff] [blame] | 74 | SerializedData compressed_log_; |
Tom Cherry | 1a796bc | 2020-05-13 09:28:37 -0700 | [diff] [blame] | 75 | }; |