]> git.hungrycats.org Git - linux/commitdiff
Revert "Add an ioctl to set/retrive the device properties"
authorZygo Blaxell <ce3g8jdj@umail.furryterror.org>
Sun, 5 Dec 2021 08:37:29 +0000 (03:37 -0500)
committerZygo Blaxell <ce3g8jdj@umail.furryterror.org>
Sun, 5 Dec 2021 08:37:29 +0000 (03:37 -0500)
This reverts commit b3850568a1748fa94393239877f47db5f7a643e1.

fs/btrfs/ioctl.c
fs/btrfs/volumes.c
fs/btrfs/volumes.h
include/uapi/linux/btrfs.h

index c8bd7fa37181b5657c9a3c9fe44c7fd735148223..2a7cda0bcb1434606a1389d5102571eeb5ad211d 100644 (file)
@@ -4834,71 +4834,6 @@ out_drop_write:
        return ret;
 }
 
-static long btrfs_ioctl_dev_properties(struct file *file,
-                                               void __user *argp)
-{
-       struct inode *inode = file_inode(file);
-       struct btrfs_fs_info *fs_info = btrfs_sb(inode->i_sb);
-       struct btrfs_ioctl_dev_properties dev_props;
-       struct btrfs_device     *device;
-        struct btrfs_root *root = fs_info->chunk_root;
-        struct btrfs_trans_handle *trans;
-       int ret;
-       u64 prev_type;
-
-       if (!capable(CAP_SYS_ADMIN))
-               return -EPERM;
-
-       if (copy_from_user(&dev_props, argp, sizeof(dev_props)))
-               return -EFAULT;
-
-       device = btrfs_find_device(fs_info->fs_devices, dev_props.devid,
-                               NULL, NULL, false);
-       if (!device) {
-               btrfs_info(fs_info, "change_dev_properties: unable to find device %llu",
-                          dev_props.devid);
-               return -ENODEV;
-       }
-
-       if (dev_props.properties & BTRFS_DEV_PROPERTY_READ) {
-               u64 props = dev_props.properties;
-               memset(&dev_props, 0, sizeof(dev_props));
-               if (props & BTRFS_DEV_PROPERTY_TYPE) {
-                       dev_props.properties = BTRFS_DEV_PROPERTY_TYPE;
-                       dev_props.type = device->type;
-               }
-               if(copy_to_user(argp, &dev_props, sizeof(dev_props)))
-                       return -EFAULT;
-               return 0;
-       }
-
-       /* it is possible to set only BTRFS_DEV_PROPERTY_TYPE for now */
-       if (dev_props.properties & ~(BTRFS_DEV_PROPERTY_TYPE))
-               return -EPERM;
-
-       trans = btrfs_start_transaction(root, 0);
-        if (IS_ERR(trans))
-                return PTR_ERR(trans);
-
-       prev_type = device->type;
-       device->type = dev_props.type;
-       ret = btrfs_update_device(trans, device);
-
-        if (ret < 0) {
-                btrfs_abort_transaction(trans, ret);
-                btrfs_end_transaction(trans);
-               device->type = prev_type;
-               return  ret;
-        }
-
-        ret = btrfs_commit_transaction(trans);
-       if (ret < 0)
-               device->type = prev_type;
-
-       return ret;
-
-}
-
 static int _btrfs_ioctl_send(struct file *file, void __user *argp, bool compat)
 {
        struct btrfs_ioctl_send_args *arg;
@@ -5074,8 +5009,6 @@ long btrfs_ioctl(struct file *file, unsigned int
                return btrfs_ioctl_get_subvol_rootref(file, argp);
        case BTRFS_IOC_INO_LOOKUP_USER:
                return btrfs_ioctl_ino_lookup_user(file, argp);
-       case BTRFS_IOC_DEV_PROPERTIES:
-               return btrfs_ioctl_dev_properties(file, argp);
        }
 
        return -ENOTTY;
index d96a5e12b58c103ef8e110b59ca082e1fa7957d5..9e4e84462757ad06ad68b6b446c30149b67608f4 100644 (file)
@@ -2812,7 +2812,7 @@ error:
        return ret;
 }
 
-int btrfs_update_device(struct btrfs_trans_handle *trans,
+static noinline int btrfs_update_device(struct btrfs_trans_handle *trans,
                                        struct btrfs_device *device)
 {
        int ret;
index 8350202e22e15bb0f283e31db463a3634bbfa61d..d5cb6cdace8b8887025f95171d33436052afe22a 100644 (file)
@@ -606,7 +606,5 @@ int btrfs_bg_type_to_factor(u64 flags);
 const char *btrfs_bg_type_to_raid_name(u64 flags);
 int btrfs_verify_dev_extents(struct btrfs_fs_info *fs_info);
 int btrfs_repair_one_zone(struct btrfs_fs_info *fs_info, u64 logical);
-int btrfs_update_device(struct btrfs_trans_handle *trans,
-                                        struct btrfs_device *device);
 
 #endif
index 79c8ad631fc6701bb95ee8255d7c5a8b659bb2b8..561af6f7ac6fc68f89e8222961c877967490ff93 100644 (file)
@@ -863,44 +863,6 @@ struct btrfs_ioctl_get_subvol_rootref_args {
                __u8 align[7];
 };
 
-#define BTRFS_DEV_PROPERTY_TYPE                (1ULL << 0)
-#define BTRFS_DEV_PROPERTY_DEV_GROUP   (1ULL << 1)
-#define BTRFS_DEV_PROPERTY_SEEK_SPEED  (1ULL << 2)
-#define BTRFS_DEV_PROPERTY_BANDWIDTH   (1ULL << 3)
-#define BTRFS_DEV_PROPERTY_READ                (1ULL << 60)
-
-/*
- * The ioctl BTRFS_IOC_DEV_PROPERTIES can read and write the device properties.
- *
- * The properties that the user want to write have to be set
- * in the 'properties' field using the BTRFS_DEV_PROPERTY_xxxx constants.
- *
- * If the ioctl is used to read the device properties, the bit
- * BTRFS_DEV_PROPERTY_READ has to be set in the 'properties' field.
- * In this case the properties that the user want have to be set in the
- * 'properties' field. The kernel doesn't return a property that was not
- * required, however it may return a subset of the requested properties.
- * The returned properties have the corrispondent BTRFS_DEV_PROPERTY_xxxx
- * flag set in the 'properties' field.
- *
- * Up to 2020/05/11 the only properties that can be read/write is the 'type'
- * one.
- */
-struct btrfs_ioctl_dev_properties {
-       __u64   devid;
-       __u64   properties;
-       __u64   type;
-       __u32   dev_group;
-       __u8    seek_speed;
-       __u8    bandwidth;
-
-       /*
-        * for future expansion
-        */
-       __u8    unused1[2];
-       __u64   unused2[4];
-};
-
 /* Error codes as returned by the kernel */
 enum btrfs_err_code {
        BTRFS_ERROR_DEV_RAID1_MIN_NOT_MET = 1,
@@ -1029,7 +991,5 @@ enum btrfs_err_code {
                                struct btrfs_ioctl_ino_lookup_user_args)
 #define BTRFS_IOC_SNAP_DESTROY_V2 _IOW(BTRFS_IOCTL_MAGIC, 63, \
                                struct btrfs_ioctl_vol_args_v2)
-#define BTRFS_IOC_DEV_PROPERTIES _IOW(BTRFS_IOCTL_MAGIC, 64, \
-                               struct btrfs_ioctl_dev_properties)
 
 #endif /* _UAPI_LINUX_BTRFS_H */