if (!reply_buf)
                return ERR_PTR(-ENOMEM);
 
+       rbd_assert(which < rbd_dev->header.snapc->num_snaps);
        snap_id = cpu_to_le64(rbd_dev->header.snapc->snaps[which]);
        ret = rbd_obj_method_sync(rbd_dev, rbd_dev->header_name,
                                "rbd", "get_snapshot_name",
                u64 *snap_size, u64 *snap_features)
 {
        u64 snap_id;
+       u64 size;
+       u64 features;
+       char *snap_name;
        int ret;
 
+       rbd_assert(which < rbd_dev->header.snapc->num_snaps);
        snap_id = rbd_dev->header.snapc->snaps[which];
-       ret = _rbd_dev_v2_snap_size(rbd_dev, snap_id, NULL, snap_size);
+       ret = _rbd_dev_v2_snap_size(rbd_dev, snap_id, NULL, &size);
        if (ret)
-               return ERR_PTR(ret);
-       ret = _rbd_dev_v2_snap_features(rbd_dev, snap_id, snap_features);
+               goto out_err;
+
+       ret = _rbd_dev_v2_snap_features(rbd_dev, snap_id, &features);
        if (ret)
-               return ERR_PTR(ret);
+               goto out_err;
+
+       snap_name = rbd_dev_v2_snap_name(rbd_dev, which);
+       if (!IS_ERR(snap_name)) {
+               *snap_size = size;
+               *snap_features = features;
+       }
 
-       return rbd_dev_v2_snap_name(rbd_dev, which);
+       return snap_name;
+out_err:
+       return ERR_PTR(ret);
 }
 
 static char *rbd_dev_snap_info(struct rbd_device *rbd_dev, u32 which,