mmap.hpp
1 /*
2  * SPDX-FileCopyrightText: Copyright (c) 2025, NVIDIA CORPORATION.
3  * SPDX-License-Identifier: Apache-2.0
4  */
5 #pragma once
6 
7 #include <cstddef>
8 #include <future>
9 
10 #include <kvikio/defaults.hpp>
11 #include <kvikio/file_handle.hpp>
12 #include <kvikio/threadpool_wrapper.hpp>
13 #include <optional>
14 
15 namespace kvikio {
16 
28 class MmapHandle {
29  private:
30  void* _buf{};
31  std::size_t _initial_map_size{};
32  std::size_t _initial_map_offset{};
33  std::size_t _file_size{};
34  std::size_t _map_offset{};
35  std::size_t _map_size{};
36  void* _map_addr{};
37  bool _initialized{};
38  int _map_protection{};
39  int _map_flags{};
40  FileWrapper _file_wrapper{};
41 
54  std::size_t validate_and_adjust_read_args(std::optional<std::size_t> const& size,
55  std::size_t offset);
56 
57  public:
62  MmapHandle() noexcept = default;
63 
84  MmapHandle(std::string const& file_path,
85  std::string const& flags = "r",
86  std::optional<std::size_t> initial_map_size = std::nullopt,
87  std::size_t initial_map_offset = 0,
88  mode_t mode = FileHandle::m644,
89  std::optional<int> map_flags = std::nullopt);
90 
91  MmapHandle(MmapHandle const&) = delete;
92  MmapHandle& operator=(MmapHandle const&) = delete;
93  MmapHandle(MmapHandle&& o) noexcept;
94  MmapHandle& operator=(MmapHandle&& o) noexcept;
95  ~MmapHandle() noexcept;
96 
102  [[nodiscard]] std::size_t initial_map_size() const noexcept;
103 
109  [[nodiscard]] std::size_t initial_map_offset() const noexcept;
110 
118  [[nodiscard]] std::size_t file_size() const;
119 
125  [[nodiscard]] std::size_t nbytes() const;
126 
132  [[nodiscard]] bool closed() const noexcept;
133 
137  void close() noexcept;
138 
153  std::size_t read(void* buf,
154  std::optional<std::size_t> size = std::nullopt,
155  std::size_t offset = 0);
156 
179  std::future<std::size_t> pread(void* buf,
180  std::optional<std::size_t> size = std::nullopt,
181  std::size_t offset = 0,
182  std::size_t task_size = defaults::task_size(),
183  ThreadPool* thread_pool = &defaults::thread_pool());
184 };
185 
186 } // namespace kvikio
Handle of an open file registered with cufile.
Definition: file_handle.hpp:33
Class that provides RAII for file handling.
Definition: file_utils.hpp:16
Handle of a memory-mapped file.
Definition: mmap.hpp:28
std::future< std::size_t > pread(void *buf, std::optional< std::size_t > size=std::nullopt, std::size_t offset=0, std::size_t task_size=defaults::task_size(), ThreadPool *thread_pool=&defaults::thread_pool())
Parallel read size bytes from the file (with the offset offset) to the destination buffer buf
std::size_t read(void *buf, std::optional< std::size_t > size=std::nullopt, std::size_t offset=0)
Sequential read size bytes from the file (with the offset offset) to the destination buffer buf
bool closed() const noexcept
Whether the mapping handle is closed.
std::size_t file_size() const
Get the file size if the file is open. Returns 0 if the file is closed.
void close() noexcept
Close the mapping handle if it is open; do nothing otherwise.
std::size_t nbytes() const
Alias of file_size
std::size_t initial_map_offset() const noexcept
File offset of the mapped region when the mapping handle was constructed.
MmapHandle() noexcept=default
Construct an empty memory-mapped file.
std::size_t initial_map_size() const noexcept
Size in bytes of the mapped region when the mapping handle was constructed.
Singleton class of default values used throughout KvikIO.
Definition: defaults.hpp:112
KvikIO namespace.
Definition: batch.hpp:16
BS::thread_pool ThreadPool
Thread pool type used for parallel I/O operations.