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 () |
| |
| 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...
|
| |