Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 359578
b: refs/heads/master
c: b395e8b
h: refs/heads/master
v: v3
  • Loading branch information
Alex Elder authored and Alex Elder committed Jan 17, 2013
1 parent 02b46cf commit 64424ba
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 27 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: cd323ac0eb433b14cbb270bfc5a82f308f2662de
refs/heads/master: b395e8b5b8f06399e3fe3ee016c9cf41ff665efc
50 changes: 24 additions & 26 deletions trunk/drivers/block/rbd.c
Original file line number Diff line number Diff line change
Expand Up @@ -1644,53 +1644,51 @@ static int rbd_dev_do_request(struct request *rq,
static void rbd_rq_fn(struct request_queue *q)
{
struct rbd_device *rbd_dev = q->queuedata;
bool read_only = rbd_dev->mapping.read_only;
struct request *rq;

while ((rq = blk_fetch_request(q))) {
struct bio *bio;
bool do_write;
unsigned int size;
u64 ofs;
struct ceph_snap_context *snapc;
struct ceph_snap_context *snapc = NULL;
unsigned int size = 0;
int result;

dout("fetched request\n");

/* filter out block requests we don't understand */
/* Filter out block requests we don't understand */

if ((rq->cmd_type != REQ_TYPE_FS)) {
__blk_end_request_all(rq, 0);
continue;
}
spin_unlock_irq(q->queue_lock);

/* deduce our operation (read, write) */
do_write = (rq_data_dir(rq) == WRITE);
if (do_write && rbd_dev->mapping.read_only) {
__blk_end_request_all(rq, -EROFS);
continue;
}
/* Stop writes to a read-only device */

spin_unlock_irq(q->queue_lock);
result = -EROFS;
if (read_only && rq_data_dir(rq) == WRITE)
goto out_end_request;

/* Grab a reference to the snapshot context */

down_read(&rbd_dev->header_rwsem);
if (rbd_dev->exists) {
snapc = ceph_get_snap_context(rbd_dev->header.snapc);
rbd_assert(snapc != NULL);
}
up_read(&rbd_dev->header_rwsem);

if (!rbd_dev->exists) {
if (!snapc) {
rbd_assert(rbd_dev->spec->snap_id != CEPH_NOSNAP);
up_read(&rbd_dev->header_rwsem);
dout("request for non-existent snapshot");
spin_lock_irq(q->queue_lock);
__blk_end_request_all(rq, -ENXIO);
continue;
result = -ENXIO;
goto out_end_request;
}

snapc = ceph_get_snap_context(rbd_dev->header.snapc);

up_read(&rbd_dev->header_rwsem);

size = blk_rq_bytes(rq);
ofs = blk_rq_pos(rq) * SECTOR_SIZE;
bio = rq->bio;

result = rbd_dev_do_request(rq, rbd_dev, snapc, ofs, size, bio);
result = rbd_dev_do_request(rq, rbd_dev, snapc,
blk_rq_pos(rq) * SECTOR_SIZE,
size, rq->bio);
out_end_request:
ceph_put_snap_context(snapc);
spin_lock_irq(q->queue_lock);
if (!size || result < 0)
Expand Down

0 comments on commit 64424ba

Please sign in to comment.