Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1129294pxb; Thu, 4 Mar 2021 04:12:03 -0800 (PST) X-Google-Smtp-Source: ABdhPJwUUpxOsvkj6fWs2iYpYrqIfeA7CaKsMWzhac47PJ6T1Plf3r4CzCWP3bthaSMbveBabVye X-Received: by 2002:a17:907:2bdd:: with SMTP id gv29mr3725809ejc.259.1614859922867; Thu, 04 Mar 2021 04:12:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614859922; cv=none; d=google.com; s=arc-20160816; b=xKq2/Mb5o2o0stB1axD/oO1mpF5eKeOuE3L4gXIMpiCfCZ3FKL/WBrZ03mauusu/gW g9edb5ODb4ktn7PlG6t0ygltYLcZXt2HPj+Mug2Wg1NmyrCowEckXKn6jFS/+zJavmDp UW0THaORHsLaUvnF6orEYCsJ6LPwo/4Gv2z3GiM9ll8/qCL6/W+zee0q0B6i1FL5TkU1 TeO52ld3aCBqcGbK9gzvhQow6AanDcWtCixupQqwGip6ilobgzXa9nFYKlSfk09oCktq smQB1KtuKnACYQQoy/NfB8j9YLyssweLIqFWKK/updbRkN+8LF2Wqaz7dTglmenv23gp X7LA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=CmHAmC1lkwH36HdV1eDW3eAkI2gtvTFuod5LzEzCVtw=; b=TQksX9gF+2Ct3KhkFX+xpDJ7L4OTF71yf2OgUZa4vIsmWCjInsJvxcJ4mfSZQQ4bCp jwHP6gsu9PE3QmAi0NDNTKMNfCGLTcVLGWphtqNKZhP4eIT0Kw6tvNB5OWqmd+7aANXw SLi7Hr0ZWrqCHT/jCTMKZvag1WNpgaQUDVL9DLxwRWCcC3lcrNqDzbpbF1KLEgzVL+4m xnBnIAgtUfG4L7xZpjpTA/6QCd0DoM0pj0k7IpwKFGJ77zQBHaMGudjv0GTJDn36iic+ 7kZouZeANR9vCZ1+G2sN4ohjJTs9ZPMQiZDEpym2TIspRBR1G84kRzJoUNnrNzd90meL eU0g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=jdQmJPCr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o13si14804027edi.135.2021.03.04.04.11.40; Thu, 04 Mar 2021 04:12:02 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=jdQmJPCr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1579429AbhCCSbQ (ORCPT + 99 others); Wed, 3 Mar 2021 13:31:16 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33454 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240347AbhCCQfP (ORCPT ); Wed, 3 Mar 2021 11:35:15 -0500 Received: from mail-pg1-x530.google.com (mail-pg1-x530.google.com [IPv6:2607:f8b0:4864:20::530]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A1C2FC061764 for ; Wed, 3 Mar 2021 08:34:13 -0800 (PST) Received: by mail-pg1-x530.google.com with SMTP id x29so8518369pgk.6 for ; Wed, 03 Mar 2021 08:34:13 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=CmHAmC1lkwH36HdV1eDW3eAkI2gtvTFuod5LzEzCVtw=; b=jdQmJPCr0o3ofSQMiQfHjQsmYPy5fGj807WS96RQedPIxJ7jImVYp0XGpxbCl/jpKk zuX5XXTvVnUrOkE8C9bUHSly2M2hy1ksFcV1zVvRKraIKO2M5w9kHh+T+VhJVUUg6Gbx 8YzWVYI+C2iuNVOlDOJ97C5JGy+RGFJaYY2pk= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=CmHAmC1lkwH36HdV1eDW3eAkI2gtvTFuod5LzEzCVtw=; b=MG770mnOGD0lBJF1aRgFe0wwcB0MkDYeI4FvBuYRT8Gn/XZJ2b7ukmRTVYCM0xoOJ4 ieAeWM9UjtWrWE+5WqUgd5EJTTC6oHxtvWbB9g1xSadBm9ycKmgxWImNNhBRM4uC10ah L+xTAsgE1SEnar+GpHliDCsnu9uQ+PeZSnTMNUfmJ/sbaA+ppK5cXGjxVWE2WLrgmVls 8H8k8n6c8kRLOI6iqQ3k5bNtSzC95rhPz6AO8HNdKz9RGJWeZl+qjJh4TWSJAzrLcbYv HnFBomm7C7zXir9AXb/UEHLHGOkMmw4lsVPpBwoWCB4fDhrzJkkOcC8fTRlzP4pOZ0Ru KrHg== X-Gm-Message-State: AOAM533odC6E4hf92gQuA0oMOqdzT4PzZqtVm9IWV498jMSYH7S22L3U o+1S/X2JDZDSbtgqToV8s4tAGA== X-Received: by 2002:a62:7597:0:b029:1ee:17a6:f91d with SMTP id q145-20020a6275970000b02901ee17a6f91dmr5443pfc.20.1614789253181; Wed, 03 Mar 2021 08:34:13 -0800 (PST) Received: from apsdesk.mtv.corp.google.com ([2620:15c:202:1:9c83:cccc:4c1:7b17]) by smtp.gmail.com with ESMTPSA id a21sm3171172pfk.83.2021.03.03.08.34.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 03 Mar 2021 08:34:12 -0800 (PST) From: Abhishek Pandit-Subedi To: marcel@holtmann.org Cc: chromeos-bluetooth-upstreaming@chromium.org, Hans de Goede , linux-bluetooth@vger.kernel.org, Abhishek Pandit-Subedi , Archie Pusaka , Alain Michaud , "David S. Miller" , Johan Hedberg , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Jakub Kicinski , Luiz Augusto von Dentz Subject: [PATCH v3 1/1] Bluetooth: Remove unneeded commands for suspend Date: Wed, 3 Mar 2021 08:34:04 -0800 Message-Id: <20210303083400.v3.1.Ifcac8bd85b5339135af8e08370bacecc518b1c35@changeid> X-Mailer: git-send-email 2.31.0.rc0.254.gbdcc3b1a9d-goog In-Reply-To: <20210303163404.1779850-1-abhishekpandit@chromium.org> References: <20210303163404.1779850-1-abhishekpandit@chromium.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org During suspend, there are a few scan enable and set event filter commands that don't need to be sent unless there are actual BR/EDR devices capable of waking the system. Check the HCI_PSCAN bit before writing scan enable and use a new dev flag, HCI_EVENT_FILTER_CONFIGURED to control whether to clear the event filter. Signed-off-by: Abhishek Pandit-Subedi Reviewed-by: Archie Pusaka Reviewed-by: Alain Michaud --- Changes in v3: * Minor change to if statement Changes in v2: * Removed hci_dev_lock from hci_cc_set_event_filter since flags are set/cleared atomically include/net/bluetooth/hci.h | 1 + net/bluetooth/hci_event.c | 27 +++++++++++++++++++++++ net/bluetooth/hci_request.c | 44 +++++++++++++++++++++++-------------- 3 files changed, 55 insertions(+), 17 deletions(-) diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h index ba2f439bc04d34..ea4ae551c42687 100644 --- a/include/net/bluetooth/hci.h +++ b/include/net/bluetooth/hci.h @@ -320,6 +320,7 @@ enum { HCI_BREDR_ENABLED, HCI_LE_SCAN_INTERRUPTED, HCI_WIDEBAND_SPEECH_ENABLED, + HCI_EVENT_FILTER_CONFIGURED, HCI_DUT_MODE, HCI_VENDOR_DIAG, diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c index 67668be3461e93..f4a734f8a9ac88 100644 --- a/net/bluetooth/hci_event.c +++ b/net/bluetooth/hci_event.c @@ -395,6 +395,29 @@ static void hci_cc_write_scan_enable(struct hci_dev *hdev, struct sk_buff *skb) hci_dev_unlock(hdev); } +static void hci_cc_set_event_filter(struct hci_dev *hdev, struct sk_buff *skb) +{ + __u8 status = *((__u8 *)skb->data); + struct hci_cp_set_event_filter *cp; + void *sent; + + BT_DBG("%s status 0x%2.2x", hdev->name, status); + + if (status) + return; + + sent = hci_sent_cmd_data(hdev, HCI_OP_SET_EVENT_FLT); + if (!sent) + return; + + cp = (struct hci_cp_set_event_filter *)sent; + + if (cp->flt_type == HCI_FLT_CLEAR_ALL) + hci_dev_clear_flag(hdev, HCI_EVENT_FILTER_CONFIGURED); + else + hci_dev_set_flag(hdev, HCI_EVENT_FILTER_CONFIGURED); +} + static void hci_cc_read_class_of_dev(struct hci_dev *hdev, struct sk_buff *skb) { struct hci_rp_read_class_of_dev *rp = (void *) skb->data; @@ -3328,6 +3351,10 @@ static void hci_cmd_complete_evt(struct hci_dev *hdev, struct sk_buff *skb, hci_cc_write_scan_enable(hdev, skb); break; + case HCI_OP_SET_EVENT_FLT: + hci_cc_set_event_filter(hdev, skb); + break; + case HCI_OP_READ_CLASS_OF_DEV: hci_cc_read_class_of_dev(hdev, skb); break; diff --git a/net/bluetooth/hci_request.c b/net/bluetooth/hci_request.c index e55976db4403e7..75a42178c82d9b 100644 --- a/net/bluetooth/hci_request.c +++ b/net/bluetooth/hci_request.c @@ -1131,14 +1131,14 @@ static void hci_req_clear_event_filter(struct hci_request *req) { struct hci_cp_set_event_filter f; - memset(&f, 0, sizeof(f)); - f.flt_type = HCI_FLT_CLEAR_ALL; - hci_req_add(req, HCI_OP_SET_EVENT_FLT, 1, &f); + if (!hci_dev_test_flag(req->hdev, HCI_BREDR_ENABLED)) + return; - /* Update page scan state (since we may have modified it when setting - * the event filter). - */ - __hci_req_update_scan(req); + if (hci_dev_test_flag(req->hdev, HCI_EVENT_FILTER_CONFIGURED)) { + memset(&f, 0, sizeof(f)); + f.flt_type = HCI_FLT_CLEAR_ALL; + hci_req_add(req, HCI_OP_SET_EVENT_FLT, 1, &f); + } } static void hci_req_set_event_filter(struct hci_request *req) @@ -1147,6 +1147,10 @@ static void hci_req_set_event_filter(struct hci_request *req) struct hci_cp_set_event_filter f; struct hci_dev *hdev = req->hdev; u8 scan = SCAN_DISABLED; + bool scanning = test_bit(HCI_PSCAN, &hdev->flags); + + if (!hci_dev_test_flag(hdev, HCI_BREDR_ENABLED)) + return; /* Always clear event filter when starting */ hci_req_clear_event_filter(req); @@ -1167,12 +1171,13 @@ static void hci_req_set_event_filter(struct hci_request *req) scan = SCAN_PAGE; } - if (scan) + if (scan && !scanning) { set_bit(SUSPEND_SCAN_ENABLE, hdev->suspend_tasks); - else + hci_req_add(req, HCI_OP_WRITE_SCAN_ENABLE, 1, &scan); + } else if (!scan && scanning) { set_bit(SUSPEND_SCAN_DISABLE, hdev->suspend_tasks); - - hci_req_add(req, HCI_OP_WRITE_SCAN_ENABLE, 1, &scan); + hci_req_add(req, HCI_OP_WRITE_SCAN_ENABLE, 1, &scan); + } } static void cancel_adv_timeout(struct hci_dev *hdev) @@ -1315,9 +1320,14 @@ void hci_req_prepare_suspend(struct hci_dev *hdev, enum suspended_state next) hdev->advertising_paused = true; hdev->advertising_old_state = old_state; - /* Disable page scan */ - page_scan = SCAN_DISABLED; - hci_req_add(&req, HCI_OP_WRITE_SCAN_ENABLE, 1, &page_scan); + + /* Disable page scan if enabled */ + if (test_bit(HCI_PSCAN, &hdev->flags)) { + page_scan = SCAN_DISABLED; + hci_req_add(&req, HCI_OP_WRITE_SCAN_ENABLE, 1, + &page_scan); + set_bit(SUSPEND_SCAN_DISABLE, hdev->suspend_tasks); + } /* Disable LE passive scan if enabled */ if (hci_dev_test_flag(hdev, HCI_LE_SCAN)) { @@ -1328,9 +1338,6 @@ void hci_req_prepare_suspend(struct hci_dev *hdev, enum suspended_state next) /* Disable advertisement filters */ hci_req_add_set_adv_filter_enable(&req, false); - /* Mark task needing completion */ - set_bit(SUSPEND_SCAN_DISABLE, hdev->suspend_tasks); - /* Prevent disconnects from causing scanning to be re-enabled */ hdev->scanning_paused = true; @@ -1364,7 +1371,10 @@ void hci_req_prepare_suspend(struct hci_dev *hdev, enum suspended_state next) hdev->suspended = false; hdev->scanning_paused = false; + /* Clear any event filters and restore scan state */ hci_req_clear_event_filter(&req); + __hci_req_update_scan(&req); + /* Reset passive/background scanning to normal */ __hci_update_background_scan(&req); /* Enable all of the advertisement filters */ -- 2.31.0.rc0.254.gbdcc3b1a9d-goog