1/* 2 * Copyright (C) 2009-2011 Red Hat, Inc. 3 * 4 * Author: Mikulas Patocka <mpatocka@redhat.com> 5 * 6 * This file is released under the GPL. 7 */ 8 9#ifndef _LINUX_DM_BUFIO_H 10#define _LINUX_DM_BUFIO_H 11 12#include <linux/blkdev.h> 13#include <linux/types.h> 14 15/*----------------------------------------------------------------*/ 16 17struct dm_bufio_client; 18struct dm_buffer; 19 20/* 21 * Create a buffered IO cache on a given device 22 */ 23struct dm_bufio_client * 24dm_bufio_client_create(struct block_device *bdev, unsigned block_size, 25 unsigned reserved_buffers, unsigned aux_size, 26 void (*alloc_callback)(struct dm_buffer *), 27 void (*write_callback)(struct dm_buffer *)); 28 29/* 30 * Release a buffered IO cache. 31 */ 32void dm_bufio_client_destroy(struct dm_bufio_client *c); 33 34/* 35 * Set the sector range. 36 * When this function is called, there must be no I/O in progress on the bufio 37 * client. 38 */ 39void dm_bufio_set_sector_offset(struct dm_bufio_client *c, sector_t start); 40 41/* 42 * WARNING: to avoid deadlocks, these conditions are observed: 43 * 44 * - At most one thread can hold at most "reserved_buffers" simultaneously. 45 * - Each other threads can hold at most one buffer. 46 * - Threads which call only dm_bufio_get can hold unlimited number of 47 * buffers. 48 */ 49 50/* 51 * Read a given block from disk. Returns pointer to data. Returns a 52 * pointer to dm_buffer that can be used to release the buffer or to make 53 * it dirty. 54 */ 55void *dm_bufio_read(struct dm_bufio_client *c, sector_t block, 56 struct dm_buffer **bp); 57 58/* 59 * Like dm_bufio_read, but return buffer from cache, don't read 60 * it. If the buffer is not in the cache, return NULL. 61 */ 62void *dm_bufio_get(struct dm_bufio_client *c, sector_t block, 63 struct dm_buffer **bp); 64 65/* 66 * Like dm_bufio_read, but don't read anything from the disk. It is 67 * expected that the caller initializes the buffer and marks it dirty. 68 */ 69void *dm_bufio_new(struct dm_bufio_client *c, sector_t block, 70 struct dm_buffer **bp); 71 72/* 73 * Prefetch the specified blocks to the cache. 74 * The function starts to read the blocks and returns without waiting for 75 * I/O to finish. 76 */ 77void dm_bufio_prefetch(struct dm_bufio_client *c, 78 sector_t block, unsigned n_blocks); 79 80/* 81 * Release a reference obtained with dm_bufio_{read,get,new}. The data 82 * pointer and dm_buffer pointer is no longer valid after this call. 83 */ 84void dm_bufio_release(struct dm_buffer *b); 85 86/* 87 * Mark a buffer dirty. It should be called after the buffer is modified. 88 * 89 * In case of memory pressure, the buffer may be written after 90 * dm_bufio_mark_buffer_dirty, but before dm_bufio_write_dirty_buffers. So 91 * dm_bufio_write_dirty_buffers guarantees that the buffer is on-disk but 92 * the actual writing may occur earlier. 93 */ 94void dm_bufio_mark_buffer_dirty(struct dm_buffer *b); 95 96/* 97 * Mark a part of the buffer dirty. 98 * 99 * The specified part of the buffer is scheduled to be written. dm-bufio may 100 * write the specified part of the buffer or it may write a larger superset. 101 */ 102void dm_bufio_mark_partial_buffer_dirty(struct dm_buffer *b, 103 unsigned start, unsigned end); 104 105/* 106 * Initiate writing of dirty buffers, without waiting for completion. 107 */ 108void dm_bufio_write_dirty_buffers_async(struct dm_bufio_client *c); 109 110/* 111 * Write all dirty buffers. Guarantees that all dirty buffers created prior 112 * to this call are on disk when this call exits. 113 */ 114int dm_bufio_write_dirty_buffers(struct dm_bufio_client *c); 115 116/* 117 * Send an empty write barrier to the device to flush hardware disk cache. 118 */ 119int dm_bufio_issue_flush(struct dm_bufio_client *c); 120 121/* 122 * Like dm_bufio_release but also move the buffer to the new 123 * block. dm_bufio_write_dirty_buffers is needed to commit the new block. 124 */ 125void dm_bufio_release_move(struct dm_buffer *b, sector_t new_block); 126 127/* 128 * Free the given buffer. 129 * This is just a hint, if the buffer is in use or dirty, this function 130 * does nothing. 131 */ 132void dm_bufio_forget(struct dm_bufio_client *c, sector_t block); 133 134/* 135 * Set the minimum number of buffers before cleanup happens. 136 */ 137void dm_bufio_set_minimum_buffers(struct dm_bufio_client *c, unsigned n); 138 139unsigned dm_bufio_get_block_size(struct dm_bufio_client *c); 140sector_t dm_bufio_get_device_size(struct dm_bufio_client *c); 141struct dm_io_client *dm_bufio_get_dm_io_client(struct dm_bufio_client *c); 142sector_t dm_bufio_get_block_number(struct dm_buffer *b); 143void *dm_bufio_get_block_data(struct dm_buffer *b); 144void *dm_bufio_get_aux_data(struct dm_buffer *b); 145struct dm_bufio_client *dm_bufio_get_client(struct dm_buffer *b); 146 147/*----------------------------------------------------------------*/ 148 149#endif 150