mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-18 19:56:07 +07:00
rbd: remove obj_req->flags field
There are no standalone (!IMG_DATA) object requests anymore. Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
This commit is contained in:
parent
15961b4494
commit
0be2d60ed8
@ -222,10 +222,6 @@ enum obj_operation_type {
|
||||
OBJ_OP_DISCARD,
|
||||
};
|
||||
|
||||
enum obj_req_flags {
|
||||
OBJ_REQ_IMG_DATA, /* object usage: standalone = 0, image = 1 */
|
||||
};
|
||||
|
||||
/*
|
||||
* Writes go through the following state machine to deal with
|
||||
* layering:
|
||||
@ -252,16 +248,11 @@ struct rbd_obj_request {
|
||||
u64 object_no;
|
||||
u64 offset; /* object start byte */
|
||||
u64 length; /* bytes from offset */
|
||||
unsigned long flags;
|
||||
union {
|
||||
bool tried_parent; /* for reads */
|
||||
enum rbd_obj_write_state write_state; /* for writes */
|
||||
};
|
||||
|
||||
/*
|
||||
* An object request associated with an image will have its
|
||||
* img_data flag set; a standalone object request will not.
|
||||
*/
|
||||
struct rbd_img_request *img_request;
|
||||
u64 img_offset;
|
||||
/* links for img_request->obj_requests list */
|
||||
@ -1291,28 +1282,6 @@ static void rbd_obj_zero_range(struct rbd_obj_request *obj_req, u32 off,
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* The default/initial value for all object request flags is 0. For
|
||||
* each flag, once its value is set to 1 it is never reset to 0
|
||||
* again.
|
||||
*/
|
||||
static void obj_request_img_data_set(struct rbd_obj_request *obj_request)
|
||||
{
|
||||
if (test_and_set_bit(OBJ_REQ_IMG_DATA, &obj_request->flags)) {
|
||||
struct rbd_device *rbd_dev;
|
||||
|
||||
rbd_dev = obj_request->img_request->rbd_dev;
|
||||
rbd_warn(rbd_dev, "obj_request %p already marked img_data",
|
||||
obj_request);
|
||||
}
|
||||
}
|
||||
|
||||
static bool obj_request_img_data_test(struct rbd_obj_request *obj_request)
|
||||
{
|
||||
smp_mb();
|
||||
return test_bit(OBJ_REQ_IMG_DATA, &obj_request->flags) != 0;
|
||||
}
|
||||
|
||||
static bool obj_request_overlaps_parent(struct rbd_obj_request *obj_request)
|
||||
{
|
||||
struct rbd_device *rbd_dev = obj_request->img_request->rbd_dev;
|
||||
@ -1365,8 +1334,6 @@ static inline void rbd_img_obj_request_add(struct rbd_img_request *img_request,
|
||||
|
||||
/* Image request now owns object's original reference */
|
||||
obj_request->img_request = img_request;
|
||||
rbd_assert(!obj_request_img_data_test(obj_request));
|
||||
obj_request_img_data_set(obj_request);
|
||||
img_request->obj_request_count++;
|
||||
img_request->pending_count++;
|
||||
list_add_tail(&obj_request->links, &img_request->obj_requests);
|
||||
@ -1380,7 +1347,6 @@ static inline void rbd_img_obj_request_del(struct rbd_img_request *img_request,
|
||||
list_del(&obj_request->links);
|
||||
rbd_assert(img_request->obj_request_count > 0);
|
||||
img_request->obj_request_count--;
|
||||
rbd_assert(obj_request_img_data_test(obj_request));
|
||||
rbd_assert(obj_request->img_request == img_request);
|
||||
obj_request->img_request = NULL;
|
||||
rbd_obj_request_put(obj_request);
|
||||
@ -1506,7 +1472,6 @@ static void rbd_osd_req_format_read(struct rbd_obj_request *obj_request)
|
||||
{
|
||||
struct ceph_osd_request *osd_req = obj_request->osd_req;
|
||||
|
||||
rbd_assert(obj_request_img_data_test(obj_request));
|
||||
osd_req->r_flags = CEPH_OSD_FLAG_READ;
|
||||
osd_req->r_snapid = obj_request->img_request->snap_id;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user