aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/block
diff options
context:
space:
mode:
authorAlex Elder <elder@inktank.com>2013-02-08 10:55:48 -0500
committerAlex Elder <elder@inktank.com>2013-02-19 20:14:03 -0500
commitfbfab53966b279f9cdb36b96ffa1e22f042c96ff (patch)
tree4f3acf06a4dd61eeeee16119b5f65290c4200bde /drivers/block
parentef06f4d32ae5b656f17b53ee3f3c43471a11cc73 (diff)
libceph: allow STAT osd operations
Add support for CEPH_OSD_OP_STAT operations in the osd client and in rbd. This operation sends no data to the osd; everything required is encoded in identity of the target object. The result will be ENOENT if the object doesn't exist. If it does exist and no other error occurs the server returns the size and last modification time of the target object as output data (in little endian format). The size is a 64 bit unsigned and the time is ceph_timespec structure (two unsigned 32-bit integers, representing a seconds and nanoseconds value). This resolves: http://tracker.ceph.com/issues/4007 Signed-off-by: Alex Elder <elder@inktank.com> Reviewed-by: Josh Durgin <josh.durgin@inktank.com>
Diffstat (limited to 'drivers/block')
-rw-r--r--drivers/block/rbd.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c
index ff9e9255745c..09514d9d8a97 100644
--- a/drivers/block/rbd.c
+++ b/drivers/block/rbd.c
@@ -1148,6 +1148,8 @@ struct ceph_osd_req_op *rbd_osd_req_op_create(u16 opcode, ...)
1148 if (opcode == CEPH_OSD_OP_WRITE) 1148 if (opcode == CEPH_OSD_OP_WRITE)
1149 op->payload_len = op->extent.length; 1149 op->payload_len = op->extent.length;
1150 break; 1150 break;
1151 case CEPH_OSD_OP_STAT:
1152 break;
1151 case CEPH_OSD_OP_CALL: 1153 case CEPH_OSD_OP_CALL:
1152 /* rbd_osd_req_op_create(CALL, class, method, data, datalen) */ 1154 /* rbd_osd_req_op_create(CALL, class, method, data, datalen) */
1153 op->cls.class_name = va_arg(args, char *); 1155 op->cls.class_name = va_arg(args, char *);
@@ -1277,6 +1279,16 @@ static void rbd_osd_write_callback(struct rbd_obj_request *obj_request,
1277 obj_request_done_set(obj_request); 1279 obj_request_done_set(obj_request);
1278} 1280}
1279 1281
1282/*
1283 * For a simple stat call there's nothing to do. We'll do more if
1284 * this is part of a write sequence for a layered image.
1285 */
1286static void rbd_osd_stat_callback(struct rbd_obj_request *obj_request,
1287 struct ceph_osd_op *op)
1288{
1289 obj_request_done_set(obj_request);
1290}
1291
1280static void rbd_osd_req_callback(struct ceph_osd_request *osd_req, 1292static void rbd_osd_req_callback(struct ceph_osd_request *osd_req,
1281 struct ceph_msg *msg) 1293 struct ceph_msg *msg)
1282{ 1294{
@@ -1307,6 +1319,9 @@ static void rbd_osd_req_callback(struct ceph_osd_request *osd_req,
1307 case CEPH_OSD_OP_WRITE: 1319 case CEPH_OSD_OP_WRITE:
1308 rbd_osd_write_callback(obj_request, op); 1320 rbd_osd_write_callback(obj_request, op);
1309 break; 1321 break;
1322 case CEPH_OSD_OP_STAT:
1323 rbd_osd_stat_callback(obj_request, op);
1324 break;
1310 case CEPH_OSD_OP_CALL: 1325 case CEPH_OSD_OP_CALL:
1311 case CEPH_OSD_OP_NOTIFY_ACK: 1326 case CEPH_OSD_OP_NOTIFY_ACK:
1312 case CEPH_OSD_OP_WATCH: 1327 case CEPH_OSD_OP_WATCH: