Commit 7c3d22cf authored by Alex Elder's avatar Alex Elder

rbd: don't bother setting snapid in rbd_do_request()

For some reason, the snapid field of the osd request header is
explicitly set to CEPH_NOSNAP in rbd_do_request().  Just a few lines
later--with no code that would access this field in between--a call
is made to ceph_calc_raw_layout() passing the snapid provided to
rbd_do_request(), which encodes the snapid value it is provided into
that field instead.

In other words, there is no need to fill in CEPH_NOSNAP, and doing
so suggests it might be necessary.  Don't do that any more.
Signed-off-by: default avatarAlex Elder <elder@inktank.com>
Reviewed-by: default avatarJosh Durgin <josh.durgin@inktank.com>
parent 25704ac9
...@@ -1132,7 +1132,6 @@ static int rbd_do_request(struct request *rq, ...@@ -1132,7 +1132,6 @@ static int rbd_do_request(struct request *rq,
u64 bno; u64 bno;
struct timespec mtime = CURRENT_TIME; struct timespec mtime = CURRENT_TIME;
struct rbd_request *rbd_req; struct rbd_request *rbd_req;
struct ceph_osd_request_head *reqhead;
struct ceph_osd_client *osdc; struct ceph_osd_client *osdc;
rbd_req = kzalloc(sizeof(*rbd_req), GFP_NOIO); rbd_req = kzalloc(sizeof(*rbd_req), GFP_NOIO);
...@@ -1165,9 +1164,6 @@ static int rbd_do_request(struct request *rq, ...@@ -1165,9 +1164,6 @@ static int rbd_do_request(struct request *rq,
osd_req->r_priv = rbd_req; osd_req->r_priv = rbd_req;
reqhead = osd_req->r_request->front.iov_base;
reqhead->snapid = cpu_to_le64(CEPH_NOSNAP);
strncpy(osd_req->r_oid, object_name, sizeof(osd_req->r_oid)); strncpy(osd_req->r_oid, object_name, sizeof(osd_req->r_oid));
osd_req->r_oid_len = strlen(osd_req->r_oid); osd_req->r_oid_len = strlen(osd_req->r_oid);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment