Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp118227ybf; Wed, 26 Feb 2020 09:51:58 -0800 (PST) X-Google-Smtp-Source: APXvYqzhI0vPljd8SOqYbi8ph6s+gObAGShDQ6bFWJlN/ajIzTf7eA5N0cNN9WDBR/9kkJQ++1KK X-Received: by 2002:a05:6830:1f5d:: with SMTP id u29mr103817oth.287.1582739518318; Wed, 26 Feb 2020 09:51:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582739518; cv=none; d=google.com; s=arc-20160816; b=oNS854IxxrEv+90OwhX93seHQxl6Es6Sz6A+LTYqTQ9pNSillXmIyh5vNRvymmPCJH BogrE0mMsl5Yr4l9vrCdwX1bFjlYYgmBtBOoP7ijADPREcZHwi4RvpcfwJ5w+DFppu5z QqGJs9onXAq+rEsdqg3SctVh9RTerg8Gcm7b0d0BkI7Eg857ZJkNI6mNZdFsiZtQasuA /HcaCWrpqRaZnR5cX60e3z0/4w2YfmVQFUTZ1rPcL+XxpmKx6tK9zzuhmcv2KgVNmakM ZoFTSNPg/a5hamBoqUn7ZQ3du/5WMQFOzGUpohxQxbhiSqlxXOh69KsZCvtAZXE5KkFS cu6w== 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 :message-id:date:subject:cc:to:from; bh=kABHyT2wzDJzBCdtu8OqzUKe2J/Rncn9Q1ELTqLQcDg=; b=RGFGTXzxmNrHAvb4q9zNdx5ee9T1MzoOUVyIsm/6+0dQSe/+JCu41A+s+w7nVpG7J+ 9TecSwtcW7WwqDu91GJKilGp+mwwucMMUXFKgguxoqs6RGu0K+4C8QnDTwN75e2pxTac 5UWdZj5spmnNiAGbaNkzKXDxg9rLTkBH1zVWv0o/IYN4tHZv8x+d+qoAtGYWxe337pi+ whElAv03okHwWpWI4IDsPGAxtpTLEupJ7dOcOeKdKF6d98mAI8RoVbhfG6FjQivEe28j UVuO8XCdUeOeM9FXau1naTVXs9twRTOU6Co5X2IJpLCdwdrgl2Kz4zkY7/QaWmK2HdK9 aNDg== 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 q25si162260otg.128.2020.02.26.09.51.46; Wed, 26 Feb 2020 09:51:58 -0800 (PST) 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 S1727024AbgBZRv3 (ORCPT + 99 others); Wed, 26 Feb 2020 12:51:29 -0500 Received: from smtp1.de.adit-jv.com ([93.241.18.167]:34638 "EHLO smtp1.de.adit-jv.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727000AbgBZRv3 (ORCPT ); Wed, 26 Feb 2020 12:51:29 -0500 Received: from localhost (smtp1.de.adit-jv.com [127.0.0.1]) by smtp1.de.adit-jv.com (Postfix) with ESMTP id 38C763C009D; Wed, 26 Feb 2020 18:51:26 +0100 (CET) Received: from smtp1.de.adit-jv.com ([127.0.0.1]) by localhost (smtp1.de.adit-jv.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id vLozTJuWFvoL; Wed, 26 Feb 2020 18:51:20 +0100 (CET) Received: from HI2EXCH01.adit-jv.com (hi2exch01.adit-jv.com [10.72.92.24]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by smtp1.de.adit-jv.com (Postfix) with ESMTPS id DDDDE3C005E; Wed, 26 Feb 2020 18:51:20 +0100 (CET) Received: from lxhi-065.adit-jv.com (10.72.93.66) by HI2EXCH01.adit-jv.com (10.72.92.24) with Microsoft SMTP Server (TLS) id 14.3.468.0; Wed, 26 Feb 2020 18:51:20 +0100 From: Eugeniu Rosca To: Alan Stern , , CC: Greg Kroah-Hartman , Thinh Nguyen , "Lee, Chiasheng" , Mathieu Malaterre , Kai-Heng Feng , Eugeniu Rosca , Eugeniu Rosca , Hardik Gajjar , , Subject: [PATCH v3 1/3] usb: core: hub: fix unhandled return by employing a void function Date: Wed, 26 Feb 2020 18:50:34 +0100 Message-ID: <20200226175036.14946-1-erosca@de.adit-jv.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.72.93.66] Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Address below Coverity complaint (Feb 25, 2020, 8:06 AM CET): *** CID 1458999: Error handling issues (CHECKED_RETURN) /drivers/usb/core/hub.c: 1869 in hub_probe() 1863 1864 if (id->driver_info & HUB_QUIRK_CHECK_PORT_AUTOSUSPEND) 1865 hub->quirk_check_port_auto_suspend = 1; 1866 1867 if (id->driver_info & HUB_QUIRK_DISABLE_AUTOSUSPEND) { 1868 hub->quirk_disable_autosuspend = 1; >>> CID 1458999: Error handling issues (CHECKED_RETURN) >>> Calling "usb_autopm_get_interface" without checking return value (as is done elsewhere 97 out of 111 times). 1869 usb_autopm_get_interface(intf); 1870 } 1871 1872 if (hub_configure(hub, &desc->endpoint[0].desc) >= 0) 1873 return 0; 1874 Rather than checking the return value of 'usb_autopm_get_interface()', switch to the usb_autopm_get_interface_no_resume() API, as per: On Tue, Feb 25, 2020 at 10:32:32AM -0500, Alan Stern wrote: ------ 8< ------ > This change (i.e. 'ret = usb_autopm_get_interface') is not necessary, > because the resume operation cannot fail at this point (interfaces > are always powered-up during probe). A better solution would be to > call usb_autopm_get_interface_no_resume() instead. ------ 8< ------ Fixes: 1208f9e1d758c9 ("USB: hub: Fix the broken detection of USB3 device in SMSC hub") Cc: Hardik Gajjar Cc: Alan Stern Cc: Greg Kroah-Hartman Cc: stable@vger.kernel.org # v4.14+ Reported-by: scan-admin@coverity.com Suggested-by: Alan Stern Signed-off-by: Eugeniu Rosca --- v3: - Make the summary line more clear - s/autpm/autopm/ in patch description - Cc with v4.14+ since v4.14.x is the earliest stable kernel which accepted commit 1208f9e1d758c9 ("USB: hub: Fix the broken detection of USB3 device in SMSC hub") v2: - [Alan Stern] Use usb_autopm_get_interface_no_resume() instead of usb_autopm_get_interface() - Augment commit description to provide background - Link: https://lore.kernel.org/lkml/20200225183057.31953-1-erosca@de.adit-jv.com v1: - Link: https://lore.kernel.org/lkml/20200225130846.20236-1-erosca@de.adit-jv.com --- drivers/usb/core/hub.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c index 1d212f82c69b..1105983b5c1c 100644 --- a/drivers/usb/core/hub.c +++ b/drivers/usb/core/hub.c @@ -1866,7 +1866,7 @@ static int hub_probe(struct usb_interface *intf, const struct usb_device_id *id) if (id->driver_info & HUB_QUIRK_DISABLE_AUTOSUSPEND) { hub->quirk_disable_autosuspend = 1; - usb_autopm_get_interface(intf); + usb_autopm_get_interface_no_resume(intf); } if (hub_configure(hub, &desc->endpoint[0].desc) >= 0) -- 2.25.1