2019-06-07 11:49:03 +02:00
|
|
|
#include <AK/kmalloc.h>
|
2019-12-09 20:06:47 +01:00
|
|
|
#include <Kernel/Syscall.h>
|
2019-07-04 16:16:50 +02:00
|
|
|
#include <SharedBuffer.h>
|
2019-03-08 12:22:55 +01:00
|
|
|
#include <stdio.h>
|
2019-06-07 11:49:03 +02:00
|
|
|
#include <unistd.h>
|
2019-03-08 12:22:55 +01:00
|
|
|
|
2019-07-18 09:52:22 +02:00
|
|
|
RefPtr<SharedBuffer> SharedBuffer::create_with_size(int size)
|
2019-03-08 12:22:55 +01:00
|
|
|
{
|
|
|
|
void* data;
|
2019-07-18 09:52:22 +02:00
|
|
|
int shared_buffer_id = create_shared_buffer(size, &data);
|
2019-03-08 12:22:55 +01:00
|
|
|
if (shared_buffer_id < 0) {
|
|
|
|
perror("create_shared_buffer");
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
return adopt(*new SharedBuffer(shared_buffer_id, size, data));
|
|
|
|
}
|
|
|
|
|
2019-07-18 09:52:22 +02:00
|
|
|
bool SharedBuffer::share_with(pid_t peer)
|
|
|
|
{
|
|
|
|
int ret = share_buffer_with(shared_buffer_id(), peer);
|
|
|
|
if (ret < 0) {
|
|
|
|
perror("share_buffer_with");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2019-12-23 20:24:26 +01:00
|
|
|
bool SharedBuffer::share_globally()
|
|
|
|
{
|
|
|
|
int ret = share_buffer_globally(shared_buffer_id());
|
|
|
|
if (ret < 0) {
|
|
|
|
perror("share_buffer_globally");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-06-21 18:37:47 +02:00
|
|
|
RefPtr<SharedBuffer> SharedBuffer::create_from_shared_buffer_id(int shared_buffer_id)
|
2019-03-08 12:22:55 +01:00
|
|
|
{
|
|
|
|
void* data = get_shared_buffer(shared_buffer_id);
|
|
|
|
if (data == (void*)-1) {
|
|
|
|
perror("get_shared_buffer");
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
int size = get_shared_buffer_size(shared_buffer_id);
|
|
|
|
if (size < 0) {
|
|
|
|
perror("get_shared_buffer_size");
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
return adopt(*new SharedBuffer(shared_buffer_id, size, data));
|
|
|
|
}
|
|
|
|
|
|
|
|
SharedBuffer::SharedBuffer(int shared_buffer_id, int size, void* data)
|
|
|
|
: m_shared_buffer_id(shared_buffer_id)
|
|
|
|
, m_size(size)
|
|
|
|
, m_data(data)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
SharedBuffer::~SharedBuffer()
|
|
|
|
{
|
|
|
|
if (m_shared_buffer_id >= 0) {
|
|
|
|
int rc = release_shared_buffer(m_shared_buffer_id);
|
|
|
|
if (rc < 0) {
|
|
|
|
perror("release_shared_buffer");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SharedBuffer::seal()
|
|
|
|
{
|
|
|
|
int rc = seal_shared_buffer(m_shared_buffer_id);
|
|
|
|
if (rc < 0) {
|
|
|
|
perror("seal_shared_buffer");
|
2019-04-04 01:44:35 +02:00
|
|
|
ASSERT_NOT_REACHED();
|
2019-03-08 12:22:55 +01:00
|
|
|
}
|
|
|
|
}
|
2019-12-09 20:06:47 +01:00
|
|
|
|
|
|
|
void SharedBuffer::set_volatile()
|
|
|
|
{
|
|
|
|
u32 rc = syscall(SC_set_shared_buffer_volatile, m_shared_buffer_id, true);
|
|
|
|
ASSERT(rc == 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool SharedBuffer::set_nonvolatile()
|
|
|
|
{
|
|
|
|
u32 rc = syscall(SC_set_shared_buffer_volatile, m_shared_buffer_id, false);
|
|
|
|
if (rc == 0)
|
|
|
|
return true;
|
|
|
|
if (rc == 1)
|
|
|
|
return false;
|
|
|
|
ASSERT_NOT_REACHED();
|
|
|
|
}
|