Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp859710pxb; Thu, 21 Oct 2021 10:49:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyzkVMLi3598tcLit34bo+tVuhkSOYQlTETSpVC4/W/Vz0IYc2HMRh9k8i9rLS/OaZBxA6G X-Received: by 2002:a63:f62:: with SMTP id 34mr5473792pgp.159.1634838598334; Thu, 21 Oct 2021 10:49:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634838598; cv=none; d=google.com; s=arc-20160816; b=d0zucBFTqXG3qZAcy+W/P7KxBzzCqZaN68qKXMROR7BnOuTNiWvTemZRlTWYkVcR25 OFln1c5kBB1x4jJFrof2EP92/e6dsM1l+9wPNOmAPHzvLxJ1v3AB1Zrm5SkRciRrBtqJ 3fc07AEJ/aCYWUVIzLmrpgcaImZn6u6xoD0GOTaHIyPbVHTbVF+rz8ugwZHEU4ZUxMzN lPU52wBnoZQVCszip+d6W3OJEiMj9sP+DgQh3fZu51o+KiOkex05QXjVhLZiwf+C4utH XVKE81lHIRuo2NzH+yt237jl+Qd2zgMhhBIHaWsHvUV7xdBl7tSUweiTU8HGOBnNj+rR bjog== 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:to:from :dkim-signature; bh=a92ewmJCIhCXFTeCxJwy0bcIgrcxBRq6irNBLVf+kLY=; b=bGXpaeH0pmAoXlh8NbL3tqzFVmbFbO2e8dgm2yftm5MqrvPAPupTtGEhpVeHMKrldt /YI0dErqDtTanRirqzSh/q7SAHPjNWCjfebtekxblk1zhAl0t0xKU0J6kESq2nsiRB79 bsNjjrtvhw4iq1L9oTbbvbB3sJsvLBYVBfYHUe+rPFs52aFdt7Go0a9umxcCHjkxS/v0 k+Tgl+VW51qVCL3LRJNPTXnmKDxBQy/29nlA6stkibrDTTi6UMKz5NBAJKxMK8ox3etS D60K9VZ38CwGVWCozAYtgzODP0ne6ILEPdeWQDsQ5tGeED1jXJOpUtmRAZIWGc+gz16i 2VXA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=jdyrLahW; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m16si12606041pgu.423.2021.10.21.10.49.27; Thu, 21 Oct 2021 10:49:58 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-bluetooth-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=@gmail.com header.s=20210112 header.b=jdyrLahW; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232187AbhJURut (ORCPT + 99 others); Thu, 21 Oct 2021 13:50:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58392 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232439AbhJURuk (ORCPT ); Thu, 21 Oct 2021 13:50:40 -0400 Received: from mail-pl1-x62b.google.com (mail-pl1-x62b.google.com [IPv6:2607:f8b0:4864:20::62b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 92900C061224 for ; Thu, 21 Oct 2021 10:48:07 -0700 (PDT) Received: by mail-pl1-x62b.google.com with SMTP id i1so910987plr.13 for ; Thu, 21 Oct 2021 10:48:07 -0700 (PDT) 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=a92ewmJCIhCXFTeCxJwy0bcIgrcxBRq6irNBLVf+kLY=; b=jdyrLahWOdjeG+znbZ1LI2at4GZjUATIhFTB7pH/hDA5ZaT/dksciGRunXHG1AQl0L P2L+qpVINeTWteIXjAvYZ8XuSeadgVK052zsvG0tAkOM+4UP0CtHrHZKyx8slR888Owi fYOVJVGd5/XCaKQQcMZvYvINmfcsPU08EG48LEhmOGBG1axx1MZ/+vAuIgS5Ee8ZKfmk XSWDDIC7iBIszGPq1nB5dcS8RfuvX0X/oO/B1K+Q3rdy5kzsmL6R9neILtDNfK+Z8P8k SZiJrOOx3Y/49JgUlNX2ySRP6miKc9znB7dSgvdx66rLCT9EKfV+X+ycAMSGiBD/GJ+v Kznw== 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=a92ewmJCIhCXFTeCxJwy0bcIgrcxBRq6irNBLVf+kLY=; b=Y1XRqKddb5FCQ4GuTVSowdGurYtSgQzMdiBL15BThQZdOJpH9ePNQaeiTxtsb04FXN JSqrwiCeyBsOzk6XDTCz9xAwq1W8PmvADfwGk7+su98RWsDp+LOrZDlUvwU5ETVGSXnY LbTfHee3v05sL7BGbBf7rq/beS68Yh8n7oZI3PVC3+5PkoT/7kZMdfk9+7JDln+wlfwQ XuORNvbkW+lXP5NWOWEy9I5bM5FQ2+KizeF6vSgt2z/tTTXfaNAHxmQOwYord7/FL3eV DIVUwzwhFcPHe7mfz6GWvjunGQCUpK56ZcV/yuMzd4j+tcEhoCCIjzGMvkh/5BT/tSk0 CWGg== X-Gm-Message-State: AOAM532W/UVghM94H4Uoyl4+lrdOTIqfowKuMB5Q02fWlNRfMQEqpWb2 InT+0P8hkl3VUai52AG2awMuZzwI8KuCAg== X-Received: by 2002:a17:902:c94e:b0:13f:1b02:e539 with SMTP id i14-20020a170902c94e00b0013f1b02e539mr6404408pla.72.1634838486593; Thu, 21 Oct 2021 10:48:06 -0700 (PDT) Received: from han1-NUC8i7BEH.hsd1.or.comcast.net ([2601:1c0:6a01:d830:e439:7541:94af:b362]) by smtp.gmail.com with ESMTPSA id g4sm5732586pgs.42.2021.10.21.10.48.06 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 21 Oct 2021 10:48:06 -0700 (PDT) From: Tedd Ho-Jeong An To: linux-bluetooth@vger.kernel.org Subject: [RFC BlueZ PATCH v13 2/5] emulator: bthost: Add support LE Ext Adv Report Date: Thu, 21 Oct 2021 10:48:01 -0700 Message-Id: <20211021174804.340160-2-hj.tedd.an@gmail.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20211021174804.340160-1-hj.tedd.an@gmail.com> References: <20211021174804.340160-1-hj.tedd.an@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org From: Tedd Ho-Jeong An This patch adds support LE_Extended_Advertising_Report Eevnt in bthost. --- emulator/bthost.c | 118 ++++++++++++++++++++++++++++++++++++++++++++++ emulator/bthost.h | 5 ++ 2 files changed, 123 insertions(+) diff --git a/emulator/bthost.c b/emulator/bthost.c index 4f1598f0d..61f1cd361 100644 --- a/emulator/bthost.c +++ b/emulator/bthost.c @@ -25,6 +25,7 @@ #include "src/shared/util.h" #include "src/shared/tester.h" +#include "src/shared/queue.h" #include "monitor/bt.h" #include "monitor/rfcomm.h" #include "bthost.h" @@ -187,6 +188,15 @@ struct rfcomm_connection_data { void *user_data; }; +struct le_ext_adv { + struct bthost *bthost; + uint16_t event_type; + uint8_t addr_type; + uint8_t addr[6]; + uint8_t direct_addr_type; + uint8_t direct_addr[6]; +}; + struct bthost { bool ready; bthost_ready_cb ready_cb; @@ -215,6 +225,8 @@ struct bthost { bool le; bool sc; + struct queue *le_ext_adv; + bthost_debug_func_t debug_callback; bthost_destroy_func_t debug_destroy; void *debug_data; @@ -234,6 +246,8 @@ struct bthost *bthost_create(void) return NULL; } + bthost->le_ext_adv = queue_new(); + /* Set defaults */ bthost->io_capability = 0x03; @@ -403,6 +417,32 @@ static struct rfcomm_conn_cb_data *bthost_find_rfcomm_cb_by_channel( return NULL; } +static struct le_ext_adv *le_ext_adv_new(struct bthost *bthost) +{ + struct le_ext_adv *ext_adv; + + ext_adv = new0(struct le_ext_adv, 1); + ext_adv->bthost = bthost; + + /* Add to queue */ + if (!queue_push_tail(bthost->le_ext_adv, ext_adv)) { + free(ext_adv); + return NULL; + } + + return ext_adv; +} + +static void le_ext_adv_free(void *data) +{ + struct le_ext_adv *ext_adv = data; + + /* Remove from queue */ + queue_remove(ext_adv->bthost->le_ext_adv, ext_adv); + + free(ext_adv); +} + void bthost_destroy(struct bthost *bthost) { if (!bthost) @@ -449,6 +489,8 @@ void bthost_destroy(struct bthost *bthost) smp_stop(bthost->smp_data); + queue_destroy(bthost->le_ext_adv, le_ext_adv_free); + free(bthost); } @@ -1306,6 +1348,38 @@ static void evt_le_cis_req(struct bthost *bthost, const void *data, uint8_t len) send_command(bthost, BT_HCI_CMD_LE_ACCEPT_CIS, &cmd, sizeof(cmd)); } +static void evt_le_ext_adv_report(struct bthost *bthost, const void *data, + uint8_t len) +{ + const struct bt_hci_evt_le_ext_adv_report *ev = data; + const struct bt_hci_le_ext_adv_report *report; + struct le_ext_adv *le_ext_adv; + int i; + + data += sizeof(ev->num_reports); + + for (i = 0; i < ev->num_reports; i++) { + char addr_str[18]; + + report = data; + ba2str((bdaddr_t *) report->addr, addr_str); + + bthost_debug(bthost, "le ext adv report: %s (0x%02x)", + addr_str, report->addr_type); + + /* Add ext event to the queue */ + le_ext_adv = le_ext_adv_new(bthost); + if (le_ext_adv) { + le_ext_adv->addr_type = report->addr_type; + memcpy(le_ext_adv->addr, report->addr, 6); + le_ext_adv->direct_addr_type = report->direct_addr_type; + memcpy(le_ext_adv->direct_addr, report->direct_addr, 6); + } + + data += (sizeof(*report) + report->data_len); + } +} + static void evt_le_meta_event(struct bthost *bthost, const void *data, uint8_t len) { @@ -1333,6 +1407,9 @@ static void evt_le_meta_event(struct bthost *bthost, const void *data, case BT_HCI_EVT_LE_ENHANCED_CONN_COMPLETE: evt_le_ext_conn_complete(bthost, evt_data, len - 1); break; + case BT_HCI_EVT_LE_EXT_ADV_REPORT: + evt_le_ext_adv_report(bthost, evt_data, len - 1); + break; case BT_HCI_EVT_LE_CIS_REQ: evt_le_cis_req(bthost, evt_data, len - 1); break; @@ -2583,6 +2660,29 @@ void bthost_set_adv_enable(struct bthost *bthost, uint8_t enable) send_command(bthost, BT_HCI_CMD_LE_SET_ADV_ENABLE, &enable, 1); } +void bthost_set_scan_params(struct bthost *bthost, uint8_t scan_type, + uint8_t addr_type, uint8_t filter_policy) +{ + struct bt_hci_cmd_le_set_scan_parameters cp; + + memset(&cp, 0, sizeof(cp)); + cp.type = scan_type; + cp.own_addr_type = addr_type; + cp.filter_policy = filter_policy; + send_command(bthost, BT_HCI_CMD_LE_SET_SCAN_PARAMETERS, + &cp, sizeof(cp)); +} + +void bthost_set_scan_enable(struct bthost *bthost, uint8_t enable) +{ + struct bt_hci_cmd_le_set_scan_enable cp; + + memset(&cp, 0, sizeof(cp)); + cp.enable = enable; + send_command(bthost, BT_HCI_CMD_LE_SET_SCAN_ENABLE, + &cp, sizeof(cp)); +} + void bthost_set_ext_adv_params(struct bthost *bthost) { struct bt_hci_cmd_le_set_ext_adv_params cp; @@ -2612,6 +2712,24 @@ void bthost_set_ext_adv_enable(struct bthost *bthost, uint8_t enable) send_command(bthost, BT_HCI_CMD_LE_SET_EXT_ADV_ENABLE, cp, 6); } +bool bthost_search_ext_adv_addr(struct bthost *bthost, const uint8_t *addr) +{ + const struct queue_entry *entry; + + if (queue_isempty(bthost->le_ext_adv)) + return false; + + for (entry = queue_get_entries(bthost->le_ext_adv); entry; + entry = entry->next) { + struct le_ext_adv *le_ext_adv = entry->data; + + if (!memcmp(le_ext_adv->addr, addr, 6)) + return true; + } + + return false; +} + void bthost_write_ssp_mode(struct bthost *bthost, uint8_t mode) { send_command(bthost, BT_HCI_CMD_WRITE_SIMPLE_PAIRING_MODE, &mode, 1); diff --git a/emulator/bthost.h b/emulator/bthost.h index 3dec44514..868af5469 100644 --- a/emulator/bthost.h +++ b/emulator/bthost.h @@ -84,6 +84,11 @@ void bthost_set_ext_adv_data(struct bthost *bthost, const uint8_t *data, uint8_t len); void bthost_set_ext_adv_params(struct bthost *bthost); void bthost_set_ext_adv_enable(struct bthost *bthost, uint8_t enable); +bool bthost_search_ext_adv_addr(struct bthost *bthost, const uint8_t *addr); + +void bthost_set_scan_params(struct bthost *bthost, uint8_t scan_type, + uint8_t addr_type, uint8_t filter_policy); +void bthost_set_scan_enable(struct bthost *bthost, uint8_t enable); void bthost_write_ssp_mode(struct bthost *bthost, uint8_t mode); -- 2.25.1