Received: by 2002:a25:23cc:0:0:0:0:0 with SMTP id j195csp78933ybj; Fri, 8 May 2020 06:58:32 -0700 (PDT) X-Google-Smtp-Source: APiQypJfqxi4IS5XDoCSoKcDaWqEzvVnn0JCg41jX4Ve3prS83rjSZOybgmypObuPTL5oN1suzwP X-Received: by 2002:a05:6000:1104:: with SMTP id z4mr267629wrw.57.1588946312273; Fri, 08 May 2020 06:58:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588946312; cv=none; d=google.com; s=arc-20160816; b=T4s4chqQ1bGoLQP/tXYUIU+OMKWorA+MdmVtvjqWWVOKbco2snQVh6gRbD6CSr77RH aGEdF4qHLUlQPNdG9/qMplSHjO3JpoMOITgIpzzcCYa6c+IqmUvJISSj7kLEPHRsfisw aIF8D4S41kRA4b1wBassDbHn8mrOHqtdW4Fg2Pv10hV/engvIlNXkcIFUFljqx6Pc7e3 FFv64Js4/D2lzRKEeN8R0qpFuFFTNvdzx7ptjEtbLE4pnhE/l1DUkOOsRJw3+3FpSeTk dnoYVT9WpwmSSyJ0mrDvrjC+QzUCj5PI0Cdlw4B0y39HY1CrZdDrD0MfgySPatH0dXZV yOzw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=3p37oxQ6xJRNjx2sk5TVOmrRREJt3TSTtikCpS5CztQ=; b=fnI5tup/mloTUYgXd81NKJyEtSh43S5v/nAp5QwF4ek7g5a56iHOTvjak6RuA0z6cB VP3sTIOsFZ9m0QUwM8r3dg/mh44cgCYzpoawyOKRC7eW0oc+inRNdlj+GH+wjlKob1Dl fFvKipINmsC2ymBNvPbplqbgKMXI7fznqTraDBDA47CEjm629nx8p2NYYTql0oh1ebpv TcZ+aJLpFK0QW/vpwZRMBM6OVQ8Jolbhv5kxWTlNc9C5tzZFIvCv16dJvVofjpC0zRrl dHEuAKbU2/sipKn/GrYk/E2L4UpDJOiXbBPj4Fy/UV9qv+esgscEJKX81cA6yZAC5CKt sTTA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y18si1553565wrt.392.2020.05.08.06.58.08; Fri, 08 May 2020 06:58:32 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728436AbgEHNzn (ORCPT + 99 others); Fri, 8 May 2020 09:55:43 -0400 Received: from cmccmta3.chinamobile.com ([221.176.66.81]:5147 "EHLO cmccmta3.chinamobile.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727879AbgEHNzn (ORCPT ); Fri, 8 May 2020 09:55:43 -0400 Received: from spf.mail.chinamobile.com (unknown[172.16.121.1]) by rmmx-syy-dmz-app12-12012 (RichMail) with SMTP id 2eec5eb564bb4ed-5a968; Fri, 08 May 2020 21:55:08 +0800 (CST) X-RM-TRANSID: 2eec5eb564bb4ed-5a968 X-RM-TagInfo: emlType=0 X-RM-SPAM-FLAG: 00000000 Received: from [192.168.43.52] (unknown[223.104.148.118]) by rmsmtp-syy-appsvr01-12001 (RichMail) with SMTP id 2ee15eb564bac79-8c4fe; Fri, 08 May 2020 21:55:07 +0800 (CST) X-RM-TRANSID: 2ee15eb564bac79-8c4fe Subject: Re: [PATCH] USB: host: ehci: Add error handling inehci_mxc_drv_probe() To: Greg KH Cc: stern@rowland.harvard.edu, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, Zhang Shengju References: <20200508114453.15436-1-tangbin@cmss.chinamobile.com> <20200508114858.GA4085349@kroah.com> From: Tang Bin Message-ID: Date: Fri, 8 May 2020 21:55:53 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:68.0) Gecko/20100101 Thunderbird/68.8.0 MIME-Version: 1.0 In-Reply-To: <20200508114858.GA4085349@kroah.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, Greg: On 2020/5/8 19:48, Greg KH wrote: > On Fri, May 08, 2020 at 07:44:53PM +0800, Tang Bin wrote: >> The function ehci_mxc_drv_probe() does not perform sufficient error >> checking after executing platform_get_irq(), thus fix it. >> >> Fixes: 7e8d5cd93fa ("USB: Add EHCI support for MX27 and MX31 based boards") >> Signed-off-by: Zhang Shengju >> Signed-off-by: Tang Bin >> --- >> drivers/usb/host/ehci-mxc.c | 2 ++ >> 1 file changed, 2 insertions(+) >> >> diff --git a/drivers/usb/host/ehci-mxc.c b/drivers/usb/host/ehci-mxc.c >> index a1eb5ee77..a0b42ba59 100644 >> --- a/drivers/usb/host/ehci-mxc.c >> +++ b/drivers/usb/host/ehci-mxc.c >> @@ -50,6 +50,8 @@ static int ehci_mxc_drv_probe(struct platform_device *pdev) >> } >> >> irq = platform_get_irq(pdev, 0); >> + if (irq < 0) >> + return irq; > <= ? In the file 'drivers/base/platform.c', the function platform_get_irq() is explained and used as follows:      * Gets an IRQ for a platform device and prints an error message if finding the      * IRQ fails. Device drivers should check the return value for errors so as to      * not pass a negative integer value to the request_irq() APIs.      *      * Example:      *        int irq = platform_get_irq(pdev, 0);      *        if (irq < 0)      *            return irq;      *      * Return: IRQ number on success, negative error number on failure. And in my hardware experiment, even if I set the irq failed deliberately in the DTS, the returned value is negative instead of zero. Thanks for your patience and replay. Tang Bin