IB/qib: Cleanup qib_register_observer()
authorDan Carpenter <dan.carpenter@oracle.com>
Thu, 30 Jan 2014 12:12:31 +0000 (15:12 +0300)
committerRoland Dreier <roland@purestorage.com>
Thu, 20 Mar 2014 17:19:18 +0000 (10:19 -0700)
Returning directly is easier to read than do-nothing gotos.  Remove the
duplicative check on "olp" and pull the code in one indent level.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Acked-by: Mike Marciniszyn <mike.marciniszyn@intel.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
drivers/infiniband/hw/qib/qib_diag.c

index 07f9030a8f10a9dc4ac90601867652283999f049..5dfda4c5cc9c3b1fde36d02c55cd387b7e366542 100644 (file)
@@ -694,28 +694,23 @@ int qib_register_observer(struct qib_devdata *dd,
                          const struct diag_observer *op)
 {
        struct diag_observer_list_elt *olp;
-       int ret = -EINVAL;
+       unsigned long flags;
 
        if (!dd || !op)
-               goto bail;
-       ret = -ENOMEM;
+               return -EINVAL;
        olp = vmalloc(sizeof *olp);
        if (!olp) {
                pr_err("vmalloc for observer failed\n");
-               goto bail;
+               return -ENOMEM;
        }
-       if (olp) {
-               unsigned long flags;
 
-               spin_lock_irqsave(&dd->qib_diag_trans_lock, flags);
-               olp->op = op;
-               olp->next = dd->diag_observer_list;
-               dd->diag_observer_list = olp;
-               spin_unlock_irqrestore(&dd->qib_diag_trans_lock, flags);
-               ret = 0;
-       }
-bail:
-       return ret;
+       spin_lock_irqsave(&dd->qib_diag_trans_lock, flags);
+       olp->op = op;
+       olp->next = dd->diag_observer_list;
+       dd->diag_observer_list = olp;
+       spin_unlock_irqrestore(&dd->qib_diag_trans_lock, flags);
+
+       return 0;
 }
 
 /* Remove all registered observers when device is closed */