Implementation of file based on buffered writes and block remapping via a translation layer.
Definition at line 36 of file wbtl_file.h.
|
| wbtl_file (file *backend_file, size_type write_buffer_size, int write_buffers=2, int queue_id=DEFAULT_QUEUE, int allocator_id=NO_ALLOCATOR) |
| Constructs file object. param backend_file file object used as storage backend, will be deleted in ~wbtl_file() More...
|
|
| ~wbtl_file () |
|
void | discard (offset_type offset, offset_type size) |
|
const char * | io_type () const |
| Identifies the type of I/O implementation. More...
|
|
void | lock () |
| Locks file for reading and writing (acquires a lock in the file system). More...
|
|
void | serve (void *buffer, offset_type offset, size_type bytes, request::request_type type) |
|
void | set_size (offset_type newsize) |
|
offset_type | size () |
| Returns size of the file. More...
|
|
| disk_queued_file (int queue_id, int allocator_id) |
|
request_ptr | aread (void *buffer, offset_type pos, size_type bytes, const completion_handler &on_cmpl=completion_handler()) |
|
request_ptr | awrite (void *buffer, offset_type pos, size_type bytes, const completion_handler &on_cmpl=completion_handler()) |
|
virtual int | get_allocator_id () const |
| Returns the file's disk allocator number. More...
|
|
virtual int | get_queue_id () const |
| Returns the identifier of the file's queue number. More...
|
|
| file (unsigned int device_id=DEFAULT_DEVICE_ID) |
| Construct a new file, usually called by a subclass. More...
|
|
virtual | ~file () noexcept(false) |
|
void | add_request_ref () |
| increment referenced requests More...
|
|
virtual request_ptr | aread (void *buffer, offset_type pos, size_type bytes, const completion_handler &on_cmpl=completion_handler())=0 |
| Schedules an asynchronous read request to the file. More...
|
|
virtual request_ptr | awrite (void *buffer, offset_type pos, size_type bytes, const completion_handler &on_cmpl=completion_handler())=0 |
| Schedules an asynchronous write request to the file. More...
|
|
virtual void | close_remove () |
| close and remove file More...
|
|
void | delete_request_ref () |
| decrement referenced requests More...
|
|
virtual void | discard (offset_type offset, offset_type size) |
| Discard a region of the file (mark it unused). Some specialized file types may need to know freed regions. More...
|
|
virtual void | export_files (offset_type offset, offset_type length, std::string prefix) |
|
unsigned int | get_device_id () const |
| Returns the file's physical device id. More...
|
|
unsigned_type | get_request_nref () |
| return number of referenced requests More...
|
|
virtual void | serve (void *buffer, offset_type offset, size_type bytes, request::request_type type)=0 |
|
virtual void | set_size (offset_type newsize)=0 |
| Changes the size of the file. More...
|
|
|
typedef request::offset_type | offset_type |
| the offset of a request, also the size of the file More...
|
|
enum | open_mode {
RDONLY = 1,
WRONLY = 2,
RDWR = 4,
CREAT = 8,
DIRECT = 16,
TRUNC = 32,
SYNC = 64,
NO_LOCK = 128,
REQUIRE_DIRECT = 256
} |
| Definition of acceptable file open modes. More...
|
|
typedef request::size_type | size_type |
| the size of a request More...
|
|
static int | unlink (const char *path) |
| unlink path from filesystem More...
|
|
static int | truncate (const char *path, external_size_type length) |
| truncate a path to given length. Use this only if you dont have a fileio-specific object, which provides truncate(). More...
|
|
static const unsigned int | DEFAULT_DEVICE_ID = (unsigned int)(-1) |
|
static const int | DEFAULT_LINUXAIO_QUEUE = -2 |
|
static const int | DEFAULT_QUEUE = -1 |
|
static const int | NO_ALLOCATOR = -1 |
|
unsigned int | m_device_id |
| The file's physical device id (e.g. used for prefetching sequence calculation) More...
|
|
atomic_counted_object | m_request_ref |
| count the number of requests referencing this file More...
|
|