anon_create.cpp 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /*
  2. * Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <Kernel/FileSystem/AnonymousFile.h>
  7. #include <Kernel/FileSystem/FileDescription.h>
  8. #include <Kernel/Process.h>
  9. #include <Kernel/VM/AnonymousVMObject.h>
  10. namespace Kernel {
  11. KResultOr<FlatPtr> Process::sys$anon_create(size_t size, int options)
  12. {
  13. REQUIRE_PROMISE(stdio);
  14. if (!size)
  15. return EINVAL;
  16. if (size % PAGE_SIZE)
  17. return EINVAL;
  18. if (size > NumericLimits<ssize_t>::max())
  19. return EINVAL;
  20. int new_fd = alloc_fd();
  21. if (new_fd < 0)
  22. return new_fd;
  23. auto vmobject = AnonymousVMObject::create_with_size(size, AllocationStrategy::Reserve);
  24. if (!vmobject)
  25. return ENOMEM;
  26. auto anon_file = AnonymousFile::create(vmobject.release_nonnull());
  27. if (!anon_file)
  28. return ENOMEM;
  29. auto description_or_error = FileDescription::create(*anon_file);
  30. if (description_or_error.is_error())
  31. return description_or_error.error();
  32. auto description = description_or_error.release_value();
  33. description->set_writable(true);
  34. description->set_readable(true);
  35. u32 fd_flags = 0;
  36. if (options & O_CLOEXEC)
  37. fd_flags |= FD_CLOEXEC;
  38. m_fds[new_fd].set(move(description), fd_flags);
  39. return new_fd;
  40. }
  41. }