From: Luiz Augusto von Dentz <luiz.von.dentz@xxxxxxxxx> This adds support to include adapter name, or alias, in the scan response with use of IncludeName property. --- doc/advertising-api.txt | 5 +++++ src/advertising.c | 27 +++++++++++++++++++++++++++ 2 files changed, 32 insertions(+) diff --git a/doc/advertising-api.txt b/doc/advertising-api.txt index 7a29b7095..3ef9a9d94 100644 --- a/doc/advertising-api.txt +++ b/doc/advertising-api.txt @@ -66,6 +66,11 @@ Properties string Type Includes the Tx Power in the advertising packet. If missing, the Tx Power is not included. + bool IncludeName + + Include adapter Name, or Alias if set, as scan + response data. + LE Advertising Manager hierarchy ================================ diff --git a/src/advertising.c b/src/advertising.c index c2af3acb4..66e380a02 100644 --- a/src/advertising.c +++ b/src/advertising.c @@ -63,6 +63,7 @@ struct btd_adv_client { DBusMessage *reg; uint8_t type; /* Advertising type */ bool include_tx_power; + bool include_name; struct bt_ad *data; uint8_t instance; }; @@ -411,6 +412,24 @@ static bool parse_include_tx_power(GDBusProxy *proxy, bool *included) return true; } +static bool parse_include_name(GDBusProxy *proxy, bool *included) +{ + DBusMessageIter iter; + dbus_bool_t b; + + if (!g_dbus_proxy_get_property(proxy, "IncludeName", &iter)) + return true; + + if (dbus_message_iter_get_arg_type(&iter) != DBUS_TYPE_BOOLEAN) + return false; + + dbus_message_iter_get_basic(&iter, &b); + + *included = b; + + return true; +} + static void add_client_complete(struct btd_adv_client *client, uint8_t status) { DBusMessage *reply; @@ -497,6 +516,9 @@ static DBusMessage *refresh_advertisement(struct btd_adv_client *client) if (client->include_tx_power) flags |= MGMT_ADV_FLAG_TX_POWER; + if (client->include_name) + flags |= MGMT_ADV_FLAG_LOCAL_NAME; + adv_data = bt_ad_generate(client->data, &adv_data_len); if (!adv_data || (adv_data_len > calc_max_adv_len(client, flags))) { @@ -573,6 +595,11 @@ static DBusMessage *parse_advertisement(struct btd_adv_client *client) goto fail; } + if (!parse_include_name(client->proxy, &client->include_name)) { + error("Property \"IncludeName\" failed to parse"); + goto fail; + } + return refresh_advertisement(client); fail: -- 2.13.3 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html