19 #include <sys/types.h>
24 #include <system_error>
27 #include <kvikio/buffer.hpp>
28 #include <kvikio/compat_mode.hpp>
29 #include <kvikio/cufile/config.hpp>
30 #include <kvikio/defaults.hpp>
31 #include <kvikio/error.hpp>
32 #include <kvikio/file_utils.hpp>
33 #include <kvikio/parallel_operation.hpp>
34 #include <kvikio/posix_io.hpp>
35 #include <kvikio/shim/cufile.hpp>
36 #include <kvikio/shim/cufile_h_wrapper.hpp>
37 #include <kvikio/stream.hpp>
38 #include <kvikio/utils.hpp>
52 bool _initialized{
false};
53 mutable std::size_t _nbytes{0};
61 static constexpr mode_t m644 = S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH;
81 std::string
const& flags =
"r",
99 [[nodiscard]]
bool closed() const noexcept;
125 [[nodiscard]]
int fd(
bool o_direct = false) const noexcept;
146 [[nodiscard]] std::
size_t nbytes() const;
178 std::
size_t read(
void* devPtr_base,
180 std::
size_t file_offset,
181 std::
size_t devPtr_offset,
182 bool sync_default_stream = true);
215 std::
size_t write(
void const* devPtr_base,
217 std::
size_t file_offset,
218 std::
size_t devPtr_offset,
219 bool sync_default_stream = true);
251 std::future<std::
size_t>
pread(
void* buf,
253 std::
size_t file_offset = 0,
254 std::
size_t task_size =
defaults::task_size(),
255 std::
size_t gds_threshold =
defaults::gds_threshold(),
256 bool sync_default_stream = true);
288 std::future<std::
size_t>
pwrite(
void const* buf,
290 std::
size_t file_offset = 0,
291 std::
size_t task_size =
defaults::task_size(),
292 std::
size_t gds_threshold =
defaults::gds_threshold(),
293 bool sync_default_stream = true);
331 off_t* file_offset_p,
332 off_t* devPtr_offset_p,
333 ssize_t* bytes_read_p,
363 off_t file_offset = 0,
364 off_t devPtr_offset = 0,
365 CUstream stream =
nullptr);
404 off_t* file_offset_p,
405 off_t* devPtr_offset_p,
406 ssize_t* bytes_written_p,
436 off_t file_offset = 0,
437 off_t devPtr_offset = 0,
438 CUstream stream =
nullptr);
Class that provides RAII for the cuFile handle.
Store and manage the compatibility mode data associated with a FileHandle.
Handle of an open file registered with cufile.
void close() noexcept
Deregister the file and close the two files.
int fd(bool o_direct=false) const noexcept
Get one of the file descriptors.
std::future< std::size_t > pread(void *buf, std::size_t size, std::size_t file_offset=0, std::size_t task_size=defaults::task_size(), std::size_t gds_threshold=defaults::gds_threshold(), bool sync_default_stream=true)
Reads specified bytes from the file into the device or host memory in parallel.
void read_async(void *devPtr_base, std::size_t *size_p, off_t *file_offset_p, off_t *devPtr_offset_p, ssize_t *bytes_read_p, CUstream stream)
Reads specified bytes from the file into the device memory asynchronously.
int fd_open_flags(bool o_direct=false) const
Get the flags of one of the file descriptors (see open(2))
std::future< std::size_t > pwrite(void const *buf, std::size_t size, std::size_t file_offset=0, std::size_t task_size=defaults::task_size(), std::size_t gds_threshold=defaults::gds_threshold(), bool sync_default_stream=true)
Writes specified bytes from device or host memory into the file in parallel.
std::size_t write(void const *devPtr_base, std::size_t size, std::size_t file_offset, std::size_t devPtr_offset, bool sync_default_stream=true)
Writes specified bytes from the device memory into the file.
CUfileHandle_t handle()
Get the underlying cuFile file handle.
const CompatModeManager & get_compat_mode_manager() const noexcept
Get the associated compatibility mode manager, which can be used to query the original requested comp...
FileHandle(std::string const &file_path, std::string const &flags="r", mode_t mode=m644, CompatMode compat_mode=defaults::compat_mode())
Construct a file handle from a file path.
bool closed() const noexcept
Whether the file is closed according to its initialization status.
void write_async(void *devPtr_base, std::size_t *size_p, off_t *file_offset_p, off_t *devPtr_offset_p, ssize_t *bytes_written_p, CUstream stream)
Writes specified bytes from the device memory into the file asynchronously.
std::size_t nbytes() const
Get the file size.
std::size_t read(void *devPtr_base, std::size_t size, std::size_t file_offset, std::size_t devPtr_offset, bool sync_default_stream=true)
Reads specified bytes from the file into the device memory.
FileHandle(FileHandle const &)=delete
FileHandle support move semantic but isn't copyable.
Class that provides RAII for file handling.
Future of an asynchronous IO operation.
Singleton class of default values used throughout KvikIO.
static CompatMode compat_mode()
Return whether the KvikIO library is running in compatibility mode or not.
CompatMode
I/O compatibility mode.