ceph: return EIO on invalid layout on GET_DATALOC ioctl
authorSage Weil <sage@inktank.com>
Tue, 25 Sep 2012 04:04:57 +0000 (21:04 -0700)
committerAlex Elder <elder@inktank.com>
Wed, 3 Oct 2012 15:51:17 +0000 (10:51 -0500)
If the user calls GET_DATALOC on a file with an invalid (e.g.,
zeroed) layout, return EIO to userland.

Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Alex Elder <elder@inktank.com>
fs/ceph/ioctl.c

index 1396ceb46797400c124ac80880f31a90583d0e4b..36549a46e311cc7f7b717634e5723dbeddb58f5f 100644 (file)
@@ -187,14 +187,18 @@ static long ceph_ioctl_get_dataloc(struct file *file, void __user *arg)
        u64 tmp;
        struct ceph_object_layout ol;
        struct ceph_pg pgid;
+       int r;
 
        /* copy and validate */
        if (copy_from_user(&dl, arg, sizeof(dl)))
                return -EFAULT;
 
        down_read(&osdc->map_sem);
-       ceph_calc_file_object_mapping(&ci->i_layout, dl.file_offset, &len,
-                                     &dl.object_no, &dl.object_offset, &olen);
+       r = ceph_calc_file_object_mapping(&ci->i_layout, dl.file_offset, &len,
+                                         &dl.object_no, &dl.object_offset,
+                                         &olen);
+       if (r < 0)
+               return -EIO;
        dl.file_offset -= dl.object_offset;
        dl.object_size = ceph_file_layout_object_size(ci->i_layout);
        dl.block_size = ceph_file_layout_su(ci->i_layout);