Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp2102905yba; Sun, 5 May 2019 22:52:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqz753RZYHxvFjivsbzLrRSM8ysud8X8bUfP+dblhm1dOd6Lnsw5ZDeUR2mCror19YlvXS5o X-Received: by 2002:a63:fb4d:: with SMTP id w13mr30265002pgj.397.1557121973799; Sun, 05 May 2019 22:52:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557121973; cv=none; d=google.com; s=arc-20160816; b=D6fqAgEsRAh41x1Pdgq+kRhds6T3P7GjJTTOl1S52T2sFbLKQIAFBJulMgLmd+VdUa OVk78fp+LN3QZ0ZP4xEcB2MRVV+UOQqurJXSaqrOhMZgMFNOprFX3M85handWFx2K2OQ 6QeyHnB09DlbIlD/oZV9N5REQs+npZqC4h/8RIQZqLEatNYxcNCliS4mKVci6Rl/HUwg Ay1dbZYjgxuw7CPm19eSHx4ZMxEIx83E1+kVnGayX8UxuNyAfSD0qySWIQDrurpmEwCv KnhFWCCK7MQ4qwUXmG40QzWpTs2BVIpEFHl0QIq57u0FlnQnMrN1+COXSbh+Jygb8k7y inYQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :dlp-reaction:dlp-version:dlp-product:content-language :accept-language:in-reply-to:references:message-id:date:thread-index :thread-topic:subject:cc:to:from; bh=4xgKVq3SLYTRrn/fEg14g0PmevtmRjdFZHp2kkM5Tu0=; b=BHxSmZReBSo9hh7whsLaAl19RSUPJXEEJFviAQ+y9NmCjlslkv7DiZhScSbZRXcPkS EWPwppxDuJcKWjhyN0ZhE6fZzlbSkQRlLwnXXwUO1fnMR66LrGKW85MogIv0mzNstH29 tkAc0HrmjMHXBM+JIKYs1xCMAnxoRHwzAd4mTAMnp7xrMeUOhCnk54HnQiOOIc4Y0oPf 5nsQ8vX+FjimrUGrV4t/9uOP+L32R5UGbt66+ePSqohXADGOB3frsLsZ7/QDXcdX8v8y rBdndTUq7sWkozsUk2VeGp2GRsBkuB2/SIvCiWVyQNcdyvhX7RyqiAMST7h4KcbzVcxg 9UwQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-bluetooth-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s78si13842337pfa.103.2019.05.05.22.52.21; Sun, 05 May 2019 22:52:53 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-bluetooth-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-bluetooth-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725830AbfEFFwS convert rfc822-to-8bit (ORCPT + 99 others); Mon, 6 May 2019 01:52:18 -0400 Received: from mga06.intel.com ([134.134.136.31]:56808 "EHLO mga06.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725813AbfEFFwS (ORCPT ); Mon, 6 May 2019 01:52:18 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by orsmga104.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 05 May 2019 22:52:17 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.60,435,1549958400"; d="scan'208";a="140353162" Received: from fmsmsx108.amr.corp.intel.com ([10.18.124.206]) by orsmga008.jf.intel.com with ESMTP; 05 May 2019 22:52:17 -0700 Received: from fmsmsx112.amr.corp.intel.com (10.18.116.6) by FMSMSX108.amr.corp.intel.com (10.18.124.206) with Microsoft SMTP Server (TLS) id 14.3.408.0; Sun, 5 May 2019 22:52:17 -0700 Received: from bgsmsx153.gar.corp.intel.com (10.224.23.4) by FMSMSX112.amr.corp.intel.com (10.18.116.6) with Microsoft SMTP Server (TLS) id 14.3.408.0; Sun, 5 May 2019 22:52:16 -0700 Received: from bgsmsx101.gar.corp.intel.com ([169.254.1.217]) by BGSMSX153.gar.corp.intel.com ([169.254.2.183]) with mapi id 14.03.0415.000; Mon, 6 May 2019 11:22:14 +0530 From: "K, SpoorthiX" To: Marcel Holtmann CC: "linux-bluetooth@vger.kernel.org" Subject: RE: [PATCH] v7 Add support for LE ping feature Thread-Topic: [PATCH] v7 Add support for LE ping feature Thread-Index: AQHVA2ehMbnY8ZJ7UEeFo1/gPcoKq6Zdlzsw Date: Mon, 6 May 2019 05:52:13 +0000 Message-ID: <6AFF54953E047B42BC60A96154D42C5CD16F45@BGSMSX101.gar.corp.intel.com> References: <1556597465-21783-1-git-send-email-spoorthix.k@intel.com> In-Reply-To: Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: dlp-product: dlpe-windows dlp-version: 11.0.600.7 dlp-reaction: no-action x-originating-ip: [10.223.10.10] Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 Sender: linux-bluetooth-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org Hi Marcel, Thanks for your valuable comments. I have removed the extra lines wherever mentioned in my latest patch sent few minutes back. But I clearly did not understand the comment ---> On hci_conn creation the hcon->auth_payload_time needs to be set to DEFAULT_AUTH_PAYLOAD_TIMEOUT as well. Could you please explain why this needs to be set after connection as it is sent as a command parameter "hdev->auth_payload_timeout" is nothing but "DEFAULT_AUTH_PAYLOAD_TIMEOUT" Thanks & Regards, Spoorthi K -----Original Message----- From: Marcel Holtmann [mailto:marcel@holtmann.org] Sent: Sunday, May 5, 2019 10:56 PM To: K, SpoorthiX Cc: linux-bluetooth@vger.kernel.org Subject: Re: [PATCH] v7 Add support for LE ping feature Hi Spoorthi, > Changes made to add HCI Write Authenticated Payload timeout command > for LE Ping feature. > As per the Core Specification 5.0 Volume 2 Part E Section 7.3.94, the > following code changes implements HCI Write Authenticated Payload > timeout command for LE Ping feature. > > Signed-off-by: Spoorthi Ravishankar Koppad > --- > include/net/bluetooth/hci.h | 20 +++++++++++ > include/net/bluetooth/hci_core.h | 5 +++ > net/bluetooth/hci_core.c | 1 + > net/bluetooth/hci_debugfs.c | 31 ++++++++++++++++ > net/bluetooth/hci_event.c | 76 ++++++++++++++++++++++++++++++++++++++++ > 5 files changed, 133 insertions(+) > > diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h > index c36dc1e..56d5236 100644 > --- a/include/net/bluetooth/hci.h > +++ b/include/net/bluetooth/hci.h > @@ -1130,6 +1130,26 @@ struct hci_cp_write_sc_support { > __u8 support; > } __packed; > > +#define HCI_OP_READ_AUTH_PAYLOAD_TO 0x0c7b > +struct hci_cp_read_auth_payload_to { > + __le16 handle; > +} __packed; > +struct hci_rp_read_auth_payload_to { > + __u8 status; > + __le16 handle; > + __le16 timeout; > +} __packed; > + > +#define HCI_OP_WRITE_AUTH_PAYLOAD_TO 0x0c7c > +struct hci_cp_write_auth_payload_to { > + __le16 handle; > + __le16 timeout; > +} __packed; > +struct hci_rp_write_auth_payload_to { > + __u8 status; > + __le16 handle; > +} __packed; > + > #define HCI_OP_READ_LOCAL_OOB_EXT_DATA 0x0c7d > struct hci_rp_read_local_oob_ext_data { > __u8 status; > diff --git a/include/net/bluetooth/hci_core.h > b/include/net/bluetooth/hci_core.h > index e5ea633..e8990fe 100644 > --- a/include/net/bluetooth/hci_core.h > +++ b/include/net/bluetooth/hci_core.h > @@ -197,6 +197,9 @@ struct adv_info { > #define DEFAULT_CONN_INFO_MIN_AGE 1000 > #define DEFAULT_CONN_INFO_MAX_AGE 3000 > > +/* Default authenticated payload timeout 30000ms/30s */ > +#define DEFAULT_AUTH_PAYLOAD_TIMEOUT 0x0bb8 > + is this the default value from the specification? And scarp 3000ms/30s conversion. Just say 30s. > struct amp_assoc { > __u16 len; > __u16 offset; > @@ -272,6 +275,7 @@ struct hci_dev { > __u16 discov_interleaved_timeout; > __u16 conn_info_min_age; > __u16 conn_info_max_age; > + __u16 auth_payload_timeout; > __u8 ssp_debug_mode; > __u8 hw_error_code; > __u32 clock; > @@ -477,6 +481,7 @@ struct hci_conn { > __u16 disc_timeout; > __u16 conn_timeout; > __u16 setting; > + __u16 auth_payload_timeout; > __u16 le_conn_min_interval; > __u16 le_conn_max_interval; > __u16 le_conn_interval; > diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c index > 7352fe8..7959ee7 100644 > --- a/net/bluetooth/hci_core.c > +++ b/net/bluetooth/hci_core.c > @@ -3156,6 +3156,7 @@ struct hci_dev *hci_alloc_dev(void) > hdev->discov_interleaved_timeout = DISCOV_INTERLEAVED_TIMEOUT; > hdev->conn_info_min_age = DEFAULT_CONN_INFO_MIN_AGE; > hdev->conn_info_max_age = DEFAULT_CONN_INFO_MAX_AGE; > + hdev->auth_payload_timeout = DEFAULT_AUTH_PAYLOAD_TIMEOUT; > > mutex_init(&hdev->lock); > mutex_init(&hdev->req_lock); > diff --git a/net/bluetooth/hci_debugfs.c b/net/bluetooth/hci_debugfs.c > index 51f5b1e..bb67f4a 100644 > --- a/net/bluetooth/hci_debugfs.c > +++ b/net/bluetooth/hci_debugfs.c > @@ -941,6 +941,35 @@ static int adv_max_interval_get(void *data, u64 > *val) DEFINE_SIMPLE_ATTRIBUTE(adv_max_interval_fops, adv_max_interval_get, > adv_max_interval_set, "%llu\n"); > > +static int auth_payload_timeout_set(void *data, u64 val) { > + struct hci_dev *hdev = data; > + > + if (val < 0x0001 || val > 0xffff) > + return -EINVAL; > + > + hci_dev_lock(hdev); > + hdev->auth_payload_timeout = val; > + hci_dev_unlock(hdev); > + > + return 0; > +} > + > +static int auth_payload_timeout_get(void *data, u64 *val) { > + struct hci_dev *hdev = data; > + > + hci_dev_lock(hdev); > + *val = hdev->auth_payload_timeout; > + hci_dev_unlock(hdev); > + > + return 0; > +} > + > +DEFINE_SIMPLE_ATTRIBUTE(auth_payload_timeout_fops, > + auth_payload_timeout_get, > + auth_payload_timeout_set, "%llu\n"); > + > DEFINE_QUIRK_ATTRIBUTE(quirk_strict_duplicate_filter, > HCI_QUIRK_STRICT_DUPLICATE_FILTER); > DEFINE_QUIRK_ATTRIBUTE(quirk_simultaneous_discovery, > @@ -994,6 +1023,8 @@ void hci_debugfs_create_le(struct hci_dev *hdev) > &adv_max_interval_fops); > debugfs_create_u16("discov_interleaved_timeout", 0644, hdev->debugfs, > &hdev->discov_interleaved_timeout); > + debugfs_create_file("auth_payload_timeout", 0644, hdev->debugfs, hdev, > + &auth_payload_timeout_fops); > > debugfs_create_file("quirk_strict_duplicate_filter", 0644, > hdev->debugfs, hdev, > diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c > index ac2826c..2593b4b 100644 > --- a/net/bluetooth/hci_event.c > +++ b/net/bluetooth/hci_event.c > @@ -545,6 +545,54 @@ static void hci_cc_write_sc_support(struct hci_dev *hdev, struct sk_buff *skb) > hci_dev_unlock(hdev); > } > On hci_conn creation the hcon->auth_payload_time needs to be set to DEFAULT_AUTH_PAYLOAD_TIMEOUT as well. > +static void hci_cc_read_auth_payload_timeout(struct hci_dev *hdev, > + struct sk_buff *skb) > +{ > + struct hci_rp_read_auth_payload_to *rp = (void *)skb->data; > + struct hci_conn *conn; > + > + BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); > + > + if (rp->status) > + return; > + > + hci_dev_lock(hdev); > + > + conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(rp->handle)); > + Remove this empty line. > + if (conn) > + conn->auth_payload_timeout = __le16_to_cpu(rp->timeout); > + > + hci_dev_unlock(hdev); > +} > + > +static void hci_cc_write_auth_payload_timeout(struct hci_dev *hdev, > + struct sk_buff *skb) > +{ > + struct hci_rp_write_auth_payload_to *rp = (void *)skb->data; > + struct hci_conn *conn; > + void *sent; > + > + BT_DBG("%s status 0x%2.2x", hdev->name, rp->status); > + > + if (rp->status) > + return; > + > + sent = hci_sent_cmd_data(hdev, HCI_OP_WRITE_AUTH_PAYLOAD_TO); > + if (!sent) > + return; > + > + hci_dev_lock(hdev); > + > + conn = hci_conn_hash_lookup_handle(hdev, __le16_to_cpu(rp->handle)); > + Remove this empty line. > + if (conn) > + conn->auth_payload_timeout = get_unaligned_le16(sent + 2); > + > + hci_dev_unlock(hdev); > +} > + > static void hci_cc_read_local_version(struct hci_dev *hdev, struct > sk_buff *skb) { > struct hci_rp_read_local_version *rp = (void *) skb->data; @@ -2975,6 > +3023,26 @@ static void hci_encrypt_change_evt(struct hci_dev *hdev, struct sk_buff *skb) > goto unlock; > } > > + /* Set the default Authenticated Payload Timeout after > + * an LE Link is established. As per Core Spec v5.0, Vol 2, Part B > + * Section 3.3, the HCI command WRITE_AUTH_PAYLOAD_TIMEOUT should be > + * sent when the link is active and Encryption is enabled, the conn > + * type can be either LE or ACL and controller must support LMP Ping. > + * Ensure for AES-CCM encryption as well. > + */ > + Remove this empty line. > + if (test_bit(HCI_CONN_ENCRYPT, &conn->flags) && > + test_bit(HCI_CONN_AES_CCM, &conn->flags) && > + ((conn->type == ACL_LINK && lmp_ping_capable(hdev)) || > + (conn->type == LE_LINK && (hdev->le_features[0] & HCI_LE_PING)))) { > + struct hci_cp_write_auth_payload_to cp; > + > + cp.handle = cpu_to_le16(conn->handle); > + cp.timeout = cpu_to_le16(hdev->auth_payload_timeout); > + hci_send_cmd(conn->hdev, HCI_OP_WRITE_AUTH_PAYLOAD_TO, > + sizeof(cp), &cp); > + } > + > notify: > if (conn->state == BT_CONFIG) { > if (!ev->status) > @@ -3170,6 +3238,14 @@ static void hci_cmd_complete_evt(struct hci_dev *hdev, struct sk_buff *skb, > hci_cc_write_sc_support(hdev, skb); > break; > > + case HCI_OP_READ_AUTH_PAYLOAD_TO: > + hci_cc_read_auth_payload_timeout(hdev, skb); > + break; > + > + case HCI_OP_WRITE_AUTH_PAYLOAD_TO: > + hci_cc_write_auth_payload_timeout(hdev, skb); > + break; > + > case HCI_OP_READ_LOCAL_VERSION: > hci_cc_read_local_version(hdev, skb); > break; Regards Marcel