Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp1088442rwb; Fri, 18 Nov 2022 12:34:10 -0800 (PST) X-Google-Smtp-Source: AA0mqf5R6kfD2ESXvCcs+z933SwFNnzGJ/t6/EhxHiGmQBvBEM1H1zg5V1VjGPpQQTOM2XHNsXsv X-Received: by 2002:a17:90a:d581:b0:212:b43b:ffe5 with SMTP id v1-20020a17090ad58100b00212b43bffe5mr9578598pju.32.1668803650338; Fri, 18 Nov 2022 12:34:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1668803650; cv=none; d=google.com; s=arc-20160816; b=BSYj1+fksyxGHemPNsfRgPi1J7sG2/T2JadqFqRINzHQCp1vsCK5OnaWJTDLZh2zLR U38cwzcOELDocfjGa7ETCWc66+T8kTQVcIBMqCrIniBrU0j+OFOwoJGH8bEinRiWGNWx lu+EhyGfO1gdRYp6XzaaACbQKe1gj5dVvvTTYim/z8V55LrzI9bMdjtaG86YGa/VxQlj UxNCZm6usOw2fI0+FJJgUgZZGXCBPr1Z7I3tYYOfvjzqS7FZZJJ7u2uw25Sr/Sm737HH im3nWIguWTph5SO7iFXxwflCsWUetJaOGYM6CfVJmiX8J21tc6wb3Yi1FifH1pCzBs3S wSRg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=GPrbHb3+211d62G+QcXXF3a3BGF9p+XV97IR2W1Bg5Q=; b=VZd9UP5qaNjqHVRuHWy4/vZ0+jYszv69+E2qoAMJvujro+J/2jmxaD0q/aOwIYqZlb bG9zNQSpXl86SomYqXunRDT/odWmb4f/IhGTI0Guq/jg3hzYMJY2EcvTeqtrHLToWm+8 Lanh7WVOIZRveh5HZ3SqBBVkDHf5ZUnTKDnEG3daqRw1f+XOGytybYYULGHSnUmYNLl+ HLaQo/aYeWPF0wdgjvIH9HKkUswnhy45BZHCQ7e9sGnm1gcOHAv2K7XZyPxaLw4z8Kf7 QUwF2+Th5Q4eKgT8mbrOaVB9I6gzshpCLxEZLJpVwutjXbenPm2W7QF+w+evqlVc7RLF RKKw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=V4M+7rpB; 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 u18-20020a627912000000b00547a857b7b3si4212466pfc.375.2022.11.18.12.33.51; Fri, 18 Nov 2022 12:34:10 -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=V4M+7rpB; 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 S230293AbiKRUBr (ORCPT + 91 others); Fri, 18 Nov 2022 15:01:47 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42304 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229451AbiKRUBo (ORCPT ); Fri, 18 Nov 2022 15:01:44 -0500 Received: from mail-lj1-x22f.google.com (mail-lj1-x22f.google.com [IPv6:2a00:1450:4864:20::22f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7126FC78DD for ; Fri, 18 Nov 2022 12:01:43 -0800 (PST) Received: by mail-lj1-x22f.google.com with SMTP id s24so8064983ljs.11 for ; Fri, 18 Nov 2022 12:01:43 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc:subject:date:message-id:reply-to; bh=GPrbHb3+211d62G+QcXXF3a3BGF9p+XV97IR2W1Bg5Q=; b=V4M+7rpBcdBq7/hYVteWBRv/ty9ZWDcURM5JZ9qyrcMFVooRl1eo4zZCg3WQDC72I0 1lsFdGZNc3Y7OGESG5dDeJD7p0K1sPRqj8+Bt62UeYA89s+Xguogj760lOIAL1vBZLyR zXtRfSpUhQ94V3BbdirO4NVCCuRMFQaXJHg1VqiC9a39yRUx48WWTM/nYK8xftob/o2m /qgDs5gTNtBRjDCv2RJurR/vEbNq3sX5ZATa45xB4pAN0HbwomgDN7r+em7i5Zm6irkV ArTYp8Xh4or840xzajEZ+qRVLHmID0ApCA3bj5+3+uiQXmE4I6gjX8r6VY4mDVBqR/Ut /0ag== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=GPrbHb3+211d62G+QcXXF3a3BGF9p+XV97IR2W1Bg5Q=; b=Bgsyct19fbf9gjhXvUEEweEZe1U6QxI+vvL1E36H8XfjvxCBqLbosiIdACV4vHJqG2 sc8xgULXOc2d4vGOZ1rm2dp8w7Sq0MHc3hlQpi+i4iud/zcTfNSCa68jup/IKSi/UV2B 8OfO5JIKf3FIi4AUuwkDTv/9+K015WVIfVhwYYLl7SsvqBQUXoaxiqUDmSCRSCFpbEE1 5q+tOHPd1JgEG6nVbsfMuKHvsdpaI04M/i3e9DWnj72A5x+nuGto/Z357ZTyrX+syEnA b1wvXo+Nr2PU+q/mxNls9uTZDNe8i9y4gZH/VkqQfwvVzNCZB94iM/rEOutkvXAkpg7c N0AQ== X-Gm-Message-State: ANoB5pnYZ95b/xegFREBhH4C/obZsrLN/qeBscfSCORTcrPtY+KHov4Q SPtpQ1HKWTpDI/MGYgBjzrqpv0oRmd70rkUGzpOQ8srS/MU= X-Received: by 2002:a2e:87ce:0:b0:277:ddf:f476 with SMTP id v14-20020a2e87ce000000b002770ddff476mr3035239ljj.432.1668801701538; Fri, 18 Nov 2022 12:01:41 -0800 (PST) MIME-Version: 1.0 References: <0000000000009d5daa05ed9815fa@google.com> <20221117024511.3606-1-hdanton@sina.com> <20221117125523.3783-1-hdanton@sina.com> <87wn7tlg4n.ffs@tglx> <20221118012805.3862-1-hdanton@sina.com> In-Reply-To: <20221118012805.3862-1-hdanton@sina.com> From: Luiz Augusto von Dentz Date: Fri, 18 Nov 2022 12:01:29 -0800 Message-ID: Subject: Re: [syzbot] WARNING in call_timer_fn To: Hillf Danton Cc: Thomas Gleixner , syzbot , linux-kernel@vger.kernel.org, pbonzini@redhat.com, syzkaller-bugs@googlegroups.com, Steven Rostedt , Marcel Holtmann , Tetsuo Handa Content-Type: text/plain; charset="UTF-8" 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, 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-kernel@vger.kernel.org Hi Hillf, On Thu, Nov 17, 2022 at 5:28 PM Hillf Danton wrote: > > On Thu, Nov 17, 2022 at 1:04 PM Luiz Augusto von Dentz wrote: > > > > > > I thought we would have something similar to shutdown_timer (e.g. > > > shutdown_delayed_work) so we can safely free its object/struct, at > > > least that was the impression I got when discussing with Steven. > > Because of the cough in Bluetooth's throat does not mean it makes sense > to ask workqueue to take a flu jab. Why not cure it directly locally, > given the cases of workqueue under the drivers dir. And timer? Like Thomas said we can only resolve this partially with the likes of cancel_workqueue(_sync), though we can use HCI_UNREGISTER to stop rescheduling cmd_timer, so imo having something similar to shutdown_timer makes things simpler for subsystems/drivers, anyway I'm fine fixing it directly since it is probably going to be simpler to backport, perhaps something like the following is all we need: diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c index 0540555b3704..977684f5fb57 100644 --- a/net/bluetooth/hci_core.c +++ b/net/bluetooth/hci_core.c @@ -4090,6 +4090,7 @@ static void hci_cmd_work(struct work_struct *work) rcu_read_lock(); if (test_bit(HCI_RESET, &hdev->flags) || + test_bit(HCI_UNREGISTER, &hdev->flags) || hci_dev_test_flag(hdev, HCI_CMD_DRAIN_WORKQUEUE)) cancel_delayed_work(&hdev->cmd_timer); else -- Luiz Augusto von Dentz