diff options
author | Mike Christie <michaelc@cs.wisc.edu> | 2011-07-31 16:05:09 -0400 |
---|---|---|
committer | Jens Axboe <jaxboe@fusionio.com> | 2011-07-31 16:05:09 -0400 |
commit | aa387cc895672b00f807ad7c734a2defaf677712 (patch) | |
tree | 31c2c3f3e0d58ff2524cdf8f94abecc394f5eb49 /include/linux/blkdev.h | |
parent | 24c3047095fa3954f114bfff2e37b8fcbb216396 (diff) |
block: add bsg helper library
This moves the FC classes bsg code to the block layer and
makes it a lib so that other classes like iscsi and SAS can use it.
It is helpful because working with the request queue, bios,
creating scatterlists, etc are a pain that the LLD does not
have to worry about with normal IOs and should not have to
worry about for bsg requests.
Signed-off-by: Mike Christie <michaelc@cs.wisc.edu>
Signed-off-by: Jens Axboe <jaxboe@fusionio.com>
Diffstat (limited to 'include/linux/blkdev.h')
-rw-r--r-- | include/linux/blkdev.h | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h index 0e67c45b3bc9..847928546076 100644 --- a/include/linux/blkdev.h +++ b/include/linux/blkdev.h | |||
@@ -30,6 +30,7 @@ struct request_pm_state; | |||
30 | struct blk_trace; | 30 | struct blk_trace; |
31 | struct request; | 31 | struct request; |
32 | struct sg_io_hdr; | 32 | struct sg_io_hdr; |
33 | struct bsg_job; | ||
33 | 34 | ||
34 | #define BLKDEV_MIN_RQ 4 | 35 | #define BLKDEV_MIN_RQ 4 |
35 | #define BLKDEV_MAX_RQ 128 /* Default maximum */ | 36 | #define BLKDEV_MAX_RQ 128 /* Default maximum */ |
@@ -209,6 +210,7 @@ typedef int (merge_bvec_fn) (struct request_queue *, struct bvec_merge_data *, | |||
209 | typedef void (softirq_done_fn)(struct request *); | 210 | typedef void (softirq_done_fn)(struct request *); |
210 | typedef int (dma_drain_needed_fn)(struct request *); | 211 | typedef int (dma_drain_needed_fn)(struct request *); |
211 | typedef int (lld_busy_fn) (struct request_queue *q); | 212 | typedef int (lld_busy_fn) (struct request_queue *q); |
213 | typedef int (bsg_job_fn) (struct bsg_job *); | ||
212 | 214 | ||
213 | enum blk_eh_timer_return { | 215 | enum blk_eh_timer_return { |
214 | BLK_EH_NOT_HANDLED, | 216 | BLK_EH_NOT_HANDLED, |
@@ -375,6 +377,8 @@ struct request_queue { | |||
375 | struct mutex sysfs_lock; | 377 | struct mutex sysfs_lock; |
376 | 378 | ||
377 | #if defined(CONFIG_BLK_DEV_BSG) | 379 | #if defined(CONFIG_BLK_DEV_BSG) |
380 | bsg_job_fn *bsg_job_fn; | ||
381 | int bsg_job_size; | ||
378 | struct bsg_class_device bsg_dev; | 382 | struct bsg_class_device bsg_dev; |
379 | #endif | 383 | #endif |
380 | 384 | ||