]> git.apps.os.sepia.ceph.com Git - ceph.git/commitdiff
kclient: rewrite layout ioctls
authorSage Weil <sage@newdream.net>
Thu, 23 Jul 2009 17:39:17 +0000 (10:39 -0700)
committerSage Weil <sage@newdream.net>
Thu, 23 Jul 2009 18:50:35 +0000 (11:50 -0700)
src/kernel/ioctl.c
src/kernel/ioctl.h

index c60ef7b3d5d4d309162596906849d61388bdfc2c..bf5a9d9d4efc8a090aa0ced961ffc6d4d9776ada 100644 (file)
 static long ceph_ioctl_get_layout(struct file *file, void __user *arg)
 {
        struct ceph_inode_info *ci = ceph_inode(file->f_dentry->d_inode);
+       struct ceph_ioctl_layout l;
        int err;
 
        err = ceph_do_getattr(file->f_dentry->d_inode, CEPH_STAT_CAP_LAYOUT);
        if (!err) {
-               if (copy_to_user(arg, &ci->i_layout, sizeof(ci->i_layout)))
+               l.stripe_unit = ceph_file_layout_su(ci->i_layout);
+               l.stripe_count = ceph_file_layout_stripe_count(ci->i_layout);
+               l.object_size = ceph_file_layout_object_size(ci->i_layout);
+               l.data_pool = le32_to_cpu(ci->i_layout.fl_pg_pool);
+               if (copy_to_user(arg, &l, sizeof(l)))
                        return -EFAULT;
        }
 
@@ -30,20 +35,49 @@ static long ceph_ioctl_set_layout(struct file *file, void __user *arg)
        struct inode *parent_inode = file->f_dentry->d_parent->d_inode;
        struct ceph_mds_client *mdsc = &ceph_sb_to_client(inode->i_sb)->mdsc;
        struct ceph_mds_request *req;
-       struct ceph_file_layout layout;
-       int err;
+       struct ceph_ioctl_layout l;
+       int err, i;
 
        /* copy and validate */
-       if (copy_from_user(&layout, arg, sizeof(layout)))
+       if (copy_from_user(&l, arg, sizeof(l)))
                return -EFAULT;
 
+       if ((l.object_size & ~PAGE_MASK) ||
+           (l.stripe_unit & ~PAGE_MASK) ||
+           !l.stripe_unit ||
+           (l.object_size &&
+            (unsigned)l.object_size % (unsigned)l.stripe_unit)) 
+               return -EINVAL;
+
+       /* make sure it's a valid data pool */
+       if (l.data_pool > 0) {
+               mutex_lock(&mdsc->mutex);
+               err = -EINVAL;
+               for (i = 0; i < mdsc->mdsmap->m_num_data_pg_pools; i++)
+                       if (mdsc->mdsmap->m_data_pg_pools[i] == l.data_pool) {
+                               err = 0;
+                               break;
+                       }
+               mutex_unlock(&mdsc->mutex);
+               if (err)
+                       return err;
+       }
+
        req = ceph_mdsc_create_request(mdsc, CEPH_MDS_OP_SETLAYOUT,
                                       USE_AUTH_MDS);
        if (IS_ERR(req))
                return PTR_ERR(req);
        req->r_inode = igrab(inode);
        req->r_inode_drop = CEPH_CAP_FILE_SHARED | CEPH_CAP_FILE_EXCL;
-       req->r_args.setlayout.layout = layout;
+
+       req->r_args.setlayout.layout.fl_stripe_unit =
+               cpu_to_le32(l.stripe_unit);
+       req->r_args.setlayout.layout.fl_stripe_count =
+               cpu_to_le32(l.stripe_count);
+       req->r_args.setlayout.layout.fl_object_size =
+               cpu_to_le32(l.object_size);
+       req->r_args.setlayout.layout.fl_pg_pool = cpu_to_le32(l.data_pool);
+       req->r_args.setlayout.layout.fl_pg_preferred = cpu_to_le32((s32)-1);
 
        err = ceph_mdsc_do_request(mdsc, parent_inode, req);
        ceph_mdsc_put_request(req);
index 537c27bf05c0f899b4e1214e9ed1be97d8210200..56f5e2c318dd9c2111b7d462cc0b71c6e106f453 100644 (file)
@@ -2,11 +2,19 @@
 #define FS_CEPH_IOCTL_H
 
 #include <linux/ioctl.h>
-#include "types.h"
+#include <linux/types.h>
 
 #define CEPH_IOCTL_MAGIC 0x97
 
-#define CEPH_IOC_GET_LAYOUT _IOR(CEPH_IOCTL_MAGIC, 1, struct ceph_file_layout)
-#define CEPH_IOC_SET_LAYOUT _IOW(CEPH_IOCTL_MAGIC, 2, struct ceph_file_layout)
+/* just use u64 to align sanely on all archs */
+struct ceph_ioctl_layout {
+       __u64 stripe_unit, stripe_count, object_size;
+       __u64 data_pool;
+};
+
+#define CEPH_IOC_GET_LAYOUT _IOR(CEPH_IOCTL_MAGIC, 1,          \
+                                  struct ceph_ioctl_layout)
+#define CEPH_IOC_SET_LAYOUT _IOW(CEPH_IOCTL_MAGIC, 2,          \
+                                  struct ceph_ioctl_layout)
 
 #endif