aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--block/blk-core.c23
-rw-r--r--include/linux/blkdev.h4
2 files changed, 20 insertions, 7 deletions
diff --git a/block/blk-core.c b/block/blk-core.c
index 4afb39c82339..fba4ca7c6086 100644
--- a/block/blk-core.c
+++ b/block/blk-core.c
@@ -102,27 +102,38 @@ struct backing_dev_info *blk_get_backing_dev_info(struct block_device *bdev)
102} 102}
103EXPORT_SYMBOL(blk_get_backing_dev_info); 103EXPORT_SYMBOL(blk_get_backing_dev_info);
104 104
105/*
106 * We can't just memset() the structure, since the allocation path
107 * already stored some information in the request.
108 */
105void rq_init(struct request_queue *q, struct request *rq) 109void rq_init(struct request_queue *q, struct request *rq)
106{ 110{
107 INIT_LIST_HEAD(&rq->queuelist); 111 INIT_LIST_HEAD(&rq->queuelist);
108 INIT_LIST_HEAD(&rq->donelist); 112 INIT_LIST_HEAD(&rq->donelist);
109 113 rq->q = q;
110 rq->errors = 0; 114 rq->sector = rq->hard_sector = (sector_t) -1;
115 rq->nr_sectors = rq->hard_nr_sectors = 0;
116 rq->current_nr_sectors = rq->hard_cur_sectors = 0;
111 rq->bio = rq->biotail = NULL; 117 rq->bio = rq->biotail = NULL;
112 INIT_HLIST_NODE(&rq->hash); 118 INIT_HLIST_NODE(&rq->hash);
113 RB_CLEAR_NODE(&rq->rb_node); 119 RB_CLEAR_NODE(&rq->rb_node);
120 rq->rq_disk = NULL;
121 rq->nr_phys_segments = 0;
122 rq->nr_hw_segments = 0;
114 rq->ioprio = 0; 123 rq->ioprio = 0;
124 rq->special = NULL;
115 rq->buffer = NULL; 125 rq->buffer = NULL;
126 rq->tag = -1;
127 rq->errors = 0;
116 rq->ref_count = 1; 128 rq->ref_count = 1;
117 rq->q = q; 129 rq->cmd_len = 0;
118 rq->special = NULL; 130 memset(rq->cmd, 0, sizeof(rq->cmd));
119 rq->data_len = 0; 131 rq->data_len = 0;
132 rq->sense_len = 0;
120 rq->data = NULL; 133 rq->data = NULL;
121 rq->nr_phys_segments = 0;
122 rq->sense = NULL; 134 rq->sense = NULL;
123 rq->end_io = NULL; 135 rq->end_io = NULL;
124 rq->end_io_data = NULL; 136 rq->end_io_data = NULL;
125 rq->completion_data = NULL;
126 rq->next_rq = NULL; 137 rq->next_rq = NULL;
127} 138}
128 139
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h
index 90392a9d7a9c..e1888cc5b8ae 100644
--- a/include/linux/blkdev.h
+++ b/include/linux/blkdev.h
@@ -137,7 +137,9 @@ enum rq_flag_bits {
137#define BLK_MAX_CDB 16 137#define BLK_MAX_CDB 16
138 138
139/* 139/*
140 * try to put the fields that are referenced together in the same cacheline 140 * try to put the fields that are referenced together in the same cacheline.
141 * if you modify this structure, be sure to check block/blk-core.c:rq_init()
142 * as well!
141 */ 143 */
142struct request { 144struct request {
143 struct list_head queuelist; 145 struct list_head queuelist;