summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Morton <akpm@osdl.org>2004-01-19 05:11:24 -0800
committerLinus Torvalds <torvalds@home.osdl.org>2004-01-19 05:11:24 -0800
commit8e05ea563f2fccdc9faedb483843fbaa82151ecf (patch)
treeef05524c15bf0d036d98e27f8cca9010bc666efb
parentf5ace1666d0e4b2de3635355e84009a9bed23ed5 (diff)
[PATCH] bio documentation update
From: Jens Axboe <axboe@suse.de> Although it was an established part of the current bio api, it was never documented that bio_add_page() and merge_bvec_fn() must accept to add at least one page to an empty bio.
-rw-r--r--drivers/block/ll_rw_blk.c8
-rw-r--r--fs/bio.c4
2 files changed, 8 insertions, 4 deletions
diff --git a/drivers/block/ll_rw_blk.c b/drivers/block/ll_rw_blk.c
index 530f6c5962aa..c23382abd4f5 100644
--- a/drivers/block/ll_rw_blk.c
+++ b/drivers/block/ll_rw_blk.c
@@ -173,9 +173,11 @@ EXPORT_SYMBOL(blk_queue_prep_rq);
* are dynamic, and thus we have to query the queue whether it is ok to
* add a new bio_vec to a bio at a given offset or not. If the block device
* has such limitations, it needs to register a merge_bvec_fn to control
- * the size of bio's sent to it. Per default now merge_bvec_fn is defined for
- * a queue, and only the fixed limits are honored.
- *
+ * the size of bio's sent to it. Note that a block device *must* allow a
+ * single page to be added to an empty bio. The block device driver may want
+ * to use the bio_split() function to deal with these bio's. By default
+ * no merge_bvec_fn is defined for a queue, and only the fixed limits are
+ * honored.
*/
void blk_queue_merge_bvec(request_queue_t *q, merge_bvec_fn *mbfn)
{
diff --git a/fs/bio.c b/fs/bio.c
index 390d862325b9..048e274084ba 100644
--- a/fs/bio.c
+++ b/fs/bio.c
@@ -290,7 +290,9 @@ int bio_get_nr_vecs(struct block_device *bdev)
*
* Attempt to add a page to the bio_vec maplist. This can fail for a
* number of reasons, such as the bio being full or target block
- * device limitations.
+ * device limitations. The target block device must allow bio's
+ * smaller than PAGE_SIZE, so it is always possible to add a single
+ * page to an empty bio.
*/
int bio_add_page(struct bio *bio, struct page *page, unsigned int len,
unsigned int offset)