Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp7731784rwl; Tue, 10 Jan 2023 04:52:15 -0800 (PST) X-Google-Smtp-Source: AMrXdXtGomcxkpY1cLZA1XiOOIQcEfPcsXWOlonFVJYAZEtKb88DkmhdFe0J+EYSxdL0TWjsG7ik X-Received: by 2002:a17:907:d093:b0:7c0:cd95:bbb7 with SMTP id vc19-20020a170907d09300b007c0cd95bbb7mr54339054ejc.77.1673355135239; Tue, 10 Jan 2023 04:52:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673355135; cv=none; d=google.com; s=arc-20160816; b=JQkvNCSRLMq0YiDI+o1XWOz+2o9qhrt5vPB1qRtb5DEgLEpNuE9C/lBwRWaXzxj5hI xRwDcO2DeZafwK347bdrCqgIStT4t4CrIzRQ+gH1aAaJRf6JkqaDTcv6kwkF33/eQq5H IKtjbozFLW0wv4L80AYgRkk1WDpYDHD3dqnZbj6KmUoS0u2cKzXtDUlMSUcAA4Attgz9 6kIkR/Q71Ww82sqFXnzjs4ShdLx5DybAvJw/UAgSmvoOJL8tgEQcOrlE84y+rFt3CUmx H20n4H4vL15AVhCxOW/Ab88HjX+CYFD0y4oG7qZlL/Bh/EoLXuCgiH+9bIx72dkLnXzk vI6Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:references :to:from:content-language:subject:user-agent:mime-version:date :message-id:dkim-signature; bh=cO7o6zy9XbYcdv1KxtYdYV7GfWo9hu8NVg99Zup2H9k=; b=YuwAZagSPRIok3xY8gGU0O0OaTjKhJ1wJ2dhI51lfdAAHTlzCAtIOU7zUtqPENOEUC 5Mite0bVHPTMIcnHZ/WUNWgI/2gmDObpcYO+u/jCTWCNFmH+PMnRuOikwqmDAE6cWDO0 5cG2tgkH79tchdgLqPLCkciomhqUgIURppy07CosJc4pMfORU5Y0SNb1uOxhWz0DwHOB 1CawrOKW7w6dpjkMdKyf5x3hf3DtJiHFYBWUqu7+LQ56GXIet92YblTwPMOxbXSi4lej 4eNr6aih9iICgD175ZXS9e6w4ANIm6mtPosYUiEb8tH33lsQVgsMX/q3wxgmrNTsYuZC Z3LQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=Cc8RYrCq; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id t4-20020a056402524400b0046bd9b65cd9si2072235edd.242.2023.01.10.04.51.58; Tue, 10 Jan 2023 04:52:15 -0800 (PST) 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; dkim=pass header.i=@linaro.org header.s=google header.b=Cc8RYrCq; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232678AbjAJMo2 (ORCPT + 65 others); Tue, 10 Jan 2023 07:44:28 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53776 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238473AbjAJMoK (ORCPT ); Tue, 10 Jan 2023 07:44:10 -0500 Received: from mail-wm1-x333.google.com (mail-wm1-x333.google.com [IPv6:2a00:1450:4864:20::333]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AD0394FD40 for ; Tue, 10 Jan 2023 04:44:09 -0800 (PST) Received: by mail-wm1-x333.google.com with SMTP id p1-20020a05600c1d8100b003d8c9b191e0so9788421wms.4 for ; Tue, 10 Jan 2023 04:44:09 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:in-reply-to:references:to:from :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=cO7o6zy9XbYcdv1KxtYdYV7GfWo9hu8NVg99Zup2H9k=; b=Cc8RYrCqPQ4c95px4RkdI6rs5reesi/TMAVQ218tvGHEb3pId+EqOHCSSSSsnBGWis MK0N1gzx1+sX9EgzsaY1iGgUmUpyEmCYxHJ5FUrR7DvXUznIT+xby0ei30EZ3laua0mu C6Pm/PfMsSn/PfGthjDHczsoLvHo1pmjaOIFeoOrb1YKJlJAi0gplcwKHaRdk/+Bm5LY i0nDFADAHKbSrSXLPCy7D+amF8e+Si55GhmS/6Rep7xWZ65IF6GuEO87Sa+XcPxlDHzk UlXxfs5urTUZRfBKQXytgNIiNJAG77e7suskerqeiXBxNPQ5y6ZnQn5xA4XBcZTcWA6E 6NiA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:in-reply-to:references:to:from :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=cO7o6zy9XbYcdv1KxtYdYV7GfWo9hu8NVg99Zup2H9k=; b=qUGUl/VnAr9/wIaICugO6WRhwYQ/y+jtESdr6NM9n7SxjfXdwoqnyxzJHKrPA4QF+b u5rFbxsk0O5XqFyw8uhL4psD4CeYqJgyzmnG2WiVT+P73MzW9qoq+V80rwQusc6drJBC MArExtQvYVYR71T06hVzYd7s5y5N47SoV+iaQ/2gLy1/eUZaAUoXd6MaqpxtUrqq5JyK +81qoWruYyVEIcBXUD1F+w5pZX+mgAD6FrIouY1kmNsaceUuWOqL4cfMUSkYEBvxVy41 L/+YyYXMwGztPysqpTMAJjNvU3WPccGLvH03giFkPQ7g4/Lypeo8TiFXOkocsf3/5hKt osAA== X-Gm-Message-State: AFqh2koPdLDztUbHlsgHpKZwu4SLsLelMytaQM1NkddsOwwxZCvLR7qW bMgC5ZKLp/D2MEL/2ncF87LvqQ== X-Received: by 2002:a05:600c:1d89:b0:3d3:5cd6:781 with SMTP id p9-20020a05600c1d8900b003d35cd60781mr48576618wms.37.1673354648289; Tue, 10 Jan 2023 04:44:08 -0800 (PST) Received: from [192.168.0.162] (188-141-3-169.dynamic.upc.ie. [188.141.3.169]) by smtp.gmail.com with ESMTPSA id m17-20020a05600c3b1100b003cfbbd54178sm1899192wms.2.2023.01.10.04.44.07 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 10 Jan 2023 04:44:07 -0800 (PST) Message-ID: <06f76774-1b2e-f563-7128-7d5b9547dfe9@linaro.org> Date: Tue, 10 Jan 2023 12:44:07 +0000 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.5.0 Subject: Re: ieee80211_handle_wake_tx_queue and dynamic ps regression Content-Language: en-US From: Bryan O'Donoghue To: linux-kernel@vger.kernel.org, alexander@wetzel-home.de, johannes.berg@intel.com, Kalle Valo , linux-wireless@vger.kernel.org References: <19015168-c747-17b7-f0ae-9d2ee27d221c@linaro.org> In-Reply-To: <19015168-c747-17b7-f0ae-9d2ee27d221c@linaro.org> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS 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 + linux-wireless On 10/01/2023 12:35, Bryan O'Donoghue wrote: > commit a790cc3a4fad75048295571a350b95b87e022a5a > (wake_tx_queue-broken-23-08-01) > Author: Alexander Wetzel > Date:   Sun Oct 9 18:30:39 2022 +0200 > >     wifi: mac80211: add wake_tx_queue callback to drivers > > is causing a regression with > > - CONF_PS = 1 > - CONF_DYNAMIC_PS = 0 > - ieee80211_handle_wake_tx_queue > > In this case we get stuck in a loop similar to this > > // IEEE80211_CONF_CHANGE_PS > [   17.255480] wcn36xx: wcn36xx_change_ps/312 enable > [   18.088835] ieee80211_tx_h_dynamic_ps/263 setting > IEEE80211_QUEUE_STOP_REASON_PS > [   18.088906] ieee80211_handle_wake_tx_queue/334 entry > [   18.091505] ieee80211_dynamic_ps_disable_work/2250 calling > ieee80211_hw_config() > [   18.095370] ieee80211_handle_wake_tx_queue/338 wake_tx_push_queue > > // IEEE80211_CONF_CHANGE_PS > [   18.102625] wcn36xx: wcn36xx_change_ps/312 disable > [   18.107643] wake_tx_push_queue/303 entry > > // txq is stopped here reason == IEEE80211_QUEUE_STOP_REASON_PS > [   18.107654] wake_tx_push_queue/311 q_stopped bitmask 0x00000002 > IEEE80211_QUEUE_STOP_REASON_PS true > [   18.107661] wake_tx_push_queue/324 exit > [   18.107667] ieee80211_handle_wake_tx_queue/342 exit > [   18.115560] ieee80211_handle_wake_tx_queue/334 entry > [   18.139937] ieee80211_handle_wake_tx_queue/338 wake_tx_push_queue > [   18.145163] wake_tx_push_queue/303 entry > [   18.150016] ieee80211_dynamic_ps_disable_work/2252 completed > ieee80211_hw_config() > > // now we unset IEEE80211_QUEUE_STOP_REASON_PS but too late > [   18.151145] wake_tx_push_queue/311 q_stopped bitmask 0x00000002 > IEEE80211_QUEUE_STOP_REASON_PS true > [   18.155263] ieee80211_dynamic_ps_disable_work/2254 clearing > IEEE80211_QUEUE_STOP_REASON_PS > [   18.162531] wake_tx_push_queue/324 exit > [   18.162548] ieee80211_handle_wake_tx_queue/342 exit > [   18.183639] ieee80211_dynamic_ps_disable_work/2259 cleared > IEEE80211_QUEUE_STOP_REASON_PS > > // IEEE80211_CONF_CHANGE_PS runs again > [   18.215487] wcn36xx: wcn36xx_change_ps/312 enable > > We get stuck in that loop. Packets getting transmitted is a rare event, > most are dropped. > > I tried this as a fix > > --- a/net/mac80211/mlme.c > +++ b/net/mac80211/mlme.c > @@ -2245,15 +2245,15 @@ void ieee80211_dynamic_ps_disable_work(struct > work_struct *work) >                 container_of(work, struct ieee80211_local, >                              dynamic_ps_disable_work); > > -       if (local->hw.conf.flags & IEEE80211_CONF_PS) { > -               local->hw.conf.flags &= ~IEEE80211_CONF_PS; > -               ieee80211_hw_config(local, IEEE80211_CONF_CHANGE_PS); > -       } > - >         ieee80211_wake_queues_by_reason(&local->hw, >                                         IEEE80211_MAX_QUEUE_MAP, >                                         IEEE80211_QUEUE_STOP_REASON_PS, >                                         false); > + > +       if (local->hw.conf.flags & IEEE80211_CONF_PS) { > +               local->hw.conf.flags &= ~IEEE80211_CONF_PS; > +               ieee80211_hw_config(local, IEEE80211_CONF_CHANGE_PS); > +       } >  } > > but it only "slightly improves" the situation, the fundamental race > condition is still there. > > Suggest reverting this change and trying again. > > --- > bod