aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/osd
diff options
context:
space:
mode:
authorJames Bottomley <James.Bottomley@HansenPartnership.com>2009-06-12 11:02:03 -0400
committerJames Bottomley <James.Bottomley@HansenPartnership.com>2009-06-12 11:02:03 -0400
commit82681a318f9f028ea64e61f24bbd9ac535531921 (patch)
tree529b6a5b4fd040fb54b7672b1a224ebd47445876 /drivers/scsi/osd
parent3860c97bd60a4525bb62eb90e3e7d2f02662ac59 (diff)
parent8ebf975608aaebd7feb33d77f07ba21a6380e086 (diff)
[SCSI] Merge branch 'linus'
Conflicts: drivers/message/fusion/mptsas.c fixed up conflict between req->data_len accessors and mptsas driver updates. Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
Diffstat (limited to 'drivers/scsi/osd')
-rw-r--r--drivers/scsi/osd/osd_initiator.c72
1 files changed, 25 insertions, 47 deletions
diff --git a/drivers/scsi/osd/osd_initiator.c b/drivers/scsi/osd/osd_initiator.c
index 71341ad3234..7a117c18114 100644
--- a/drivers/scsi/osd/osd_initiator.c
+++ b/drivers/scsi/osd/osd_initiator.c
@@ -921,26 +921,6 @@ int osd_req_add_set_attr_list(struct osd_request *or,
921} 921}
922EXPORT_SYMBOL(osd_req_add_set_attr_list); 922EXPORT_SYMBOL(osd_req_add_set_attr_list);
923 923
924static int _append_map_kern(struct request *req,
925 void *buff, unsigned len, gfp_t flags)
926{
927 struct bio *bio;
928 int ret;
929
930 bio = bio_map_kern(req->q, buff, len, flags);
931 if (IS_ERR(bio)) {
932 OSD_ERR("Failed bio_map_kern(%p, %d) => %ld\n", buff, len,
933 PTR_ERR(bio));
934 return PTR_ERR(bio);
935 }
936 ret = blk_rq_append_bio(req->q, req, bio);
937 if (ret) {
938 OSD_ERR("Failed blk_rq_append_bio(%p) => %d\n", bio, ret);
939 bio_put(bio);
940 }
941 return ret;
942}
943
944static int _req_append_segment(struct osd_request *or, 924static int _req_append_segment(struct osd_request *or,
945 unsigned padding, struct _osd_req_data_segment *seg, 925 unsigned padding, struct _osd_req_data_segment *seg,
946 struct _osd_req_data_segment *last_seg, struct _osd_io_info *io) 926 struct _osd_req_data_segment *last_seg, struct _osd_io_info *io)
@@ -956,14 +936,14 @@ static int _req_append_segment(struct osd_request *or,
956 else 936 else
957 pad_buff = io->pad_buff; 937 pad_buff = io->pad_buff;
958 938
959 ret = _append_map_kern(io->req, pad_buff, padding, 939 ret = blk_rq_map_kern(io->req->q, io->req, pad_buff, padding,
960 or->alloc_flags); 940 or->alloc_flags);
961 if (ret) 941 if (ret)
962 return ret; 942 return ret;
963 io->total_bytes += padding; 943 io->total_bytes += padding;
964 } 944 }
965 945
966 ret = _append_map_kern(io->req, seg->buff, seg->total_bytes, 946 ret = blk_rq_map_kern(io->req->q, io->req, seg->buff, seg->total_bytes,
967 or->alloc_flags); 947 or->alloc_flags);
968 if (ret) 948 if (ret)
969 return ret; 949 return ret;
@@ -1324,6 +1304,21 @@ static int _osd_req_finalize_data_integrity(struct osd_request *or,
1324/* 1304/*
1325 * osd_finalize_request and helpers 1305 * osd_finalize_request and helpers
1326 */ 1306 */
1307static struct request *_make_request(struct request_queue *q, bool has_write,
1308 struct _osd_io_info *oii, gfp_t flags)
1309{
1310 if (oii->bio)
1311 return blk_make_request(q, oii->bio, flags);
1312 else {
1313 struct request *req;
1314
1315 req = blk_get_request(q, has_write ? WRITE : READ, flags);
1316 if (unlikely(!req))
1317 return ERR_PTR(-ENOMEM);
1318
1319 return req;
1320 }
1321}
1327 1322
1328static int _init_blk_request(struct osd_request *or, 1323static int _init_blk_request(struct osd_request *or,
1329 bool has_in, bool has_out) 1324 bool has_in, bool has_out)
@@ -1332,11 +1327,13 @@ static int _init_blk_request(struct osd_request *or,
1332 struct scsi_device *scsi_device = or->osd_dev->scsi_device; 1327 struct scsi_device *scsi_device = or->osd_dev->scsi_device;
1333 struct request_queue *q = scsi_device->request_queue; 1328 struct request_queue *q = scsi_device->request_queue;
1334 struct request *req; 1329 struct request *req;
1335 int ret = -ENOMEM; 1330 int ret;
1336 1331
1337 req = blk_get_request(q, has_out, flags); 1332 req = _make_request(q, has_out, has_out ? &or->out : &or->in, flags);
1338 if (!req) 1333 if (IS_ERR(req)) {
1334 ret = PTR_ERR(req);
1339 goto out; 1335 goto out;
1336 }
1340 1337
1341 or->request = req; 1338 or->request = req;
1342 req->cmd_type = REQ_TYPE_BLOCK_PC; 1339 req->cmd_type = REQ_TYPE_BLOCK_PC;
@@ -1351,9 +1348,10 @@ static int _init_blk_request(struct osd_request *or,
1351 or->out.req = req; 1348 or->out.req = req;
1352 if (has_in) { 1349 if (has_in) {
1353 /* allocate bidi request */ 1350 /* allocate bidi request */
1354 req = blk_get_request(q, READ, flags); 1351 req = _make_request(q, false, &or->in, flags);
1355 if (!req) { 1352 if (IS_ERR(req)) {
1356 OSD_DEBUG("blk_get_request for bidi failed\n"); 1353 OSD_DEBUG("blk_get_request for bidi failed\n");
1354 ret = PTR_ERR(req);
1357 goto out; 1355 goto out;
1358 } 1356 }
1359 req->cmd_type = REQ_TYPE_BLOCK_PC; 1357 req->cmd_type = REQ_TYPE_BLOCK_PC;
@@ -1398,26 +1396,6 @@ int osd_finalize_request(struct osd_request *or,
1398 return ret; 1396 return ret;
1399 } 1397 }
1400 1398
1401 if (or->out.bio) {
1402 ret = blk_rq_append_bio(or->request->q, or->out.req,
1403 or->out.bio);
1404 if (ret) {
1405 OSD_DEBUG("blk_rq_append_bio out failed\n");
1406 return ret;
1407 }
1408 OSD_DEBUG("out bytes=%llu (bytes_req=%u)\n",
1409 _LLU(or->out.total_bytes), or->out.req->data_len);
1410 }
1411 if (or->in.bio) {
1412 ret = blk_rq_append_bio(or->request->q, or->in.req, or->in.bio);
1413 if (ret) {
1414 OSD_DEBUG("blk_rq_append_bio in failed\n");
1415 return ret;
1416 }
1417 OSD_DEBUG("in bytes=%llu (bytes_req=%u)\n",
1418 _LLU(or->in.total_bytes), or->in.req->data_len);
1419 }
1420
1421 or->out.pad_buff = sg_out_pad_buffer; 1399 or->out.pad_buff = sg_out_pad_buffer;
1422 or->in.pad_buff = sg_in_pad_buffer; 1400 or->in.pad_buff = sg_in_pad_buffer;
1423 1401