Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp1863853yba; Fri, 17 May 2019 06:43:26 -0700 (PDT) X-Google-Smtp-Source: APXvYqzS4MSUATyCD3nO2i7xk97x5aivINWelSquTuIzcZtQleqTtE5BfMBaGLSeX1tWw2pqkh1O X-Received: by 2002:a63:cf01:: with SMTP id j1mr53517745pgg.97.1558100606365; Fri, 17 May 2019 06:43:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558100606; cv=none; d=google.com; s=arc-20160816; b=NYWHNKiUTbQY4j1I49tkIzSQtqYaXcMeRBv15V3N8//iuo9svP1qdppTMVKFiPc8HD yootXuIdHCTxRUgyj2VO7rbGXaZzMv/abxqrlDsnTarJYU6+zQHYMBTk3WtLORj715x9 nMPas36Pd+wwM4MpY2jbuKHFmi2kqtgm4N4jETFSPyUHro4bRLd6v5AJPOMIHPUGqEpB fzzIG3N6UYJQUAATAzJfAJzQCUaS/WtTgQA6JCJ38FSy60VdUY8+Xr8fArhCAEMCx4yp IqduN2fI0Tejq9MaJyCKNGW1aKXtRhBeQwvnyHtiMp5mp/2DwcD+BnDIfNeCYEoXQzcf oDnw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=zd1JxDrgBYrqE6Qw1LUTfDRpPQduYNbgmbCRWOV3xxg=; b=SOUwMQgnYHXSdN7+7omT+s6U/r3LS7+Z3GOS3tLDzW3cciKV9CuotDZcpDSbBtfQtF Hv0zOKd2Kpwg6z5GQnGpJb6gkEdoe0Iz+KZNFY74CsAAaovjBYz0nO71/W6Atu3/+GSJ dSSMh5fkbat6R0cmjEa4z2PAvQAsFPFwunN6l8b5fW2cFyOhWR3Qkj8v4eTzQ4J8l3SJ h0A92Yo/NlOkQ2JvnZXxuOHoB0G+rp520cFf01Eu7OrtoXC3F2AvXHfosjjwnCMbKYL2 w1UneRwHAMfqPUizDTmwpr3FLof1UUda1kOFNaRgkROAQygQUg4PWlP3s+a/raDnqcnb STBw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=MYs5t+8J; 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 f14si7201428plr.1.2019.05.17.06.43.10; Fri, 17 May 2019 06:43:26 -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; dkim=pass header.i=@kernel.org header.s=default header.b=MYs5t+8J; 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 S1728985AbfEQN3Q (ORCPT + 99 others); Fri, 17 May 2019 09:29:16 -0400 Received: from mail.kernel.org ([198.145.29.99]:54978 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728333AbfEQN3P (ORCPT ); Fri, 17 May 2019 09:29:15 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D63BD20818; Fri, 17 May 2019 13:29:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1558099754; bh=YlPg6sbrNc9Z9eYwr6qYX0YGHPoOYgMx4kk5T7hr/1Q=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=MYs5t+8J4i0T05BxQVrXKC0DMQVezSSap2TOBfSujq+c6CVs4GZjDnSek9rcGvnd4 y+pwqAIVEeqkZWngptk9WSmNI/gFE5wRk9FZzSiMLGckMZAVVPGOtEMHYSmxjpFm9+ YMioJSAwId0KkBa+Xaf5MYyszU9b9wgI+qZpVDK4= Date: Fri, 17 May 2019 15:29:11 +0200 From: Greg Kroah-Hartman To: Quentin Deslandes Cc: "kernel-janitors@vger.kernel.org" , "devel@driverdev.osuosl.org" , Mukesh Ojha , "linux-kernel@vger.kernel.org" , Forest Bond , Ojaswin Mujoo Subject: Re: [PATCH v3] staging: vt6656: returns error code on vnt_int_start_interrupt fail Message-ID: <20190517132911.GA4037@kroah.com> References: <20190516093046.1400-1-quentin.deslandes@itdev.co.uk> <20190517075331.3658-1-quentin.deslandes@itdev.co.uk> <20190517091723.GA4602@kroah.com> <20190517131539.GA9842@qd-ubuntu> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190517131539.GA9842@qd-ubuntu> User-Agent: Mutt/1.11.4 (2019-03-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, May 17, 2019 at 01:15:43PM +0000, Quentin Deslandes wrote: > On Fri, May 17, 2019 at 11:17:23AM +0200, Greg Kroah-Hartman wrote: > > On Fri, May 17, 2019 at 07:53:49AM +0000, Quentin Deslandes wrote: > > > Returns error code from 'vnt_int_start_interrupt()' so the device's private > > > buffers will be correctly freed and 'struct ieee80211_hw' start function > > > will return an error code. > > > > > > Signed-off-by: Quentin Deslandes > > > --- > > > v2: returns 'status' value to caller instead of removing it. > > > v3: add patch version details. Thanks to Greg K-H for his help. > > > > Looking better! > > > > But a few minor things below: > > > > > > > > drivers/staging/vt6656/int.c | 4 +++- > > > drivers/staging/vt6656/int.h | 2 +- > > > drivers/staging/vt6656/main_usb.c | 12 +++++++++--- > > > 3 files changed, 13 insertions(+), 5 deletions(-) > > > > > > diff --git a/drivers/staging/vt6656/int.c b/drivers/staging/vt6656/int.c > > > index 504424b19fcf..f3ee2198e1b3 100644 > > > --- a/drivers/staging/vt6656/int.c > > > +++ b/drivers/staging/vt6656/int.c > > > @@ -39,7 +39,7 @@ static const u8 fallback_rate1[5][5] = { > > > {RATE_54M, RATE_54M, RATE_36M, RATE_18M, RATE_18M} > > > }; > > > > > > -void vnt_int_start_interrupt(struct vnt_private *priv) > > > +int vnt_int_start_interrupt(struct vnt_private *priv) > > > { > > > unsigned long flags; > > > int status; > > > @@ -51,6 +51,8 @@ void vnt_int_start_interrupt(struct vnt_private *priv) > > > status = vnt_start_interrupt_urb(priv); > > > > > > spin_unlock_irqrestore(&priv->lock, flags); > > > + > > > + return status; > > > } > > > > > > static int vnt_int_report_rate(struct vnt_private *priv, u8 pkt_no, u8 tsr) > > > diff --git a/drivers/staging/vt6656/int.h b/drivers/staging/vt6656/int.h > > > index 987c454e99e9..8a6d60569ceb 100644 > > > --- a/drivers/staging/vt6656/int.h > > > +++ b/drivers/staging/vt6656/int.h > > > @@ -41,7 +41,7 @@ struct vnt_interrupt_data { > > > u8 sw[2]; > > > } __packed; > > > > > > -void vnt_int_start_interrupt(struct vnt_private *priv); > > > +int vnt_int_start_interrupt(struct vnt_private *priv); > > > void vnt_int_process_data(struct vnt_private *priv); > > > > > > #endif /* __INT_H__ */ > > > diff --git a/drivers/staging/vt6656/main_usb.c b/drivers/staging/vt6656/main_usb.c > > > index ccafcc2c87ac..71e10b9ae253 100644 > > > --- a/drivers/staging/vt6656/main_usb.c > > > +++ b/drivers/staging/vt6656/main_usb.c > > > @@ -483,6 +483,7 @@ static void vnt_tx_80211(struct ieee80211_hw *hw, > > > > > > static int vnt_start(struct ieee80211_hw *hw) > > > { > > > + int err = 0; > > > struct vnt_private *priv = hw->priv; > > > > > > priv->rx_buf_sz = MAX_TOTAL_SIZE_WITH_ALL_HEADERS; > > > @@ -496,15 +497,20 @@ static int vnt_start(struct ieee80211_hw *hw) > > > > > > if (vnt_init_registers(priv) == false) { > > > dev_dbg(&priv->usb->dev, " init register fail\n"); > > > + err = -ENOMEM; > > > > Why ENOMEM? vnt_init_registers() should return a proper error code, > > based on what went wrong, not true/false. So fix that up first, and > > then you can do this patch. > > > > See, your one tiny coding style fix is turning into real cleanups, nice! > > > > > goto free_all; > > > } > > > > > > - if (vnt_key_init_table(priv)) > > > + if (vnt_key_init_table(priv)) { > > > + err = -ENOMEM; > > > > Same here, vnt_key_init_table() should return a real error value, and > > then just return that here. > > > > > goto free_all; > > > + } > > > > > > priv->int_interval = 1; /* bInterval is set to 1 */ > > > > > > - vnt_int_start_interrupt(priv); > > > + err = vnt_int_start_interrupt(priv); > > > + if (err) > > > + goto free_all; > > > > Like this, that is the correct thing. > > > > So, this is now going to be a patch series, fixing up those two > > functions (and any functions they call possibly), and then this can be > > the last patch of the series. > > > > thanks, > > > > greg k-h > > Thank you for your help, this is getting really exciting! However, I had > a look at these function (vnt_init_registers() and vnt_key_init_table()) > and some questions popped in my mind. > > If I understand correctly, your request is to fix these function so they > can return an error code instead of just failing, as I did with > vnt_int_start_interrupt() in the third patch, which is also the most > logical behaviour. Yes, that is correct. > So, vnt_init_registers() is a big function (~240 lines), which should > return a proper error code. For this, all the function called in > vnt_init_registers() should also return a proper error code, right? Correct. > What about functions called that does not return any value, but their only > action is to call a function that return a status code? As I learn with this > patch, discarding error values is not a acceptable behaviour. Why would we write > functions returning an error code solely to discard it? So such function should > be changed too? Yes, those functions need to be changed too. > I listed up to 22 function that need to be updated in order to correctly > propagate errors up to vnt_start() so it could "nicely" fail and here is > the last problem: regarding this fair amount of changes, how to ensure > the device will work as well as before? I don't have this device at home > or at work and it doesn't seems easy to find. Start small, at the "root" of the call chain, and work backwards. You aren't changing any logic, only passing the errors, if there are any, back on up. Now if the driver was relying on those functions to fail, that's a bug in the driver, and someone who has the hardware will notice and send us an email saying that the patches broke something. But that's a few months out, don't worry about that now :) thanks, greg k-h