From patchwork Thu Nov 18 23:13:01 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Luiz Augusto von Dentz X-Patchwork-Id: 518236 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 02201C433F5 for ; Thu, 18 Nov 2021 23:13:06 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id CA15361A81 for ; Thu, 18 Nov 2021 23:13:05 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232996AbhKRXQF (ORCPT ); Thu, 18 Nov 2021 18:16:05 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51418 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229678AbhKRXQF (ORCPT ); Thu, 18 Nov 2021 18:16:05 -0500 Received: from mail-pj1-x102a.google.com (mail-pj1-x102a.google.com [IPv6:2607:f8b0:4864:20::102a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DDDC7C061574 for ; Thu, 18 Nov 2021 15:13:04 -0800 (PST) Received: by mail-pj1-x102a.google.com with SMTP id gb13-20020a17090b060d00b001a674e2c4a8so7149394pjb.4 for ; Thu, 18 Nov 2021 15:13:04 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:subject:date:message-id:mime-version :content-transfer-encoding; bh=wYdUcxwZgdoNimqI0BNpqpVCtxd7ojVPvU/h10KvHIE=; b=fuv4IaVBUjjRpVK9Hdptuw76wI2g5oacHREiqV+llmDdva/N+kfLX6BzoC/YeHIWKd 182RY29UaODQiYoybLXnXgkxkONsDxbfXi6fOPSgRhOn56DWkBtpi29r6pd7vxERH2Mb KlXjkE82m6/lxASEdmjZ64EE+VbE1Q6bO+mxG3eYDs9reG0U5xuQH+PGQzBHIPVIcFdy DI5YPEh098le+H8uu9nbHx4InWOKFHq7Hly8hrVCPjzUejOlpyT70uDP98iockb3eLMS giwGDdFtqIQ/fBNJ7Ah2M4OLr80got/3pBqPHp4lSoDq4HrdMpE0U7MGg76aV00rDsc7 5+Tw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:subject:date:message-id:mime-version :content-transfer-encoding; bh=wYdUcxwZgdoNimqI0BNpqpVCtxd7ojVPvU/h10KvHIE=; b=Jh2/Yqc2xvxfHqomfIOAREXOvLxE4k1tR78U2ZNtt4VNSvtYKUZ/B28AUHDRTc8wcV XKnBHTz17qDwyyV9A4PGfEAI93jPvu8f3kwcqV0TZfBO2pxAzeJsALMm3pwhzJHfupP1 uJnW5rNhyKS6esnWHtuPGqsUE7FyDKruLRBWreAJEjZaDdugDZVeje2gluasCywVtnwZ /W1OiTtcnyRBOMLvO0xhsMMLKBq/iEy7mOQ+AfT7QyHvEDksBy/MNeLruYHgxDW3zSV2 e1He5s9Qwz1ah1pcoM41jO2MZP5fdIrSdqQ5W3tF0DGPqbPsdzq86yQ0XEk6NYmGC1YZ ZUMw== X-Gm-Message-State: AOAM531c8L7eqwOl1a85AffspZjhKJi2g197dlhslamtu0e+Xwa0fYpF DPFFDfIaOsb+NL/TyYaMAzDDVIDyhyQ= X-Google-Smtp-Source: ABdhPJxFon+XKcVXWFvxyMwSz04jAUp4hLu6EnMalpe+CVX+CQRORa17f5NmoXEQvqyuCFwfXGNRkQ== X-Received: by 2002:a17:90a:800a:: with SMTP id b10mr15121344pjn.162.1637277184034; Thu, 18 Nov 2021 15:13:04 -0800 (PST) Received: from lvondent-mobl4.intel.com (c-71-56-157-77.hsd1.or.comcast.net. [71.56.157.77]) by smtp.gmail.com with ESMTPSA id c6sm626956pfd.114.2021.11.18.15.13.03 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 18 Nov 2021 15:13:03 -0800 (PST) From: Luiz Augusto von Dentz To: linux-bluetooth@vger.kernel.org Subject: [PATCH v2 1/2] Bluetooth: Introduce HCI_CONN_FLAG_DEVICE_PRIVACY device flag Date: Thu, 18 Nov 2021 15:13:01 -0800 Message-Id: <20211118231302.1000168-1-luiz.dentz@gmail.com> X-Mailer: git-send-email 2.33.1 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org From: Luiz Augusto von Dentz This introduces HCI_CONN_FLAG_DEVICE_PRIVACY which can be used by userspace to indicate to the controller to use Device Privacy Mode to a specific device. Signed-off-by: Luiz Augusto von Dentz --- v2: Fix supported flags not actually checking if the hdev really supports the flags. include/net/bluetooth/hci_core.h | 4 ++++ net/bluetooth/mgmt.c | 30 ++++++++++++++++++++++++++---- 2 files changed, 30 insertions(+), 4 deletions(-) diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h index 2560cfe80db8..42ba40df6e20 100644 --- a/include/net/bluetooth/hci_core.h +++ b/include/net/bluetooth/hci_core.h @@ -160,6 +160,7 @@ struct bdaddr_list_with_flags { enum hci_conn_flags { HCI_CONN_FLAG_REMOTE_WAKEUP, + HCI_CONN_FLAG_DEVICE_PRIVACY, HCI_CONN_FLAG_MAX }; @@ -1465,6 +1466,9 @@ void hci_conn_del_sysfs(struct hci_conn *conn); #define use_ll_privacy(dev) (ll_privacy_capable(dev) && \ hci_dev_test_flag(dev, HCI_ENABLE_LL_PRIVACY)) +#define privacy_mode_capable(dev) (use_ll_privacy(dev) && \ + (hdev->commands[39] & 0x04)) + /* Use enhanced synchronous connection if command is supported */ #define enhanced_sco_capable(dev) ((dev)->commands[29] & 0x08) diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c index f8f74d344297..d82d1a62754a 100644 --- a/net/bluetooth/mgmt.c +++ b/net/bluetooth/mgmt.c @@ -4349,7 +4349,22 @@ static int set_exp_feature(struct sock *sk, struct hci_dev *hdev, MGMT_STATUS_NOT_SUPPORTED); } -#define SUPPORTED_DEVICE_FLAGS() ((1U << HCI_CONN_FLAG_MAX) - 1) +static u32 supported_device_flags(struct hci_dev *hdev) +{ + u32 flags = 0; + + /* Check if adapter can wakeup the system */ + if (hdev->wakeup && hdev->wakeup(hdev)) + flags |= BIT(HCI_CONN_FLAG_REMOTE_WAKEUP); + + /* Check if Privacy Mode can be set */ + if (privacy_mode_capable(hdev)) + flags |= BIT(HCI_CONN_FLAG_DEVICE_PRIVACY); + + bt_dev_err(hdev, "flag 0x%8x", flags); + + return flags; +} static int get_device_flags(struct sock *sk, struct hci_dev *hdev, void *data, u16 data_len) @@ -4358,7 +4373,7 @@ static int get_device_flags(struct sock *sk, struct hci_dev *hdev, void *data, struct mgmt_rp_get_device_flags rp; struct bdaddr_list_with_flags *br_params; struct hci_conn_params *params; - u32 supported_flags = SUPPORTED_DEVICE_FLAGS(); + u32 supported_flags = supported_device_flags(hdev); u32 current_flags = 0; u8 status = MGMT_STATUS_INVALID_PARAMS; @@ -4422,7 +4437,7 @@ static int set_device_flags(struct sock *sk, struct hci_dev *hdev, void *data, struct bdaddr_list_with_flags *br_params; struct hci_conn_params *params; u8 status = MGMT_STATUS_INVALID_PARAMS; - u32 supported_flags = SUPPORTED_DEVICE_FLAGS(); + u32 supported_flags = supported_device_flags(hdev); u32 current_flags = __le32_to_cpu(cp->current_flags); bt_dev_dbg(hdev, "Set device flags %pMR (type 0x%x) = 0x%x", @@ -4455,6 +4470,13 @@ static int set_device_flags(struct sock *sk, struct hci_dev *hdev, void *data, if (params) { params->current_flags = current_flags; status = MGMT_STATUS_SUCCESS; + + /* Update passive scan if HCI_CONN_FLAG_DEVICE_PRIVACY + * has been set. + */ + if (hci_conn_test_flag(HCI_CONN_FLAG_DEVICE_PRIVACY, + params->current_flags)) + hci_update_passive_scan(hdev); } else { bt_dev_warn(hdev, "No such LE device %pMR (0x%x)", &cp->addr.bdaddr, @@ -7060,7 +7082,7 @@ static int add_device(struct sock *sk, struct hci_dev *hdev, added: device_added(sk, hdev, &cp->addr.bdaddr, cp->addr.type, cp->action); device_flags_changed(NULL, hdev, &cp->addr.bdaddr, cp->addr.type, - SUPPORTED_DEVICE_FLAGS(), current_flags); + supported_device_flags(hdev), current_flags); err = mgmt_cmd_complete(sk, hdev->id, MGMT_OP_ADD_DEVICE, MGMT_STATUS_SUCCESS, &cp->addr, From patchwork Thu Nov 18 23:13:02 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Luiz Augusto von Dentz X-Patchwork-Id: 516985 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 07864C433EF for ; Thu, 18 Nov 2021 23:13:07 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id D4EF361994 for ; Thu, 18 Nov 2021 23:13:06 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233050AbhKRXQG (ORCPT ); Thu, 18 Nov 2021 18:16:06 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51424 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229678AbhKRXQG (ORCPT ); Thu, 18 Nov 2021 18:16:06 -0500 Received: from mail-pl1-x631.google.com (mail-pl1-x631.google.com [IPv6:2607:f8b0:4864:20::631]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DF47AC061574 for ; Thu, 18 Nov 2021 15:13:05 -0800 (PST) Received: by mail-pl1-x631.google.com with SMTP id y8so6630122plg.1 for ; Thu, 18 Nov 2021 15:13:05 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:subject:date:message-id:in-reply-to:references:mime-version :content-transfer-encoding; bh=TFZlm7EpeuwvqA5SGSTHAbvjYjaJTAIIkITSO1s+Dgo=; b=ERwarWwWhmf4Y+QKvNd025jSU+TRXbKaYybZoxYAGvqSRMwVtmq0eX1XXpBCcnfMkn tUXHcaA6fMYyEZ20+hKAOwDgX1lPWQPJlFJFN84E4GnrG7BU8mlQ+veWVrdmkDu16H6k TyZHMsAnm2n0/YZSKffLiGaga/5LL6HBTuhqtafnx6FfbbEyi7qOTjSSDAc50l+DxYrH kCVgMp/l0zs9TfOsPjkAKGCDppAWvMCnI4VHZ1cNlgHdgiNi3JCoVjh2ssfD8YIZf9K/ almajKvBTonERgLDAu5ShLqxYYLpdqftt+/H+vnAxDbUs4d+cwIHWSs0hqDOoMeX3y4B OjpQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=TFZlm7EpeuwvqA5SGSTHAbvjYjaJTAIIkITSO1s+Dgo=; b=EvIX6Gmx4Pjql8HQCSsvOAUNbb+OYYa/bDHP+QEclrMzQhUgD6zGwH82Nu4HlLQUXA IMeeWtw27XD15fy1MrVq/mAeKM/hBGT15VnlVF9O5aCJSEsVvPgUTdwCzNkAObi8AaT6 F07R+GW8WR2wKKz6XMdnxb3dwvjSn89CYa2NqbsxokXzhJkn6CU0mOArVepN9EA+hsOk KO8UnWcH8801N0xxznJCuXZf4bv+35Z0j1yzG8e5AncHNrCoosuYxbrusD8pGGLZqqI3 HxFkI3eQp/aZP6H5xx8SAPs+AzMY2lu/wMYGYiqC0fT03SyMrLWnmaD/eENIrgnLfVRv k5lQ== X-Gm-Message-State: AOAM530Tt8YK5b7MSA8give5Pzy6f4iTuZ0XKfmc75br8erQoEAdWkck fNQHi90wFRdnt2B0ssGrV6D77978ioo= X-Google-Smtp-Source: ABdhPJy+5j795A14hSqbXs6JE7d6Z9gJ4aa/Jn12mpCk2OHxzZWrzSTxKR7bjgevLuc3/YhioTIxyw== X-Received: by 2002:a17:90b:4d86:: with SMTP id oj6mr159397pjb.101.1637277185020; Thu, 18 Nov 2021 15:13:05 -0800 (PST) Received: from lvondent-mobl4.intel.com (c-71-56-157-77.hsd1.or.comcast.net. [71.56.157.77]) by smtp.gmail.com with ESMTPSA id c6sm626956pfd.114.2021.11.18.15.13.04 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 18 Nov 2021 15:13:04 -0800 (PST) From: Luiz Augusto von Dentz To: linux-bluetooth@vger.kernel.org Subject: [PATCH v2 2/2] Bluetooth: hci_sync: Set Privacy Mode when updating the resolving list Date: Thu, 18 Nov 2021 15:13:02 -0800 Message-Id: <20211118231302.1000168-2-luiz.dentz@gmail.com> X-Mailer: git-send-email 2.33.1 In-Reply-To: <20211118231302.1000168-1-luiz.dentz@gmail.com> References: <20211118231302.1000168-1-luiz.dentz@gmail.com> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org From: Luiz Augusto von Dentz This adds support for Set Privacy Mode when updating the resolving list when HCI_CONN_FLAG_DEVICE_PRIVACY so the controller shall use Device Mode for devices programmed in the resolving list, Device Mode is actually required when the remote device are not able to use RPA as otherwise the default mode is Network Privacy Mode in which only allows RPAs thus the controller would filter out advertisement using identity addresses for which there is an IRK. Signed-off-by: Luiz Augusto von Dentz --- include/net/bluetooth/hci.h | 10 ++++++ include/net/bluetooth/hci_core.h | 1 + net/bluetooth/hci_event.c | 29 +++++++++++++++++ net/bluetooth/hci_sync.c | 53 ++++++++++++++++++++++++++++---- 4 files changed, 87 insertions(+), 6 deletions(-) diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h index 84db6b275231..7444d286e6be 100644 --- a/include/net/bluetooth/hci.h +++ b/include/net/bluetooth/hci.h @@ -1931,6 +1931,16 @@ struct hci_rp_le_read_transmit_power { __s8 max_le_tx_power; } __packed; +#define HCI_NETWORK_PRIVACY 0x00 +#define HCI_DEVICE_PRIVACY 0x01 + +#define HCI_OP_LE_SET_PRIVACY_MODE 0x204e +struct hci_cp_le_set_privacy_mode { + __u8 bdaddr_type; + bdaddr_t bdaddr; + __u8 mode; +} __packed; + #define HCI_OP_LE_READ_BUFFER_SIZE_V2 0x2060 struct hci_rp_le_read_buffer_size_v2 { __u8 status; diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h index 42ba40df6e20..0b3de5411948 100644 --- a/include/net/bluetooth/hci_core.h +++ b/include/net/bluetooth/hci_core.h @@ -755,6 +755,7 @@ struct hci_conn_params { struct hci_conn *conn; bool explicit_connect; + u8 privacy_mode; u32 current_flags; }; diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c index efc5458b1345..51c88f4f1274 100644 --- a/net/bluetooth/hci_event.c +++ b/net/bluetooth/hci_event.c @@ -1300,6 +1300,31 @@ static void hci_cc_le_read_transmit_power(struct hci_dev *hdev, hdev->max_le_tx_power = rp->max_le_tx_power; } +static void hci_cc_le_set_privacy_mode(struct hci_dev *hdev, + struct sk_buff *skb) +{ + __u8 status = *((__u8 *)skb->data); + struct hci_cp_le_set_privacy_mode *cp; + struct hci_conn_params *params; + + bt_dev_dbg(hdev, "status 0x%2.2x", status); + + if (status) + return; + + cp = hci_sent_cmd_data(hdev, HCI_OP_LE_SET_PRIVACY_MODE); + if (!cp) + return; + + hci_dev_lock(hdev); + + params = hci_conn_params_lookup(hdev, &cp->bdaddr, cp->bdaddr_type); + if (params) + params->privacy_mode = cp->mode; + + hci_dev_unlock(hdev); +} + static void hci_cc_le_set_adv_enable(struct hci_dev *hdev, struct sk_buff *skb) { __u8 *sent, status = *((__u8 *) skb->data); @@ -3812,6 +3837,10 @@ static void hci_cmd_complete_evt(struct hci_dev *hdev, struct sk_buff *skb, hci_cc_le_read_transmit_power(hdev, skb); break; + case HCI_OP_LE_SET_PRIVACY_MODE: + hci_cc_le_set_privacy_mode(hdev, skb); + break; + default: BT_DBG("%s opcode 0x%4.4x", hdev->name, *opcode); break; diff --git a/net/bluetooth/hci_sync.c b/net/bluetooth/hci_sync.c index ad86caf41f91..08acd664590b 100644 --- a/net/bluetooth/hci_sync.c +++ b/net/bluetooth/hci_sync.c @@ -1580,8 +1580,42 @@ static int hci_le_add_resolve_list_sync(struct hci_dev *hdev, sizeof(cp), &cp, HCI_CMD_TIMEOUT); } +/* Set Device Privacy Mode. */ +static int hci_le_set_privacy_mode_sync(struct hci_dev *hdev, + struct hci_conn_params *params) +{ + struct hci_cp_le_set_privacy_mode cp; + struct smp_irk *irk; + + /* If device privacy mode has already been set there is nothing to do */ + if (params->privacy_mode == HCI_DEVICE_PRIVACY) + return 0; + + /* Set Privacy Mode requires the use of resolving list (aka. LL Privacy) + * by default Network Mode is used so only really send the command if + * Device Mode is required (HCI_CONN_FLAG_DEVICE_PRIVACY). + */ + if (!privacy_mode_capable(hdev) || + !hci_conn_test_flag(HCI_CONN_FLAG_DEVICE_PRIVACY, + params->current_flags)) + return 0; + + irk = hci_find_irk_by_addr(hdev, ¶ms->addr, params->addr_type); + if (!irk) + return 0; + + memset(&cp, 0, sizeof(cp)); + cp.bdaddr_type = irk->addr_type; + bacpy(&cp.bdaddr, &irk->bdaddr); + cp.mode = HCI_DEVICE_PRIVACY; + + return __hci_cmd_sync_status(hdev, HCI_OP_LE_SET_PRIVACY_MODE, + sizeof(cp), &cp, HCI_CMD_TIMEOUT); +} + /* Adds connection to allow list if needed, if the device uses RPA (has IRK) - * this attempts to program the device in the resolving list as well. + * this attempts to program the device in the resolving list as well and + * properly set the privacy mode. */ static int hci_le_add_accept_list_sync(struct hci_dev *hdev, struct hci_conn_params *params, @@ -1590,11 +1624,6 @@ static int hci_le_add_accept_list_sync(struct hci_dev *hdev, struct hci_cp_le_add_to_accept_list cp; int err; - /* Already in accept list */ - if (hci_bdaddr_list_lookup(&hdev->le_accept_list, ¶ms->addr, - params->addr_type)) - return 0; - /* Select filter policy to accept all advertising */ if (*num_entries >= hdev->le_accept_list_size) return -ENOSPC; @@ -1620,6 +1649,18 @@ static int hci_le_add_accept_list_sync(struct hci_dev *hdev, return err; } + /* Set Privacy Mode */ + err = hci_le_set_privacy_mode_sync(hdev, params); + if (err) { + bt_dev_err(hdev, "Unable to set privacy mode: %d", err); + return err; + } + + /* Check if already in accept list */ + if (hci_bdaddr_list_lookup(&hdev->le_accept_list, ¶ms->addr, + params->addr_type)) + return 0; + *num_entries += 1; cp.bdaddr_type = params->addr_type; bacpy(&cp.bdaddr, ¶ms->addr);