Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp2324682imm; Sun, 12 Aug 2018 11:36:52 -0700 (PDT) X-Google-Smtp-Source: AA+uWPzudqpKpqBg3uTcyHQl2+wl1bv0XsRd4ZXeg/hu/lz+JiUEOKRNyTnxr2fndybdQGke1zCX X-Received: by 2002:a65:4888:: with SMTP id n8-v6mr14452903pgs.149.1534099012079; Sun, 12 Aug 2018 11:36:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1534099012; cv=none; d=google.com; s=arc-20160816; b=LSXssIF3RkUkOaHMDIk1KS6wBSYA35ISXqZrVNScFTBMVWuQPvhWSyYMbZPSLhI6Ml wQWXs//h0yB4Yg24G5T+TMe5QUkymihptjR+yPzBBOf83ZH8wClrrOemvEBrJiNJCjPM p1Ar/0KxC6MvB7ikSx6LZXE1NlOgdYdJexfmbRQUhmdGcw4Uc/AGxHFU9rRY+vd4OQ0U HXQqhYqB3lF0K56UvxDeE7pndEXLrxZkhC/fOlqnVGAVJgvEVuwPk4mfNE93AcbM30wK dXHCFXQfY5omrZ2cDsqbPdxemT+q13GuhZ0fO4OPLIVt+zZF4yX0Y9jrWdqmgnW/jZgt Y1HA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:date:cc:to:from:subject:message-id :arc-authentication-results; bh=FRblg3YbRV4Ot/dCJvpcgSykuxFKxVCJyxPA/jsmcJs=; b=doRrCltEHw8VCq+3tK2ZTpCEkHLhTvE5iiWV7cjnPbwRka5odpB8oBGtIRUwZYae0+ KhqTYIGML3qlaknjrRy4UQgvLa2TJ2mSw4q3lJXAh7nt8KLRUkz2hAslDLZu3fPRFPNT P24nuEJ8weKbQjBplWcQh2gdXgyTazMJ0ToF8FAq5K1kUgh2SNe98ciOuGhbZg/bBEeR CfANJdFtEW1HnVVjcQbw6p7OOtNQK5HNZpg+kX7TRcggoo3HjcAsY0RI/vqfx2N2ybEB NBzqY56O51a/p1UlZaKDkpfZBdHo4qI5KRPciR66Y3I4uQ8G6tHrJkUYawPOHA2P//a4 BoGg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b7-v6si16888244pfc.352.2018.08.12.11.36.37; Sun, 12 Aug 2018 11:36:52 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728046AbeHLVN5 (ORCPT + 99 others); Sun, 12 Aug 2018 17:13:57 -0400 Received: from smtprelay0119.hostedemail.com ([216.40.44.119]:46931 "EHLO smtprelay.hostedemail.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727550AbeHLVN4 (ORCPT ); Sun, 12 Aug 2018 17:13:56 -0400 Received: from filter.hostedemail.com (clb03-v110.bra.tucows.net [216.40.38.60]) by smtprelay05.hostedemail.com (Postfix) with ESMTP id 986F518028E9F; Sun, 12 Aug 2018 18:35:02 +0000 (UTC) X-Session-Marker: 6A6F6540706572636865732E636F6D X-Spam-Summary: 2,0,0,,d41d8cd98f00b204,joe@perches.com,:::::::::::::,RULES_HIT:41:69:355:379:541:599:966:973:988:989:1260:1277:1311:1313:1314:1345:1359:1437:1515:1516:1518:1534:1543:1593:1594:1605:1711:1730:1747:1777:1792:2196:2199:2393:2559:2562:2828:3138:3139:3140:3141:3142:3622:3865:3867:3868:3871:3872:4250:4321:4385:5007:6119:7903:8603:9592:10004:10400:10848:11026:11232:11473:11658:11914:12043:12291:12296:12438:12555:12683:12740:12760:12895:12986:13439:14096:14097:14181:14659:14721:21080:21433:21451:21627:21789:30012:30045:30054:30091,0,RBL:47.151.153.53:@perches.com:.lbl8.mailshell.net-62.14.0.100 64.201.201.201,CacheIP:none,Bayesian:0.5,0.5,0.5,Netcheck:none,DomainCache:0,MSF:not bulk,SPF:fn,MSBL:0,DNSBL:neutral,Custom_rules:0:0:0,LFtime:31,LUA_SUMMARY:none X-HE-Tag: size83_831fd4dc17922 X-Filterd-Recvd-Size: 4678 Received: from XPS-9350.home (unknown [47.151.153.53]) (Authenticated sender: joe@perches.com) by omf06.hostedemail.com (Postfix) with ESMTPA; Sun, 12 Aug 2018 18:35:00 +0000 (UTC) Message-ID: <10f9f13a5421299a6efda1e1f84ab304ef18ddec.camel@perches.com> Subject: Re: [PATCH] USB: core: devio: fixed a trailing statement code style issue From: Joe Perches To: Tom Todd , gregkh@linuxfoundation.org Cc: stern@rowland.harvard.edu, dan.carpenter@oracle.com, arvind.yadav.cs@gmail.com, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org Date: Sun, 12 Aug 2018 11:34:59 -0700 In-Reply-To: <20180812180656.26079-1-thomas.m.a.todd@gmail.com> References: <20180812180656.26079-1-thomas.m.a.todd@gmail.com> Content-Type: text/plain; charset="ISO-8859-1" X-Mailer: Evolution 3.28.1-2 Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, 2018-08-12 at 19:06 +0100, Tom Todd wrote: > Fixed a code styling issue while it's OK to fix style only issues, it's much better to reorganize the code for reader clarity. For this code, something like: o use memdup_user o use an exit label to free allocated memory o invert tests to return on unexpected results o move logical continuations to EOL o don't use successive code like: if (foo) return -ERRNO; else if (bar) return -ERRNO; else baz; simpler and less indentation is: if (foo) return -ERRNO; if (bar) return -ERRNO; baz; --- drivers/usb/core/devio.c | 68 ++++++++++++++++++++++++++---------------------- 1 file changed, 37 insertions(+), 31 deletions(-) diff --git a/drivers/usb/core/devio.c b/drivers/usb/core/devio.c index 6ce77b33da61..74ae4e052357 100644 --- a/drivers/usb/core/devio.c +++ b/drivers/usb/core/devio.c @@ -2118,68 +2118,74 @@ static int proc_ioctl(struct usb_dev_state *ps, struct usbdevfs_ioctl *ctl) /* alloc buffer */ size = _IOC_SIZE(ctl->ioctl_code); if (size > 0) { - buf = kmalloc(size, GFP_KERNEL); - if (buf == NULL) - return -ENOMEM; - if ((_IOC_DIR(ctl->ioctl_code) & _IOC_WRITE)) { - if (copy_from_user(buf, ctl->data, size)) { - kfree(buf); + if (_IOC_DIR(ctl->ioctl_code) & _IOC_WRITE) { + buf = memdup_user(ctl->data, size); + if (!buf) return -EFAULT; - } } else { - memset(buf, 0, size); + buf = kzalloc(size, GFP_KERNEL); + if (!buf) + return -ENOMEM; } } if (!connected(ps)) { - kfree(buf); - return -ENODEV; + retval = -ENODEV; + goto exit; } - - if (ps->dev->state != USB_STATE_CONFIGURED) + if (ps->dev->state != USB_STATE_CONFIGURED) { retval = -EHOSTUNREACH; - else if (!(intf = usb_ifnum_to_if(ps->dev, ctl->ifno))) + goto exit; + } + intf = usb_ifnum_to_if(ps->dev, ctl->ifno); + if (!intf) { retval = -EINVAL; - else switch (ctl->ioctl_code) { + goto exit; + } + switch (ctl->ioctl_code) { /* disconnect kernel driver from interface */ case USBDEVFS_DISCONNECT: - if (intf->dev.driver) { - driver = to_usb_driver(intf->dev.driver); - dev_dbg(&intf->dev, "disconnect by usbfs\n"); - usb_driver_release_interface(driver, intf); - } else + if (!intf->dev.driver) { retval = -ENODATA; + goto exit; + } + driver = to_usb_driver(intf->dev.driver); + dev_dbg(&intf->dev, "disconnect by usbfs\n"); + usb_driver_release_interface(driver, intf); break; /* let kernel drivers try to (re)bind to the interface */ case USBDEVFS_CONNECT: - if (!intf->dev.driver) - retval = device_attach(&intf->dev); - else + if (!intf->dev.driver) { retval = -EBUSY; + goto exit; + } + retval = device_attach(&intf->dev); break; /* talk directly to the interface's driver */ default: if (intf->dev.driver) driver = to_usb_driver(intf->dev.driver); - if (driver == NULL || driver->unlocked_ioctl == NULL) { + if (!driver || !driver->unlocked_ioctl) { retval = -ENOTTY; - } else { - retval = driver->unlocked_ioctl(intf, ctl->ioctl_code, buf); - if (retval == -ENOIOCTLCMD) - retval = -ENOTTY; + goto exit; + } + retval = driver->unlocked_ioctl(intf, ctl->ioctl_code, buf); + if (retval == -ENOIOCTLCMD) { + retval = -ENOTTY; + goto exit; } + break; } /* cleanup and return */ - if (retval >= 0 - && (_IOC_DIR(ctl->ioctl_code) & _IOC_READ) != 0 - && size > 0 - && copy_to_user(ctl->data, buf, size) != 0) + if (retval >= 0 && (_IOC_DIR(ctl->ioctl_code) & _IOC_READ) != 0 && + size > 0 && copy_to_user(ctl->data, buf, size) != 0) retval = -EFAULT; +exit: kfree(buf); return retval; }