Commit 845e30e6 authored by Ira Weiny's avatar Ira Weiny Committed by Greg Kroah-Hartman

staging/rdma/hfi1: Return early from hfi1_ioctl parameter errors

Rather than have a switch in a large else clause make the parameter checks
return immediately.
Signed-off-by: default avatarDennis Dalessandro <dennis.dalessandro@intel.com>
Signed-off-by: default avatarIra Weiny <ira.weiny@intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ae1724df
...@@ -987,17 +987,15 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg) ...@@ -987,17 +987,15 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg)
if (!dd) if (!dd)
return -ENODEV; return -ENODEV;
spin_lock_irqsave(&dd->hfi1_snoop.snoop_lock, flags);
mode_flag = dd->hfi1_snoop.mode_flag; mode_flag = dd->hfi1_snoop.mode_flag;
if (((_IOC_DIR(cmd) & _IOC_READ) if (((_IOC_DIR(cmd) & _IOC_READ)
&& !access_ok(VERIFY_WRITE, (void __user *)arg, _IOC_SIZE(cmd))) && !access_ok(VERIFY_WRITE, (void __user *)arg, _IOC_SIZE(cmd)))
|| ((_IOC_DIR(cmd) & _IOC_WRITE) || ((_IOC_DIR(cmd) & _IOC_WRITE)
&& !access_ok(VERIFY_READ, (void __user *)arg, _IOC_SIZE(cmd)))) { && !access_ok(VERIFY_READ, (void __user *)arg, _IOC_SIZE(cmd)))) {
ret = -EFAULT; return -EFAULT;
} else if (!capable(CAP_SYS_ADMIN)) { } else if (!capable(CAP_SYS_ADMIN)) {
ret = -EPERM; return -EPERM;
} else if ((mode_flag & HFI1_PORT_CAPTURE_MODE) && } else if ((mode_flag & HFI1_PORT_CAPTURE_MODE) &&
(cmd != HFI1_SNOOP_IOCCLEARQUEUE) && (cmd != HFI1_SNOOP_IOCCLEARQUEUE) &&
(cmd != HFI1_SNOOP_IOCCLEARFILTER) && (cmd != HFI1_SNOOP_IOCCLEARFILTER) &&
...@@ -1008,8 +1006,11 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg) ...@@ -1008,8 +1006,11 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg)
* 3.Set capture filter * 3.Set capture filter
* Other are invalid. * Other are invalid.
*/ */
ret = -EINVAL; return -EINVAL;
} else { }
spin_lock_irqsave(&dd->hfi1_snoop.snoop_lock, flags);
switch (cmd) { switch (cmd) {
case HFI1_SNOOP_IOCSETLINKSTATE: case HFI1_SNOOP_IOCSETLINKSTATE:
snoop_dbg("HFI1_SNOOP_IOCSETLINKSTATE is not valid"); snoop_dbg("HFI1_SNOOP_IOCSETLINKSTATE is not valid");
...@@ -1092,7 +1093,7 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg) ...@@ -1092,7 +1093,7 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg)
ret = -EFAULT; ret = -EFAULT;
index = link_info.port_number; index = link_info.port_number;
} else { } else {
ret = __get_user(index, (int __user *) arg); ret = __get_user(index, (int __user *)arg);
if (ret != 0) if (ret != 0)
break; break;
} }
...@@ -1121,8 +1122,7 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg) ...@@ -1121,8 +1122,7 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg)
ppd->link_speed_active; ppd->link_speed_active;
link_info.link_width_active = link_info.link_width_active =
ppd->link_width_active; ppd->link_width_active;
if (copy_to_user( if (copy_to_user((struct hfi1_link_info __user *)arg,
(struct hfi1_link_info __user *)arg,
&link_info, sizeof(link_info))) &link_info, sizeof(link_info)))
ret = -EFAULT; ret = -EFAULT;
} else { } else {
...@@ -1168,7 +1168,6 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg) ...@@ -1168,7 +1168,6 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg)
filter_value = kcalloc(filter_cmd.length, sizeof(u8), filter_value = kcalloc(filter_cmd.length, sizeof(u8),
GFP_KERNEL); GFP_KERNEL);
if (!filter_value) { if (!filter_value) {
pr_alert("Not enough memory\n");
ret = -ENOMEM; ret = -ENOMEM;
break; break;
} }
...@@ -1196,7 +1195,7 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg) ...@@ -1196,7 +1195,7 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg)
break; break;
case HFI1_SNOOP_IOCSET_OPTS: case HFI1_SNOOP_IOCSET_OPTS:
snoop_flags = 0; snoop_flags = 0;
ret = __get_user(value, (int __user *) arg); ret = __get_user(value, (int __user *)arg);
if (ret != 0) if (ret != 0)
break; break;
...@@ -1210,7 +1209,6 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg) ...@@ -1210,7 +1209,6 @@ static long hfi1_ioctl(struct file *fp, unsigned int cmd, unsigned long arg)
ret = -ENOTTY; ret = -ENOTTY;
break; break;
} }
}
done: done:
spin_unlock_irqrestore(&dd->hfi1_snoop.snoop_lock, flags); spin_unlock_irqrestore(&dd->hfi1_snoop.snoop_lock, flags);
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment