am7xxx: clean up the exit path in open_device()
[libam7xxx.git] / src / am7xxx.c
index 3334615..fedf11a 100644 (file)
@@ -747,12 +747,15 @@ static int open_device(am7xxx_context *ctx,
                debug(ctx, "libusb_claim_interface failed\n");
                debug(ctx, "Cannot claim interface %hhu\n",
                      (*dev)->desc->interface_number);
-out_libusb_close:
-               libusb_close((*dev)->usb_device);
-               (*dev)->usb_device = NULL;
+               goto out_libusb_close;
        }
 out:
        return ret;
+
+out_libusb_close:
+       libusb_close((*dev)->usb_device);
+       (*dev)->usb_device = NULL;
+       return ret;
 }
 
 typedef enum {