Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp4135065ybi; Mon, 15 Jul 2019 04:25:52 -0700 (PDT) X-Google-Smtp-Source: APXvYqy6uqFD+rzmCQhl75Xv6lBaEPZNEOqucYjB7JBr8E7jJyTFoPbRrwvn3F3jCmZBdNddJipS X-Received: by 2002:a17:90b:f0f:: with SMTP id br15mr29104368pjb.101.1563189952047; Mon, 15 Jul 2019 04:25:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563189952; cv=none; d=google.com; s=arc-20160816; b=sNvlPL8ZwYCOL6n1UT7B8OMJg/y4ez1/8OAvlM2Gp7u77Jb6GAKDJlm4updRiv34Ud Bly1pKkO7jac0dv5SDHIQW8QubBWiclgKU6ekQJEa/RA39xgQVU7nuzQHw3WvaBz8F3E sgKsdrGgU9NDVowOrQyDzOyKn2U+TmZhYLCIuBgWSrNKq66brg23Zjx0bpqQwI1fFipI eym58pwx08PVQLtWOLAPPs9QzED0aOKQ2Gk3pPztAbLgrNzZGav1o/QdRSpXyafjNmbU JsqxL9rXQW+djblCFDiWmcXVnYVYFQMefc7FqCT1x00PyAo4Ogv11ejN4eajh5EViWVA D7rg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=3Uh1EGypi0lkHTF5+6LJsfp7Dfs+SBtJmqWo+/7DidU=; b=T53xBqOa1OjAU9V16VZZOp+YhT0PKkkZWXMCgIK6ux7jF6fOnCNMj3lv/rlESigxOP ElPCKfkuSivbY1QKkOYAGx5x5IVV1+tNeZNi3gbRzIO8hXQSFlQ5Ixqp54AJSykZWFhC 3czKbD1mM91kIfk7jTW7mF0FMCrhsGdQvy0KwRSkZoCk9jftL3xy5WK8Fd0D/+N9eEkj wd9+EqJtEtRKL5pYBTypaVI6fKk3W/Ycefige85xxNBeEJAd8PxvEZuqSjD2GUVk7OKt hdR7SvHfIQ3cAw/RjCL8KXzMjAlJ/BRAM7b+rRfK013/usBOf8HPjhVr/dIr0EoYYop0 ErDw== 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 b9si5694666pgb.478.2019.07.15.04.25.22; Mon, 15 Jul 2019 04:25:52 -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 S1729821AbfGOLYs (ORCPT + 99 others); Mon, 15 Jul 2019 07:24:48 -0400 Received: from mga07.intel.com ([134.134.136.100]:53955 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729799AbfGOLYs (ORCPT ); Mon, 15 Jul 2019 07:24:48 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by orsmga105.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 15 Jul 2019 04:24:47 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.63,493,1557212400"; d="scan'208";a="187098490" Received: from spoorthi-h97m-d3h.iind.intel.com ([10.223.96.21]) by fmsmga001.fm.intel.com with ESMTP; 15 Jul 2019 04:24:46 -0700 From: spoorthix.k@intel.com To: linux-bluetooth@vger.kernel.org Cc: bharat.b.panda@intel.com Subject: [PATCH] v3 Fast Advertising Interval Date: Mon, 15 Jul 2019 17:05:22 +0530 Message-Id: <1563190522-23651-1-git-send-email-spoorthix.k@intel.com> X-Mailer: git-send-email 1.9.1 Sender: linux-bluetooth-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org From: Spoorthi Ravishankar Koppad Changes made to add support for fast advertising interval as per core 4.1 specification, section 9.3.11.2. A peripheral device entering any of the following GAP modes and sending either non-connectable advertising events or scannable undirected advertising events should use adv_fast_interval2 (100ms - 150ms) for adv_fast_period(30s). - Non-Discoverable Mode - Non-Connectable Mode - Limited Discoverable Mode - General Discoverable Mode Signed-off-by: Spoorthi Ravishankar Koppad --- include/net/bluetooth/hci_core.h | 2 ++ net/bluetooth/hci_request.c | 32 ++++++++++++++++++++++---------- 2 files changed, 24 insertions(+), 10 deletions(-) diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h index 7dfe6ff..a69534d 100644 --- a/include/net/bluetooth/hci_core.h +++ b/include/net/bluetooth/hci_core.h @@ -1512,6 +1512,8 @@ struct hci_mgmt_chan { #define DISCOV_INTERLEAVED_INQUIRY_LEN 0x04 #define DISCOV_BREDR_INQUIRY_LEN 0x08 #define DISCOV_LE_RESTART_DELAY msecs_to_jiffies(200) /* msec */ +#define DISCOV_LE_FAST_ADV_INT_MIN 100 /* msec */ +#define DISCOV_LE_FAST_ADV_INT_MAX 150 /* msec */ void mgmt_fill_version_info(void *ver); int mgmt_new_settings(struct hci_dev *hdev); diff --git a/net/bluetooth/hci_request.c b/net/bluetooth/hci_request.c index ca73d36..d42b6fd 100644 --- a/net/bluetooth/hci_request.c +++ b/net/bluetooth/hci_request.c @@ -1082,19 +1082,31 @@ void __hci_req_enable_advertising(struct hci_request *req) return; memset(&cp, 0, sizeof(cp)); - cp.min_interval = cpu_to_le16(hdev->le_adv_min_interval); - cp.max_interval = cpu_to_le16(hdev->le_adv_max_interval); - - if (connectable) - cp.type = LE_ADV_IND; - else if (get_cur_adv_instance_scan_rsp_len(hdev)) - cp.type = LE_ADV_SCAN_IND; - else - cp.type = LE_ADV_NONCONN_IND; - cp.own_address_type = own_addr_type; cp.channel_map = hdev->le_adv_channel_map; + if (connectable) { + cp.type = LE_ADV_IND; + cp.min_interval = cpu_to_le16(hdev->le_adv_min_interval); + cp.max_interval = cpu_to_le16(hdev->le_adv_max_interval); + } else { + if (get_cur_adv_instance_scan_rsp_len(hdev)) + cp.type = LE_ADV_SCAN_IND; + else + cp.type = LE_ADV_NONCONN_IND; + + if (!hci_dev_test_flag(hdev, HCI_DISCOVERABLE) || + hci_dev_test_flag(hdev, HCI_LIMITED_DISCOVERABLE)) { + cp.min_interval = + cpu_to_le16(DISCOV_LE_FAST_ADV_INT_MIN); + cp.max_interval = + cpu_to_le16(DISCOV_LE_FAST_ADV_INT_MAX); + } else { + cp.min_interval = cpu_to_le16(hdev->le_adv_min_interval); + cp.max_interval = cpu_to_le16(hdev->le_adv_max_interval); + } + } + hci_req_add(req, HCI_OP_LE_SET_ADV_PARAM, sizeof(cp), &cp); hci_req_add(req, HCI_OP_LE_SET_ADV_ENABLE, sizeof(enable), &enable); -- 1.9.1