Received: by 2002:ab2:6857:0:b0:1ef:ffd0:ce49 with SMTP id l23csp2564917lqp; Mon, 25 Mar 2024 02:47:34 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCU/HzcTsckLDdEmN0GbLXPWX4PXEpk7VvLxaiyjez+CPv1knCf9BdNDulaz6TMXGUHA11Yl4Hk80kPT0kUr4e3St5gO+ur1nJTajhbdvw== X-Google-Smtp-Source: AGHT+IFw9fz497XQEEHbqBIXfpe0FPW5xpqTDuQFY4QLsTBU11AHaM4zVo+ZRTAbYoDVE8A7JXb2 X-Received: by 2002:a05:620a:16bb:b0:78a:34ca:7382 with SMTP id s27-20020a05620a16bb00b0078a34ca7382mr6719849qkj.35.1711360054387; Mon, 25 Mar 2024 02:47:34 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711360054; cv=pass; d=google.com; s=arc-20160816; b=MUUt9KR+s5oEX76jcXLMMDW65ZpbVPIFVmTvEid0sBq+HNQ3jshXUo2oEs3oUXNhY0 AxOBYKrnm3GYYSNW5fZV2zh2Kfqsoo2t4uYGQUIVgb+gon9HoZ8RzLqG3syQR1rrLl+Y 4/mXpb0LwzDOb4XcS5Ez0m7EW3UT9NJweDFTzni1YAcnIYQ6zT7b5W0eNlHTLfAbY2p2 oPpvoKwWYL4i5mYoruZlFXw0nMnDNrn4DrsQnU6WcqgJehwt1wTDdJqnlsen97LMRqgB vBTPQX5u44qj/eW/GgA15kStIdBxy1vxKmCkkjfceCahn+uQjgzMtwmytQa4LTi3cTzR jByg== ARC-Message-Signature: i=2; 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:dkim-signature; bh=KMgbzHLNrmUWGOSCCGETY47N7R92EpqtWNzitY71xAc=; fh=Yq9pTZcfK+NqYz0VmPJ83nJ7o0CwDlSayUr/Cvn/Z8A=; b=mHCyHk6P98A1GjIZm4mjO2Ri241nY3DhkTa0gn9WxIfn2l21kOHOx6gEfrZtd/665e SC+ZTtiJR2nkrN1t3kVPNnl9uRQKpNDBmm6uBJ9N7XJM8xFxzgoTj3Yet9qoupGDYJNJ My0RS2XkPctm3KMjum1QVZy4HmX16+TJg4ZzcGHh3fKxNTd1yaKVCElWXOlMbDVDovlx /qmymWbHV3nA481Muy4AwNkJln6/QxLFiGZynWfEWg/eRhtrPHm+fyE87s09lUpYye7j iW6BB2kt/AYPg8HqiXa1V5/WhTDfn6X5woTM6Y3gJuB1vR+h9zcJPo3xjRSodH/nPWD+ Ywfw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=YP3T+FV4; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-115929-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-115929-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id ya26-20020a05620a5e5a00b00789ec1d4503si5024573qkn.389.2024.03.25.02.47.34 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Mar 2024 02:47:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-115929-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=YP3T+FV4; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-115929-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-115929-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=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 ny.mirrors.kernel.org (Postfix) with ESMTPS id 23CE31C30F51 for ; Mon, 25 Mar 2024 09:47:34 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id AF04638CE5C; Mon, 25 Mar 2024 03:03:55 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="YP3T+FV4" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (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 8A688227E03; Sun, 24 Mar 2024 23:15:20 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711322121; cv=none; b=FCxF0bXwLCIvh1VVkunL7ClNYzylANV0Hzd5n1+nqcE2878Z0gPq+uyTeRxKYnjUbYz6I9e1vGWzk6RNlheITGoD/Fcsyqi0vUDkc9nZCTdh4zr3Ao3T4wSCMGcV0yals/OclJ2RflSqq+uc7eVXoHc+5SKOLGP38Wn/hEhk3/Y= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711322121; c=relaxed/simple; bh=QMTB5ty4wAWaaMauawzTLJGbHPTq/VgmxTmQY9eNAD0=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=CtGsI6/ZVf8EMBsCfMHXO5CJvmrWDYct5mHWlguhcO1db338pM7oPGfWq26Iz+6K6hZCcdKerO5zHXglw9pCj3/tMAsfpD3hOT4kqxYsjJJ8b3tHEy5ZrswGDgoTSkr7ic5tOzR+FYmYpqVP3nuKLif7GlLZVE4pbwSgXTzokj8= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=YP3T+FV4; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id C969DC43399; Sun, 24 Mar 2024 23:15:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1711322120; bh=QMTB5ty4wAWaaMauawzTLJGbHPTq/VgmxTmQY9eNAD0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=YP3T+FV4S1cirIhpj4MLtjZEFnqaWsEvmMIoVjgXgigF8jtpHis2aReq+4r/Vk8bo u6xQTnxNZ2tKmE6XwpdjlrDwA8IGux5rdDC8QEKilzrqbT9sCiASo3JT8kEb6dI5vl y1LDUJbJGoBR5CuKELCAvgpXxmePZssDw9SEpHeb8UwH3z5zv0jDMWUAxoooy091pr fxca7G6JciCKL4iTm5uB2zASdp/SEBqhwcmwNIwsl9f5zvNq6MprQR5Py3CEmpamRz rTsSAFkoPsujeW4vOiy9sqlGEOiJK7Z0U5VEiTbRAAuBpp+a/XtyKR+I6Aa77IRxsm IFCjPZ2GV3PbQ== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: =?UTF-8?q?Jonas=20Dre=C3=9Fler?= , Luiz Augusto von Dentz , Sasha Levin Subject: [PATCH 6.1 195/451] Bluetooth: mgmt: Remove leftover queuing of power_off work Date: Sun, 24 Mar 2024 19:07:51 -0400 Message-ID: <20240324231207.1351418-196-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240324231207.1351418-1-sashal@kernel.org> References: <20240324231207.1351418-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit From: Jonas Dreßler [ Upstream commit fee054b7579fe252f8b9e6c17b9c5bfdaa84dd7e ] Queuing of power_off work was introduced in these functions with commits 8b064a3ad377 ("Bluetooth: Clean up HCI state when doing power off") and c9910d0fb4fc ("Bluetooth: Fix disconnecting connections in non-connected states") in an effort to clean up state and do things like disconnecting devices before actually powering off the device. After that, commit a3172b7eb4a2 ("Bluetooth: Add timer to force power off") 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 cf75ad8b41d2 ("Bluetooth: hci_sync: Convert MGMT_SET_POWERED"), 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. Fixes: cf75ad8b41d2 ("Bluetooth: hci_sync: Convert MGMT_SET_POWERED") Signed-off-by: Jonas Dreßler Signed-off-by: Luiz Augusto von Dentz Signed-off-by: Sasha Levin --- net/bluetooth/mgmt.c | 16 ---------------- 1 file changed, 16 deletions(-) diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c index ab63f807e3c80..a80bf9c42c2ef 100644 --- a/net/bluetooth/mgmt.c +++ b/net/bluetooth/mgmt.c @@ -9766,14 +9766,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; @@ -9830,14 +9822,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