Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3066431pxf; Mon, 5 Apr 2021 02:12:05 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzk98aiJXQgWVjel1QsvA9dGmbWbGMaGOgpHZX1hv42uCaTpjjCez5vlY7aaG9p80Ti38UQ X-Received: by 2002:a6b:5b0a:: with SMTP id v10mr19179679ioh.37.1617613925202; Mon, 05 Apr 2021 02:12:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617613925; cv=none; d=google.com; s=arc-20160816; b=bINZFZdkKkf1d8H+6F+qiwodRA7nLGGWRzp7Vz20gjGIz6ryJy9fbQOGcqPbKZjL3g vcfJo0yPkw/5J1163tUtnEbZYfr+pzFJ4fgRa2l3tkC+ZSIvHP2F4cs20ZxY1AlhB5jC m1NDE+U0LkD8qTUoTovHbpzRwFbqlw0LgSEuEg7OoBb3mjVjdPEzcUPxEsYj6HScjVQ8 tNuEeAgRNjenP3+hMn/43bGOtT7+bG3b5CjKuWXNWOFQXjSIIH3ikYv4RR9R+AUw4IZ8 oWO9xPs8oGT21ZewGkVBCiT0hVIqKAMOLabo+yUfjk423dUjInFCRcfwqQ/LfIbVg/5b Gq0Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=CazK6V24ruJjawY6OtTPMo/pzAPNyGtkQYR55hr7aPE=; b=Cnkddt0IKOc4jtUKtH+NABFMJsIm1V0JzOykPnM3v1kU2eqnc3+HW78y1OZcF9o/hI w8E5XF4my3c0I9bcyLb7eaSXxVBoV2pEsRgxJU1z2VXkItc0PZ1zmDIuQGEfoi+kMsGG tuzDWLJapeAj5oRs5QJxGIB+dTOjY9zk2vVQFAiN6MiUTvqcA/MiGG6Oy5dDYAnDZdpQ ODSYzBN2FeK1t6A92GREwVtfejdvxr2yb8GEvTZHNhbnkXm9M0wfuxIe+b+ZKyrZvMEo nAGZab01mOqj3OhoFxurDPsun65oYV1GzXzgCMlgWc51RcO3SjfOVogkhzfM2yOdS4wi 2lgw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-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 p7si14659381iol.88.2021.04.05.02.11.46; Mon, 05 Apr 2021 02:12:05 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-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-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238728AbhDEJKx (ORCPT + 99 others); Mon, 5 Apr 2021 05:10:53 -0400 Received: from smtp13.smtpout.orange.fr ([80.12.242.135]:35756 "EHLO smtp.smtpout.orange.fr" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S239056AbhDEJJ0 (ORCPT ); Mon, 5 Apr 2021 05:09:26 -0400 Received: from localhost.localdomain ([90.126.11.170]) by mwinf5d73 with ME id ox9G2400A3g7mfN03x9HB9; Mon, 05 Apr 2021 11:09:18 +0200 X-ME-Helo: localhost.localdomain X-ME-Auth: Y2hyaXN0b3BoZS5qYWlsbGV0QHdhbmFkb28uZnI= X-ME-Date: Mon, 05 Apr 2021 11:09:18 +0200 X-ME-IP: 90.126.11.170 From: Christophe JAILLET To: Jes.Sorensen@gmail.com, kvalo@codeaurora.org, davem@davemloft.net, kuba@kernel.org Cc: linux-wireless@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, kernel-janitors@vger.kernel.org, Christophe JAILLET Subject: [PATCH] rtl8xxxu: Simplify locking of a skb list accesses Date: Mon, 5 Apr 2021 11:09:14 +0200 Message-Id: <8bcec6429615aeb498482dc7e1955ce09b456585.1617613700.git.christophe.jaillet@wanadoo.fr> X-Mailer: git-send-email 2.27.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org The 'c2hcmd_lock' spinlock is only used to protect some __skb_queue_tail() and __skb_dequeue() calls. Use the lock provided in the skb itself and call skb_queue_tail() and skb_dequeue(). These functions already include the correct locking. Signed-off-by: Christophe JAILLET --- drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu.h | 1 - drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_core.c | 11 ++--------- 2 files changed, 2 insertions(+), 10 deletions(-) diff --git a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu.h b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu.h index d6d1be4169e5..d1a566cc0c9e 100644 --- a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu.h +++ b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu.h @@ -1391,7 +1391,6 @@ struct rtl8xxxu_priv { struct delayed_work ra_watchdog; struct work_struct c2hcmd_work; struct sk_buff_head c2hcmd_queue; - spinlock_t c2hcmd_lock; struct rtl8xxxu_btcoex bt_coex; struct rtl8xxxu_ra_report ra_report; }; diff --git a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_core.c b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_core.c index 5cd7ef3625c5..0eba42f2a66c 100644 --- a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_core.c +++ b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_core.c @@ -5423,7 +5423,6 @@ static void rtl8xxxu_c2hcmd_callback(struct work_struct *work) struct rtl8xxxu_priv *priv; struct rtl8723bu_c2h *c2h; struct sk_buff *skb = NULL; - unsigned long flags; u8 bt_info = 0; struct rtl8xxxu_btcoex *btcoex; struct rtl8xxxu_ra_report *rarpt; @@ -5439,9 +5438,7 @@ static void rtl8xxxu_c2hcmd_callback(struct work_struct *work) goto out; while (!skb_queue_empty(&priv->c2hcmd_queue)) { - spin_lock_irqsave(&priv->c2hcmd_lock, flags); - skb = __skb_dequeue(&priv->c2hcmd_queue); - spin_unlock_irqrestore(&priv->c2hcmd_lock, flags); + skb = skb_dequeue(&priv->c2hcmd_queue); c2h = (struct rtl8723bu_c2h *)skb->data; @@ -5499,7 +5496,6 @@ static void rtl8723bu_handle_c2h(struct rtl8xxxu_priv *priv, struct rtl8723bu_c2h *c2h = (struct rtl8723bu_c2h *)skb->data; struct device *dev = &priv->udev->dev; int len; - unsigned long flags; len = skb->len - 2; @@ -5538,9 +5534,7 @@ static void rtl8723bu_handle_c2h(struct rtl8xxxu_priv *priv, break; } - spin_lock_irqsave(&priv->c2hcmd_lock, flags); - __skb_queue_tail(&priv->c2hcmd_queue, skb); - spin_unlock_irqrestore(&priv->c2hcmd_lock, flags); + skb_queue_tail(&priv->c2hcmd_queue, skb); schedule_work(&priv->c2hcmd_work); } @@ -6606,7 +6600,6 @@ static int rtl8xxxu_probe(struct usb_interface *interface, spin_lock_init(&priv->rx_urb_lock); INIT_WORK(&priv->rx_urb_wq, rtl8xxxu_rx_urb_work); INIT_DELAYED_WORK(&priv->ra_watchdog, rtl8xxxu_watchdog_callback); - spin_lock_init(&priv->c2hcmd_lock); INIT_WORK(&priv->c2hcmd_work, rtl8xxxu_c2hcmd_callback); skb_queue_head_init(&priv->c2hcmd_queue); -- 2.27.0