Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp2438968iob; Fri, 20 May 2022 09:21:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzgN0ngUBNiBlZi5jrQgYFCEuEtzY+ePVC33berT6E1Z6Ev+OVNocIjyHlPQ4sZkWj73wDp X-Received: by 2002:a17:906:2001:b0:6f3:bd7f:d878 with SMTP id 1-20020a170906200100b006f3bd7fd878mr9365461ejo.133.1653063675161; Fri, 20 May 2022 09:21:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1653063675; cv=none; d=google.com; s=arc-20160816; b=O1h8ptsDhyVBskpWtV5BvAjaoWTNZqyzK4Vs3x6If82YAhMVACQ8bHl4qOfPkSgCCr mUDOq4xAwr7fAA3dDujqZdOKQWpN2ySNvQY2olW28tpMb/dDQBIxrTEaOQTPCGjQtJFG 4SM5p0enZ03mQatxxSVeM02nobOWIs+0fipedJ9cSJoGoG5flR7XLeXR/fXJsV90tQQY SZMuCwCMhjoWgR/L3FcXd1i9RFgRDYHqHH5pJVf0uHlpghQlSEwZo292so9m1yttUTSv MAP0EBvdJblloFO9GyZW2REacwh02kMtd2kA+f2PraEEf6DILL9BubH9N2GkSfATgjgW P0NQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=Q1nilk9iYZ9pn/Yjf+CNrl4nfLXcOef8E702x0wmhJ8=; b=FiOHDfTd1VUkJ4ouU7ItgyjloNGfhdPgRnPexssCNqmh3rvKIYVg0K3bUnLv9x7hdH P/u//tJc5Piaa742sWrRMRJEaBgcoCZKxyOXHyjLtNM+3NyYI2rWeu6X71ZD4SdLnqPj 0/fKTFnEBpiWsABxG00VdE/KZfRIo2dx5Ucx98c6hA0t4Ss3R21jGERbhezgJN6diEa8 kN2RzL9DAmlg7W8k034Q5dfF1J3qUrFzk2tNKkUVlolYR6DhTgMRMPZH0yzDIaUvpQbK ofs83s1z1OACFPwjxeVMWx0vFzjmde20zAubZFpu0/oVWYOrUSo36WbVBovN84qbaQ6/ WMEg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nd33-20020a17090762a100b006e8cb75fd59si659254ejc.723.2022.05.20.09.20.57; Fri, 20 May 2022 09:21:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1347402AbiETIwF (ORCPT + 69 others); Fri, 20 May 2022 04:52:05 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53546 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1347398AbiETIwC (ORCPT ); Fri, 20 May 2022 04:52:02 -0400 Received: from metis.ext.pengutronix.de (metis.ext.pengutronix.de [IPv6:2001:67c:670:201:290:27ff:fe1d:cc33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 85F9F5DD03 for ; Fri, 20 May 2022 01:52:01 -0700 (PDT) Received: from ptx.hi.pengutronix.de ([2001:67c:670:100:1d::c0]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1nryMX-0006Xw-Bd; Fri, 20 May 2022 10:51:57 +0200 Received: from sha by ptx.hi.pengutronix.de with local (Exim 4.92) (envelope-from ) id 1nryMW-0005Nx-Ak; Fri, 20 May 2022 10:51:56 +0200 Date: Fri, 20 May 2022 10:51:56 +0200 From: "s.hauer@pengutronix.de" To: Pkshih Cc: "linux-wireless@vger.kernel.org" , "johannes@sipsolutions.net" , "kernel@pengutronix.de" , "neojou@gmail.com" , "kvalo@kernel.org" , "tony0620emma@gmail.com" , "linux-kernel@vger.kernel.org" , "martin.blumenstingl@googlemail.com" , "linux@ulli-kroll.de" , "netdev@vger.kernel.org" , "neo_jou@realtek.com" Subject: Re: [PATCH 06/10] rtw88: Add common USB chip support Message-ID: <20220520085156.GE25578@pengutronix.de> References: <20220518082318.3898514-1-s.hauer@pengutronix.de> <20220518082318.3898514-7-s.hauer@pengutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Sent-From: Pengutronix Hildesheim X-URL: http://www.pengutronix.de/ X-IRC: #ptxdist @freenode X-Accept-Language: de,en X-Accept-Content-Type: text/plain X-Uptime: 10:21:45 up 50 days, 20:51, 53 users, load average: 0.08, 0.07, 0.09 User-Agent: Mutt/1.10.1 (2018-07-13) X-SA-Exim-Connect-IP: 2001:67c:670:100:1d::c0 X-SA-Exim-Mail-From: sha@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-wireless@vger.kernel.org X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org On Fri, May 20, 2022 at 07:39:03AM +0000, Pkshih wrote: > On Wed, 2022-05-18 at 10:23 +0200, Sascha Hauer wrote: > > Add the common bits and pieces to add USB support to the RTW88 driver. > > This is based on https://github.com/ulli-kroll/rtw88-usb.git which > > itself is first written by Neo Jou. > > > > Signed-off-by: neo_jou > > Signed-off-by: Hans Ulli Kroll > > Signed-off-by: Sascha Hauer > > --- > > drivers/net/wireless/realtek/rtw88/Kconfig | 3 + > > drivers/net/wireless/realtek/rtw88/Makefile | 2 + > > drivers/net/wireless/realtek/rtw88/mac.c | 3 + > > drivers/net/wireless/realtek/rtw88/main.c | 5 + > > drivers/net/wireless/realtek/rtw88/main.h | 4 + > > drivers/net/wireless/realtek/rtw88/reg.h | 1 + > > drivers/net/wireless/realtek/rtw88/tx.h | 31 + > > drivers/net/wireless/realtek/rtw88/usb.c | 1051 +++++++++++++++++++ > > drivers/net/wireless/realtek/rtw88/usb.h | 109 ++ > > 9 files changed, 1209 insertions(+) > > create mode 100644 drivers/net/wireless/realtek/rtw88/usb.c > > create mode 100644 drivers/net/wireless/realtek/rtw88/usb.h > > > > [...] > > > diff --git a/drivers/net/wireless/realtek/rtw88/reg.h b/drivers/net/wireless/realtek/rtw88/reg.h > > index 84ba9ec489c37..a928899030863 100644 > > --- a/drivers/net/wireless/realtek/rtw88/reg.h > > +++ b/drivers/net/wireless/realtek/rtw88/reg.h > > @@ -184,6 +184,7 @@ > > #define BIT_TXDMA_VIQ_MAP(x) \ > ^^^^^^^ replace 8 spaces by one tab This line is not added by me. There are spaces used before the linebreaks throughout this file. > > + do { > > + spin_lock_irqsave(&rtwusb->rx_data_list_lock, flags); > > + > > + rxcb = list_first_entry_or_null(&rtwusb->rx_data_free, > > + struct rx_usb_ctrl_block, list); > > + > > + spin_unlock_irqrestore(&rtwusb->rx_data_list_lock, flags); > > + if (!rxcb) > > + return; > > + > > + rxcb->rx_skb = alloc_skb(RTW_USB_MAX_RECVBUF_SZ, GFP_KERNEL); > > + if (!rxcb->rx_skb) { > > + rtw_err(rtwdev, "could not allocate rx skbuff\n"); > > + return; > > + } > > + > > + usb_fill_bulk_urb(rxcb->rx_urb, rtwusb->udev, > > + usb_rcvbulkpipe(rtwusb->udev, rtwusb->pipe_in), > > + rxcb->rx_skb->data, RTW_USB_MAX_RECVBUF_SZ, > > + rtw_usb_read_port_complete, rxcb); > > + > > + spin_lock_irqsave(&rtwusb->rx_data_list_lock, flags); > > + list_move(&rxcb->list, &rtwusb->rx_data_used); > > + spin_unlock_irqrestore(&rtwusb->rx_data_list_lock, flags); > > + > > + error = usb_submit_urb(rxcb->rx_urb, GFP_KERNEL); > > + if (error) { > > + kfree_skb(rxcb->rx_skb); > > + if (error != -ENODEV) > > + rtw_err(rtwdev, "Err sending rx data urb %d\n", > > + error); > > + rtw_usb_rx_data_put(rtwusb, rxcb); > > + > > + return; > > + } > > + } while (true); > > Can we have a limit of 'for(; > > +} > > + > > +static void rtw_usb_cancel_rx_bufs(struct rtw_usb *rtwusb) > > +{ > > + struct rx_usb_ctrl_block *rxcb; > > + unsigned long flags; > > + > > + spin_lock_irqsave(&rtwusb->rx_data_list_lock, flags); > > + > > + while (true) { > > + rxcb = list_first_entry_or_null(&rtwusb->rx_data_used, > > + struct rx_usb_ctrl_block, list); > > + > > + spin_unlock_irqrestore(&rtwusb->rx_data_list_lock, flags); > > + > > + if (!rxcb) > > + break; > > + > > + usb_kill_urb(rxcb->rx_urb); > > + > > + spin_lock_irqsave(&rtwusb->rx_data_list_lock, flags); > > + list_move(&rxcb->list, &rtwusb->rx_data_free); > > + } > > +} > > The spin_lock pairs are not intuitive. > Can we change this chunk to > > while (true) { > spin_lock(); > rxcb = list_first_entry_or_null(); > spin_unlock() > > if (!rxcb) > return; > > usb_free_urb(); > > spin_lock(); > list_del(); > spin_unlock(); > } > > The drawback is lock/unlock twice in single loop. Yes, that's why I did it the way I did ;) How about: while (true) { unsigned long flags; spin_lock_irqsave(&rtwusb->rx_data_list_lock, flags); rxcb = list_first_entry_or_null(&rtwusb->rx_data_free, struct rx_usb_ctrl_block, list); if (rxcb) list_del(&rxcb->list); spin_unlock_irqrestore(&rtwusb->rx_data_list_lock, flags); if (!rxcb) break; usb_free_urb(rxcb->rx_urb); } Sascha -- Pengutronix e.K. | | Steuerwalder Str. 21 | http://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |