Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
home:dirkmueller:acdc:sp5-rebuild
bluez.25899
adapter-Discovery-filter-discoverable.patch
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File adapter-Discovery-filter-discoverable.patch of Package bluez.25899
From d04eb02f9bad8795297210ef80e262be16ea8f07 Mon Sep 17 00:00:00 2001 From: Luiz Augusto von Dentz <luiz.von.dentz@intel.com> Date: Thu, 26 Jul 2018 15:23:05 +0300 Subject: [PATCH] adapter: Discovery filter discoverable This implements the discovery filter discoverable and tracks which clients had enabled it and restores the settings when the last client enabling it exits. --- src/adapter.c | 56 +++++++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 54 insertions(+), 2 deletions(-) Index: bluez-5.48/src/adapter.c =================================================================== --- bluez-5.48.orig/src/adapter.c +++ bluez-5.48/src/adapter.c @@ -156,6 +156,7 @@ struct discovery_filter { int16_t rssi; GSList *uuids; bool duplicate; + bool discoverable; }; struct watch_client { @@ -217,6 +218,7 @@ struct btd_adapter { uint8_t discovery_type; /* current active discovery type */ uint8_t discovery_enable; /* discovery enabled/disabled */ bool discovery_suspended; /* discovery has been suspended */ + bool discovery_discoverable; /* discoverable while discovering */ GSList *discovery_list; /* list of discovery clients */ GSList *set_filter_list; /* list of clients that specified * filter, but don't scan yet @@ -1819,6 +1821,20 @@ static void discovery_free(void *user_da g_free(client); } +static bool set_discovery_discoverable(struct btd_adapter *adapter, bool enable) +{ + if (adapter->discovery_discoverable == enable) + return true; + + /* Reset discoverable filter if already set */ + if (enable && (adapter->current_settings & MGMT_OP_SET_DISCOVERABLE)) + return true; + + adapter->discovery_discoverable = enable; + + return set_discoverable(adapter, enable, 0); +} + static void discovery_remove(struct watch_client *client) { struct btd_adapter *adapter = client->adapter; @@ -2069,6 +2085,8 @@ static bool filters_equal(struct mgmt_cp static int update_discovery_filter(struct btd_adapter *adapter) { struct mgmt_cp_start_service_discovery *sd_cp; + GSList *l; + DBG(""); @@ -2078,6 +2096,18 @@ static int update_discovery_filter(struc return -ENOMEM; } + for (l = adapter->discovery_list; l; l = g_slist_next(l)) { + struct watch_client *client = l->data; + + if (!client->discovery_filter) + continue; + + if (client->discovery_filter->discoverable) + break; + } + + set_discovery_discoverable(adapter, l ? true : false); + /* * If filters are equal, then don't update scan, except for when * starting discovery. @@ -2109,6 +2139,9 @@ static int discovery_stop(struct watch_c return 0; } + if (adapter->discovery_discoverable) + set_discovery_discoverable(adapter, false); + /* * In the idle phase of a discovery, there is no need to stop it * and so it is enough to send out the signal and just return. @@ -2203,6 +2236,7 @@ static DBusMessage *start_discovery(DBus adapter->set_filter_list, client); adapter->discovery_list = g_slist_prepend( adapter->discovery_list, client); + goto done; } @@ -2327,6 +2361,17 @@ static bool parse_duplicate_data(DBusMes return true; } +static bool parse_discoverable(DBusMessageIter *value, + struct discovery_filter *filter) +{ + if (dbus_message_iter_get_arg_type(value) != DBUS_TYPE_BOOLEAN) + return false; + + dbus_message_iter_get_basic(value, &filter->discoverable); + + return true; +} + struct filter_parser { const char *name; bool (*func)(DBusMessageIter *iter, struct discovery_filter *filter); @@ -2336,6 +2381,7 @@ struct filter_parser { { "Pathloss", parse_pathloss }, { "Transport", parse_transport }, { "DuplicateData", parse_duplicate_data }, + { "Discoverable", parse_discoverable }, { } }; @@ -2375,6 +2421,7 @@ static bool parse_discovery_filter_dict( (*filter)->rssi = DISTANCE_VAL_INVALID; (*filter)->type = get_scan_type(adapter); (*filter)->duplicate = false; + (*filter)->discoverable = false; dbus_message_iter_init(msg, &iter); if (dbus_message_iter_get_arg_type(&iter) != DBUS_TYPE_ARRAY || @@ -2420,8 +2467,10 @@ static bool parse_discovery_filter_dict( goto invalid_args; DBG("filtered discovery params: transport: %d rssi: %d pathloss: %d " - " duplicate data: %s ", (*filter)->type, (*filter)->rssi, - (*filter)->pathloss, (*filter)->duplicate ? "true" : "false"); + " duplicate data: %s discoverable %s", (*filter)->type, + (*filter)->rssi, (*filter)->pathloss, + (*filter)->duplicate ? "true" : "false", + (*filter)->discoverable ? "true" : "false"); return true; @@ -2829,6 +2878,9 @@ static void property_set_discoverable(co return; } + /* Reset discovery_discoverable as Discoverable takes precedence */ + adapter->discovery_discoverable = false; + property_set_mode(adapter, MGMT_SETTING_DISCOVERABLE, iter, id); }
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor