mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 08:58:11 +00:00

Before we start disabling acquisition of the big process lock for specific syscalls, make sure to document and assert that all the lock is held during all syscalls.
55 lines
1.4 KiB
C++
55 lines
1.4 KiB
C++
/*
|
|
* Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <Kernel/FileSystem/AnonymousFile.h>
|
|
#include <Kernel/FileSystem/FileDescription.h>
|
|
#include <Kernel/Process.h>
|
|
#include <Kernel/VM/AnonymousVMObject.h>
|
|
|
|
namespace Kernel {
|
|
|
|
KResultOr<FlatPtr> Process::sys$anon_create(size_t size, int options)
|
|
{
|
|
VERIFY_PROCESS_BIG_LOCK_ACQUIRED(this);
|
|
REQUIRE_PROMISE(stdio);
|
|
|
|
if (!size)
|
|
return EINVAL;
|
|
|
|
if (size % PAGE_SIZE)
|
|
return EINVAL;
|
|
|
|
if (size > NumericLimits<ssize_t>::max())
|
|
return EINVAL;
|
|
|
|
int new_fd = m_fds.allocate();
|
|
if (new_fd < 0)
|
|
return new_fd;
|
|
|
|
auto vmobject = AnonymousVMObject::try_create_with_size(size, AllocationStrategy::Reserve);
|
|
if (!vmobject)
|
|
return ENOMEM;
|
|
|
|
auto anon_file = AnonymousFile::create(vmobject.release_nonnull());
|
|
if (!anon_file)
|
|
return ENOMEM;
|
|
auto description_or_error = FileDescription::create(*anon_file);
|
|
if (description_or_error.is_error())
|
|
return description_or_error.error();
|
|
|
|
auto description = description_or_error.release_value();
|
|
description->set_writable(true);
|
|
description->set_readable(true);
|
|
|
|
u32 fd_flags = 0;
|
|
if (options & O_CLOEXEC)
|
|
fd_flags |= FD_CLOEXEC;
|
|
|
|
m_fds[new_fd].set(move(description), fd_flags);
|
|
return new_fd;
|
|
}
|
|
|
|
}
|