blob: b4fd63f119e6074c8218d02cf5f93c5cb6941b14 [file] [log] [blame]
/*
* Copyright (C) 2019 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#pragma once
#include "LogEvent.h"
#include <condition_variable>
#include <memory>
#include <mutex>
#include <queue>
#include <thread>
namespace android {
namespace os {
namespace statsd {
/**
* A zero copy thread safe queue buffer for producing and consuming LogEvent.
*/
class LogEventQueue {
public:
explicit LogEventQueue(size_t maxSize) : mQueueLimit(maxSize){};
/**
* Blocking read one event from the queue.
*/
std::unique_ptr<LogEvent> waitPop();
/**
* Puts a LogEvent ptr to the end of the queue.
* Returns false on failure when the queue is full, and output the oldest event timestamp
* in the queue.
*/
bool push(std::unique_ptr<LogEvent> event, int64_t* oldestTimestampNs);
private:
const size_t mQueueLimit;
std::condition_variable mCondition;
std::mutex mMutex;
std::queue<std::unique_ptr<LogEvent>> mQueue;
};
} // namespace statsd
} // namespace os
} // namespace android