Received: by 2002:a05:7412:b995:b0:f9:9502:5bb8 with SMTP id it21csp6541775rdb; Tue, 2 Jan 2024 05:33:52 -0800 (PST) X-Google-Smtp-Source: AGHT+IFO5oNoiJ4dDx+vo1N/i6mX/5DRr2XvQwf95WjG/KMVF4/gapEhDxlqIbGiZ/p9ZWq0sLsJ X-Received: by 2002:a05:6e02:214d:b0:35f:ce83:95af with SMTP id d13-20020a056e02214d00b0035fce8395afmr18987315ilv.56.1704202432457; Tue, 02 Jan 2024 05:33:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1704202432; cv=none; d=google.com; s=arc-20160816; b=YlqKqI2ZM3XpWzqRR7zLL6Gy/EGYkXg61IFSbu1nZv+vcXnY8Y+0gE3m/kjieYD0AL GgL/DJL1HcQzkqrp2G4lgUJyf4SkbRjgHJ8NV2Ss3KCfXCe3TRtqUlC7sWDkWI9HQtXG PpL3xq0WGZfI2Skw5JQiwuXUBJwfjFSMeORLjzP+Z9TzSvCltMkD/6VxBcWif1/meRfP dOCZoSbL36mpYv2brDQalVy+fA5kZn10opNgJDOiLXhyr9Lou9d7TI4cv5puTs4QORDJ xdpsOlAxDz+Yim9VAdjcYruPJKIlvymCHYbRcfeQEasPwC4M9bMD3VuiAlmsHsreHPOv gGKQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from; bh=87+jM2180EUyQlCWJD7RFO6Vd7lJRZXroSxhcNUu254=; fh=S5rf2bc7VLlSXYQ0EqFAIodb1qEiUfsxulvZhQKZRws=; b=J58egR2F/OkCZ4lDXlJW2CRfhKNLEvhvNMR/M9Beg+4fvmkGIMjclBzOaRb5VGD3FX aE1So7hgexHgM76ntEutMcqHxJh9xnJXsOwNjyY/GVMH4+j6MTw5ws9BkQ398fHFyBYq gPcVjsf2h/5cTbVElJbCah6X9MJ7ckyE47u1ihAmpa8Ww8Y/9m6uS5qjMX1O16CUYPt7 D3koTIWhxM9ITDc05UjbaZyO4spCvZ12XczykcywVh86u2oxuuNXznOw33Lb4vWdVnmc qUKuyIQ+hAtNety5FhMTsgPxxxSCmuQqDu17Mv/+/yoVhKgUbKMYJYA0x76Jdi5FOLhI zKaQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-bluetooth+bounces-802-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-802-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id w8-20020a63f508000000b005c668a5a90esi20157988pgh.596.2024.01.02.05.33.51 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Jan 2024 05:33:52 -0800 (PST) Received-SPF: pass (google.com: domain of linux-bluetooth+bounces-802-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-bluetooth+bounces-802-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-802-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id DC6BDB215D2 for ; Tue, 2 Jan 2024 13:33:48 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 79480FC18; Tue, 2 Jan 2024 13:33:28 +0000 (UTC) X-Original-To: linux-bluetooth@vger.kernel.org Received: from mout-p-202.mailbox.org (mout-p-202.mailbox.org [80.241.56.172]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id C01BAFBEC; Tue, 2 Jan 2024 13:33:25 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=v0yd.nl Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=v0yd.nl Received: from smtp2.mailbox.org (smtp2.mailbox.org [IPv6:2001:67c:2050:b231:465::2]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by mout-p-202.mailbox.org (Postfix) with ESMTPS id 4T4DM61GV8z9t16; Tue, 2 Jan 2024 14:33:22 +0100 (CET) From: =?UTF-8?q?Jonas=20Dre=C3=9Fler?= To: Marcel Holtmann , Johan Hedberg , Luiz Augusto von Dentz Cc: =?UTF-8?q?Jonas=20Dre=C3=9Fler?= , asahi@lists.linux.dev, linux-bluetooth@vger.kernel.org, linux-kernel@vger.kernel.org, netdev@vger.kernel.org Subject: [PATCH 2/4] Bluetooth: mgmt: Remove leftover queuing of power_off work Date: Tue, 2 Jan 2024 14:33:08 +0100 Message-ID: <20240102133311.6712-3-verdre@v0yd.nl> In-Reply-To: <20240102133311.6712-1-verdre@v0yd.nl> References: <20240102133311.6712-1-verdre@v0yd.nl> Precedence: bulk X-Mailing-List: linux-bluetooth@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Rspamd-Queue-Id: 4T4DM61GV8z9t16 Queuing of power_off work was introduced in these functions with commits 8b064a3ad377c016a17e74f676e7a204c2b8c9f2 and c9910d0fb4fc2ede468b26d45a1d50c309897770 in an effort to clean up state and do things like disconnecting devices before actually powering off the device. After that, commit a3172b7eb4a2719711187cfca12097d2326e85a7 introduced a timeout to ensure that the device actually got powered off, even if some of the cleanup work would never complete. This code later got refactored with commit cf75ad8b41d2aa06f98f365d42a3ae8b059daddd, which made powering off the device synchronous and removed the need for initiating the power_off work from other places. The timeout mentioned above got removed too, because we now also made use of the command timeout during power on/off. These days the power_off work still exists, but it only seems to only be used for HCI_AUTO_OFF functionality, which is why we never noticed those two leftover places where we queue power_off work. So let's remove that code. Signed-off-by: Jonas Dreßler --- net/bluetooth/mgmt.c | 16 ---------------- 1 file changed, 16 deletions(-) diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c index d4498037f..c5291e139 100644 --- a/net/bluetooth/mgmt.c +++ b/net/bluetooth/mgmt.c @@ -9760,14 +9760,6 @@ void mgmt_device_disconnected(struct hci_dev *hdev, bdaddr_t *bdaddr, struct mgmt_ev_device_disconnected ev; struct sock *sk = NULL; - /* The connection is still in hci_conn_hash so test for 1 - * instead of 0 to know if this is the last one. - */ - if (mgmt_powering_down(hdev) && hci_conn_count(hdev) == 1) { - cancel_delayed_work(&hdev->power_off); - queue_work(hdev->req_workqueue, &hdev->power_off.work); - } - if (!mgmt_connected) return; @@ -9824,14 +9816,6 @@ void mgmt_connect_failed(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 link_type, { struct mgmt_ev_connect_failed ev; - /* The connection is still in hci_conn_hash so test for 1 - * instead of 0 to know if this is the last one. - */ - if (mgmt_powering_down(hdev) && hci_conn_count(hdev) == 1) { - cancel_delayed_work(&hdev->power_off); - queue_work(hdev->req_workqueue, &hdev->power_off.work); - } - bacpy(&ev.addr.bdaddr, bdaddr); ev.addr.type = link_to_bdaddr(link_type, addr_type); ev.status = mgmt_status(status); -- 2.43.0