mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-25 19:02:07 -05:00
ec65b8db2e
This reverts commit 1cca5142af
.
This appears to be causing intermittent triple-faults and I don't know
why yet, so I'll just revert it to keep the tree in decent shape.
34 lines
841 B
C++
34 lines
841 B
C++
#pragma once
|
|
|
|
#include <AK/Types.h>
|
|
#include <AK/Vector.h>
|
|
#include <Kernel/Lock.h>
|
|
|
|
class DoubleBuffer {
|
|
public:
|
|
DoubleBuffer()
|
|
: m_write_buffer(&m_buffer1)
|
|
, m_read_buffer(&m_buffer2)
|
|
{
|
|
}
|
|
|
|
ssize_t write(const u8*, ssize_t);
|
|
ssize_t read(u8*, ssize_t);
|
|
|
|
bool is_empty() const { return m_empty; }
|
|
|
|
// FIXME: Isn't this racy? What if we get interrupted between getting the buffer pointer and dereferencing it?
|
|
ssize_t bytes_in_write_buffer() const { return (ssize_t)m_write_buffer->size(); }
|
|
|
|
private:
|
|
void flip();
|
|
void compute_emptiness();
|
|
|
|
Vector<u8>* m_write_buffer { nullptr };
|
|
Vector<u8>* m_read_buffer { nullptr };
|
|
Vector<u8> m_buffer1;
|
|
Vector<u8> m_buffer2;
|
|
ssize_t m_read_buffer_index { 0 };
|
|
bool m_empty { true };
|
|
Lock m_lock { "DoubleBuffer" };
|
|
};
|