Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp944705pxb; Tue, 8 Feb 2022 06:07:05 -0800 (PST) X-Google-Smtp-Source: ABdhPJzlJ9rEYICp/iZ3oEyjicr0U0necTVNKxP9hLlvi/nluX1nfoYuq+dO9bXXmNjHDhJbsitR X-Received: by 2002:a17:902:9308:: with SMTP id bc8mr4777641plb.147.1644329225146; Tue, 08 Feb 2022 06:07:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1644329225; cv=none; d=google.com; s=arc-20160816; b=Sbb6AUbjKTLJEyvrafUAhXq4c+iefL81IUiIrGswh1oqmuMP3RSs8sZL6wT4pB/sC5 /xCzkkaMz8XQYQrbpmC+q20MFAXjH3EuTMH4CwnJshKp8olGrCGW2ThcpJRE9SklsF/L kditzhyGWbkD4384J5vrBVtFH9gcgR9L7sOlfwBkhDgrlOY/Sxy2WDiL/2S+WiYQVoE4 RMDBB71wzhh4AAoGzmMotx2nJdqFOjo0z5VmfWV39x98ts5qVGsLm/J6FZ2YU1xIt1Ic ekq97gm48mqdAZB1dz3y/5+2YB6QnxW/GTycDXHMAmPRGxQiXzSHZy0yqNvoEttRyMNP Cdyg== 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:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=zT3oKzS7n7TI0D8XaL63jjRHo7FI4UGfj4YRLtEmDxg=; b=SmNLyZRLhFqMnil9Pc+y6i06OsVYwDygXqw0qzv3Z7Hg5edr41viivRv0oxB0rhgy0 V4dkC1cUo7ZkfBZp1pn0M7bzXTxihJtp136HN/e7l8ynfqY06ZXCvjT+J9r85rlL2+yF Yl+q6G1gn2khW1xO+hyfDsrsI378CnKi3ZtlHJhp/HfGfJF1I/oB8fVWEJgYkwgLV6jz YSiYlJ++vKujhN9Kx/1hLJwZTxr2Q4SgYD3klsdokPKZ6h/5KdOnDKfir5wYLgQtJXnv 1bOqoq3PD0GAgvMhL6bEgG+FJthR8mEijZ2ZcM3jiznXNT66tln2Wa8meLNY0pft1UaL umlQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=QR4Jc2mI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 16si3792359pfm.155.2022.02.08.06.06.52; Tue, 08 Feb 2022 06:07:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-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=@gmail.com header.s=20210112 header.b=QR4Jc2mI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237337AbiBGVNN (ORCPT + 99 others); Mon, 7 Feb 2022 16:13:13 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41604 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235998AbiBGVNL (ORCPT ); Mon, 7 Feb 2022 16:13:11 -0500 Received: from mail-ed1-x535.google.com (mail-ed1-x535.google.com [IPv6:2a00:1450:4864:20::535]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 09DFDC06173B; Mon, 7 Feb 2022 13:13:11 -0800 (PST) Received: by mail-ed1-x535.google.com with SMTP id l25so12550369eda.12; Mon, 07 Feb 2022 13:13:10 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=message-id:date:mime-version:user-agent:subject:content-language:to :cc:references:from:in-reply-to:content-transfer-encoding; bh=zT3oKzS7n7TI0D8XaL63jjRHo7FI4UGfj4YRLtEmDxg=; b=QR4Jc2mIcnWKHiYdoFEJ5zevhFJyEliAI5KBqZrUbY9rLUnmJuFmL5mMzVoJQveBx6 bQKjeiAEyGGkvvKddmCr4S0JElAz3tca5rUbg9We0fHqb6MJhOU3cbspzMY7eP5q3VSv o73vYEdAF5+amj8IL/ESmg3zp2/x6vzygRMHArv14zYwJsjV/z+qZDGo04DAUZEt7TQd 5q3hEJf/+LcyDZG2f556d1kDc8HVzfvkdYmTUtYi/PtpFDb+zdv32TgeFqvgB0slNyHb gPv40errXwoy706jxPdyeF8dAh3O2tPaKh7Iwga0jwATcDdGGJR0Fps0AfOmnEIO4Ccf 6UJQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :content-language:to:cc:references:from:in-reply-to :content-transfer-encoding; bh=zT3oKzS7n7TI0D8XaL63jjRHo7FI4UGfj4YRLtEmDxg=; b=ikGdHmzinLGnY385TcpwaA+lPnsNXo6KkctiR0js8RBGuMWlegb5RE5BEn2F/hgwy9 MHtT5XI9yl3csswLJilozlziXqUtRmildx3vzy5cBMRaQQM17SJk6qCthBaARvzxYJ7y A/Dq4oGxxTffDWHzQqqJq7cu+ZrH3jIpZsGUrimDnYVVJpeVZGESJ+R8qBv8p2FuPMtk C6DAxmP30+cGV7zZJNXxf1uo1YqtL/9CcCJMmxZQXYc2TcYzG51JgPhTEuS3HLo0LaIC GpD0/pX/CsIgiGwYrPw0DymEBClIkDSIHbyhywGmSD+Ck9KFCmaqk/ZM3rs/FmL9pFQn lRRw== X-Gm-Message-State: AOAM530iHn7zNw9naD+t+fsplVwqCvucZBFTRtKF38cR5DhIIztJaFY8 ItRHgz7/Jx5Xh5tvwVXk+xJqBN66M7c= X-Received: by 2002:a05:6402:254a:: with SMTP id l10mr1340361edb.318.1644268389476; Mon, 07 Feb 2022 13:13:09 -0800 (PST) Received: from debian64.daheim (pd9e292b6.dip0.t-ipconnect.de. [217.226.146.182]) by smtp.gmail.com with ESMTPSA id z6sm4058135ejd.96.2022.02.07.13.13.08 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 07 Feb 2022 13:13:08 -0800 (PST) Received: from localhost.daheim ([127.0.0.1]) by debian64.daheim with esmtp (Exim 4.95) (envelope-from ) id 1nHAN7-001CUZ-Os; Mon, 07 Feb 2022 22:13:08 +0100 Message-ID: Date: Mon, 7 Feb 2022 22:13:08 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.5.1 Subject: Re: [BUG] intersil: p54: possible deadlock in p54_remove_interface() and p54_stop() Content-Language: en-US To: Jia-Ju Bai , chunkeey@googlemail.com, kvalo@kernel.org, davem@davemloft.net, kuba@kernel.org Cc: linux-wireless@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org References: From: Christian Lamparter In-Reply-To: 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,FREEMAIL_FROM,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,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-kernel@vger.kernel.org Hi, On 07/02/2022 16:31, Jia-Ju Bai wrote: > Hello, > > My static analysis tool reports a possible deadlock in the p54 driver in Linux 5.16: > > p54_remove_interface() >   mutex_lock(&priv->conf_mutex); --> Line 262 (Lock A) > wait_for_completion_interruptible_timeout(&priv->beacon_comp, HZ); --> Line 271 (Wait X) > > p54_stop() >   mutex_lock(&priv->conf_mutex); --> Line 208 (Lock A) >   p54p_stop() (call via priv->stop) >     p54_free_skb() >       p54_tx_qos_accounting_free() >         complete(&priv->beacon_comp); --> Line 230 (Wake X) > > When p54_remove_interface() is executed, "Wait X" is performed by holding "Lock A". > If p54_stop() is executed at this time, "Wake X" cannot be performed to wake > up "Wait X" in p54_remove_interface(), because "Lock A" has been already hold by > p54_remove_interface(), causing a possible deadlock. > > I find that "Wait X" is performed with a timeout, to relieve the possible deadlock; > but I think this timeout can cause inefficient execution. > > I am not quite sure whether this possible problem is real and how to fix it if it is real. > Any feedback would be appreciated, thanks :) This has been such a long long time ago. But I think I found the right documentation entry for you: (scroll down a bit) | remove_interface | Notifies a driver that an interface is going down. | >>The stop callback is called after this if it is the last interface | and no monitor interfaces are present.<< | (it goes on a bit. But I don't think there's anything important left) The documentation tells you not to worry. p54_stop() and p54_remove_interface() are being serialized by mac80211. Cheers, Christian