2023-05-10 20:48:31 +00:00
|
|
|
#pragma once
|
|
|
|
#include "fs/VFS.h"
|
|
|
|
#include <luna/Buffer.h>
|
|
|
|
|
|
|
|
class PipeInodeBase;
|
|
|
|
class PipeReader;
|
|
|
|
class PipeWriter;
|
|
|
|
|
2023-07-30 09:32:46 +00:00
|
|
|
class Pipe : public Shareable
|
2023-05-10 20:48:31 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
static Result<void> create(SharedPtr<VFS::Inode>& rpipe, SharedPtr<VFS::Inode>& wpipe);
|
|
|
|
|
|
|
|
Result<usize> read(u8* buf, usize, usize length);
|
|
|
|
|
|
|
|
Result<usize> write(const u8* buf, usize, usize length);
|
|
|
|
|
2023-07-30 09:41:53 +00:00
|
|
|
bool will_block_if_read() const;
|
2023-05-10 20:48:31 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
Buffer m_data_buffer;
|
|
|
|
PipeWriter* m_writer;
|
|
|
|
PipeReader* m_reader;
|
|
|
|
|
|
|
|
friend class PipeInodeBase;
|
|
|
|
friend class PipeReader;
|
|
|
|
friend class PipeWriter;
|
|
|
|
};
|
|
|
|
|
|
|
|
class PipeInodeBase : public VFS::FileInode
|
|
|
|
{
|
|
|
|
public:
|
2023-05-23 18:54:25 +00:00
|
|
|
VFS::InodeType type() const override
|
|
|
|
{
|
|
|
|
return VFS::InodeType::FIFO;
|
|
|
|
}
|
|
|
|
|
2023-05-10 20:48:31 +00:00
|
|
|
Result<void> truncate(usize) override
|
|
|
|
{
|
|
|
|
return err(ENOTSUP);
|
|
|
|
}
|
|
|
|
|
2023-07-30 09:41:53 +00:00
|
|
|
bool will_block_if_read() const override
|
2023-05-10 20:48:31 +00:00
|
|
|
{
|
2023-07-30 09:41:53 +00:00
|
|
|
return m_pipe->will_block_if_read();
|
2023-05-10 20:48:31 +00:00
|
|
|
}
|
|
|
|
|
2023-08-01 15:20:28 +00:00
|
|
|
const VFS::InodeMetadata& metadata() const override
|
2023-05-10 20:48:31 +00:00
|
|
|
{
|
2023-08-01 15:20:28 +00:00
|
|
|
m_metadata.size = m_pipe->m_data_buffer.size();
|
|
|
|
return m_metadata;
|
2023-05-10 20:48:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void did_link() override
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void did_unlink() override
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
VFS::FileSystem* fs() const override
|
|
|
|
{
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual ~PipeInodeBase() = default;
|
|
|
|
|
|
|
|
friend class Pipe;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
SharedPtr<Pipe> m_pipe;
|
|
|
|
};
|
|
|
|
|
|
|
|
class PipeWriter : public PipeInodeBase
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Result<usize> read(u8*, usize, usize) const override
|
|
|
|
{
|
|
|
|
// A FileDescriptor pointing to a PipeWriter should never be opened for reading.
|
|
|
|
check(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
Result<usize> write(const u8* buf, usize offset, usize length) override
|
|
|
|
{
|
|
|
|
return m_pipe->write(buf, offset, length);
|
|
|
|
}
|
|
|
|
|
|
|
|
~PipeWriter();
|
|
|
|
|
|
|
|
friend class Pipe;
|
|
|
|
};
|
|
|
|
|
|
|
|
class PipeReader : public PipeInodeBase
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Result<usize> read(u8* buf, usize offset, usize length) const override
|
|
|
|
{
|
|
|
|
return m_pipe->read(buf, offset, length);
|
|
|
|
}
|
|
|
|
|
|
|
|
Result<usize> write(const u8*, usize, usize) override
|
|
|
|
{
|
|
|
|
// A FileDescriptor pointing to a PipeReader should never be opened for writing.
|
|
|
|
check(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
~PipeReader();
|
|
|
|
|
|
|
|
friend class Pipe;
|
|
|
|
};
|