On 2/23/21 5:28 AM, kernel test robot wrote:
Hi Goffredo,

Thank you for the patch! Perhaps something to improve:

[auto build test WARNING on kdave/for-next]
[also build test WARNING on next-20210222]
[cannot apply to v5.11]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use '--base' as documented in
https://git-scm.com/docs/git-format-patch]

url:    
https://github.com/0day-ci/linux/commits/Goffredo-Baroncelli/btrfs-add-ioctl-BTRFS_IOC_DEV_PROPERTIES/20210223-062001
base:   https://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux.git for-next
config: i386-randconfig-r011-20210222 (attached as .config)
compiler: gcc-9 (Debian 9.3.0-15) 9.3.0
reproduce (this is a W=1 build):
         # 
https://github.com/0day-ci/linux/commit/62c95ccebf2c45bb8e91d379b454dd720734da34
         git remote add linux-review https://github.com/0day-ci/linux
         git fetch --no-tags linux-review 
Goffredo-Baroncelli/btrfs-add-ioctl-BTRFS_IOC_DEV_PROPERTIES/20210223-062001
         git checkout 62c95ccebf2c45bb8e91d379b454dd720734da34
         # save the attached .config to linux build tree
         make W=1 ARCH=i386

If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot <l...@intel.com>

All warnings (new ones prefixed by >>):

    fs/btrfs/ioctl.c: In function 'btrfs_ioctl_dev_properties':
fs/btrfs/ioctl.c:4923:1: warning: the frame size of 1036 bytes is larger than 
1024 bytes [-Wframe-larger-than=]
     4923 | }
          | ^


vim +4923 fs/btrfs/ioctl.c

   4858 
   4859 static long btrfs_ioctl_dev_properties(struct file *file,
   4860                                                 void __user *argp)
   4861 {
   4862         struct inode *inode = file_inode(file);
   4863         struct btrfs_fs_info *fs_info = btrfs_sb(inode->i_sb);
   4864         struct btrfs_ioctl_dev_properties dev_props;

Right, now that btrfs_ioctl_dev_properties is large 1k, it is not nice to store 
it in the stack...


   4865         struct btrfs_device     *device;
   4866         struct btrfs_root *root = fs_info->chunk_root;
   4867         struct btrfs_trans_handle *trans;
   4868         int ret;
   4869         u64 prev_type;
   4870 
   4871         if (!capable(CAP_SYS_ADMIN))
   4872                 return -EPERM;
   4873 
   4874         if (copy_from_user(&dev_props, argp, sizeof(dev_props)))
   4875                 return -EFAULT;
   4876 
   4877         device = btrfs_find_device(fs_info->fs_devices, dev_props.devid,
   4878                                 NULL, NULL);
   4879         if (!device) {
   4880                 btrfs_info(fs_info, "change_dev_properties: unable to find 
device %llu",
   4881                            dev_props.devid);
   4882                 return -ENODEV;
   4883         }
   4884 
   4885         if (dev_props.properties & BTRFS_DEV_PROPERTY_READ) {
   4886                 u64 props = dev_props.properties;
   4887 
   4888                 memset(&dev_props, 0, sizeof(dev_props));
   4889                 if (props & BTRFS_DEV_PROPERTY_TYPE) {
   4890                         dev_props.properties = BTRFS_DEV_PROPERTY_TYPE;
   4891                         dev_props.type = device->type;
   4892                 }
   4893                 if (copy_to_user(argp, &dev_props, sizeof(dev_props)))
   4894                         return -EFAULT;
   4895                 return 0;
   4896         }
   4897 
   4898         /* it is possible to set only BTRFS_DEV_PROPERTY_TYPE for now */
   4899         if (dev_props.properties & ~(BTRFS_DEV_PROPERTY_TYPE))
   4900                 return -EPERM;
   4901 
   4902         trans = btrfs_start_transaction(root, 1);
   4903         if (IS_ERR(trans))
   4904                 return PTR_ERR(trans);
   4905 
   4906         prev_type = device->type;
   4907         device->type = dev_props.type;
   4908         ret = btrfs_update_device(trans, device);
   4909 
   4910         if (ret < 0) {
   4911                 btrfs_abort_transaction(trans, ret);
   4912                 btrfs_end_transaction(trans);
   4913                 device->type = prev_type;
   4914                 return  ret;
   4915         }
   4916 
   4917         ret = btrfs_commit_transaction(trans);
   4918         if (ret < 0)
   4919                 device->type = prev_type;
   4920 
   4921         return ret;
   4922 
4923    }
   4924 

---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-...@lists.01.org



--
gpg @keyserver.linux.it: Goffredo Baroncelli <kreijackATinwind.it>
Key fingerprint BBF5 1610 0B64 DAC6 5F7D  17B2 0EDA 9B37 8B82 E0B5

Reply via email to