Commit a4e80a1b authored by Alan Cox's avatar Alan Cox Committed by Greg Kroah-Hartman

Staging: sep: untangle the register_fs code

While goto can be useful for cleaner cleaning up in C (as Linux sometimes
does and I think Linus borrowed stylistically from Amiga) you can overdo it.
Here is a fine fine example of when it's overkill
Signed-off-by: default avatarAlan Cox <alan@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent cfd498be
...@@ -2169,8 +2169,8 @@ static int sep_get_time_handler(struct sep_device *sep, unsigned long arg) ...@@ -2169,8 +2169,8 @@ static int sep_get_time_handler(struct sep_device *sep, unsigned long arg)
struct sep_driver_get_time_t command_args; struct sep_driver_get_time_t command_args;
mutex_lock(&sep_mutex); mutex_lock(&sep_mutex);
command_arg.time_value = sep_set_time(sep); command_args.time_value = sep_set_time(sep);
command_args.time_physical_address = sep_time_address(sep); command_args.time_physical_address = (unsigned long)sep_time_address(sep);
mutex_unlock(&sep_mutex); mutex_unlock(&sep_mutex);
if (copy_to_user((void __user *)arg, if (copy_to_user((void __user *)arg,
&command_args, sizeof(struct sep_driver_get_time_t))) &command_args, sizeof(struct sep_driver_get_time_t)))
...@@ -2646,31 +2646,22 @@ static int sep_register_driver_to_fs(void) ...@@ -2646,31 +2646,22 @@ static int sep_register_driver_to_fs(void)
{ {
int ret_val = alloc_chrdev_region(&sep_devno, 0, 1, "sep_sec_driver"); int ret_val = alloc_chrdev_region(&sep_devno, 0, 1, "sep_sec_driver");
if (ret_val) { if (ret_val) {
edbg("sep_driver:major number allocation failed, retval is %d\n", ret_val); edbg("sep: major number allocation failed, retval is %d\n",
goto end_function; ret_val);
return ret_val;
} }
/* init cdev */ /* init cdev */
cdev_init(&sep_cdev, &sep_file_operations); cdev_init(&sep_cdev, &sep_file_operations);
sep_cdev.owner = THIS_MODULE; sep_cdev.owner = THIS_MODULE;
/* register the driver with the kernel */ /* register the driver with the kernel */
ret_val = cdev_add(&sep_cdev, sep_devno, 1); ret_val = cdev_add(&sep_cdev, sep_devno, 1);
if (ret_val) { if (ret_val) {
edbg("sep_driver:cdev_add failed, retval is %d\n", ret_val); edbg("sep_driver:cdev_add failed, retval is %d\n", ret_val);
goto end_function_unregister_devnum; /* unregister dev numbers */
unregister_chrdev_region(sep_devno, 1);
} }
return ret_val;
goto end_function;
end_function_unregister_devnum:
/* unregister dev numbers */
unregister_chrdev_region(sep_devno, 1);
end_function:
return ret_val;
} }
......
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