On Wed, 2021-09-08 at 10:43 -0400, Trevor Gamblin wrote: > > On 2021-09-01 2:45 p.m., Trevor Gamblin wrote: > > > Backporting upstream fix since the uprev from 5.60 -> 5.61 does > > include > > some minor functionality changes. > > > > Signed-off-by: Trevor Gamblin <trevor.gamb...@windriver.com> > Ping. Just wanna make sure this is picked up.
Yes, this is in the queue I sent for review. https://lists.openembedded.org/g/openembedded-core/message/155731 Thanks, Anuj > > > --- > > meta/recipes-connectivity/bluez5/bluez5.inc | 1 + > > ...ter-Fix-storing-discoverable-setting.patch | 100 > > ++++++++++++++++++ > > 2 files changed, 101 insertions(+) > > create mode 100644 meta/recipes-connectivity/bluez5/bluez5/0001- > > adapter-Fix-storing-discoverable-setting.patch > > > > diff --git a/meta/recipes-connectivity/bluez5/bluez5.inc > > b/meta/recipes-connectivity/bluez5/bluez5.inc > > index a7b628ce1b..0d30b1a3f5 100644 > > --- a/meta/recipes-connectivity/bluez5/bluez5.inc > > +++ b/meta/recipes-connectivity/bluez5/bluez5.inc > > @@ -52,6 +52,7 @@ SRC_URI = > > "${KERNELORG_MIRROR}/linux/bluetooth/bluez-${PV}.tar.xz \ > > ${@bb.utils.contains('DISTRO_FEATURES', 'systemd', '', > > 'file://0001-Allow-using-obexd-without-systemd-in-the-user-sessio.patch' > > , d)} \ > > > > file://0001-tests-add-a-target-for-building-tests-without-runnin.patch > > \ > > file://0001-test-gatt-Fix-hung-issue.patch \ > > + > > file://0001-adapter-Fix-storing-discoverable-setting.patch \ > > " > > S = "${WORKDIR}/bluez-${PV}" > > > > diff --git a/meta/recipes-connectivity/bluez5/bluez5/0001-adapter- > > Fix-storing-discoverable-setting.patch b/meta/recipes- > > connectivity/bluez5/bluez5/0001-adapter-Fix-storing-discoverable- > > setting.patch > > new file mode 100644 > > index 0000000000..c2a5edd226 > > --- /dev/null > > +++ b/meta/recipes-connectivity/bluez5/bluez5/0001-adapter-Fix- > > storing-discoverable-setting.patch > > @@ -0,0 +1,100 @@ > > +From b497b5942a8beb8f89ca1c359c54ad67ec843055 Mon Sep 17 00:00:00 > > 2001 > > +From: Luiz Augusto von Dentz <luiz.von.de...@intel.com> > > +Date: Thu, 24 Jun 2021 16:32:04 -0700 > > +Subject: [PATCH] adapter: Fix storing discoverable setting > > + > > +discoverable setting shall only be store when changed via > > Discoverable > > +property and not when discovery client set it as that be considered > > +temporary just for the lifetime of the discovery. > > + > > +Upstream-Status: Backport > > +( > > https://git.kernel.org/pub/scm/bluetooth/bluez.git/commit/?id=b497b5942a8beb8f89ca1c359c54ad67ec843055 > > ) > > + > > +CVE: CVE-2021-3658 > > + > > +Signed-off-by: Trevor Gamblin <trevor.gamb...@windriver.com> > > + > > +--- > > + src/adapter.c | 35 ++++++++++++++++++++++------------- > > + 1 file changed, 22 insertions(+), 13 deletions(-) > > + > > +diff --git a/src/adapter.c b/src/adapter.c > > +index 12e4ff5c0..663b778e4 100644 > > +--- a/src/adapter.c > > ++++ b/src/adapter.c > > +@@ -560,7 +560,11 @@ static void settings_changed(struct btd_adapter > > *adapter, uint32_t settings) > > + if (changed_mask & MGMT_SETTING_DISCOVERABLE) { > > + g_dbus_emit_property_changed(dbus_conn, adapter- > > >path, > > + ADAPTER_INTERFACE, > > "Discoverable"); > > +- store_adapter_info(adapter); > > ++ /* Only persist discoverable setting if it was not > > set > > ++ * temporarily by discovery. > > ++ */ > > ++ if (!adapter->discovery_discoverable) > > ++ store_adapter_info(adapter); > > + btd_adv_manager_refresh(adapter->adv_manager); > > + } > > + > > +@@ -2162,8 +2166,6 @@ static bool filters_equal(struct > > mgmt_cp_start_service_discovery *a, > > + static int update_discovery_filter(struct btd_adapter *adapter) > > + { > > + struct mgmt_cp_start_service_discovery *sd_cp; > > +- GSList *l; > > +- > > + > > + DBG(""); > > + > > +@@ -2173,17 +2175,24 @@ static int update_discovery_filter(struct > > btd_adapter *adapter) > > + return -ENOMEM; > > + } > > + > > +- for (l = adapter->discovery_list; l; l = g_slist_next(l)) { > > +- struct discovery_client *client = l->data; > > ++ /* Only attempt to overwrite current discoverable setting > > when not > > ++ * discoverable. > > ++ */ > > ++ if (!(adapter->current_settings & MGMT_OP_SET_DISCOVERABLE)) > > { > > ++ GSList *l; > > + > > +- if (!client->discovery_filter) > > +- continue; > > ++ for (l = adapter->discovery_list; l; l = > > g_slist_next(l)) { > > ++ struct discovery_client *client = l->data; > > + > > +- if (client->discovery_filter->discoverable) > > +- break; > > +- } > > ++ if (!client->discovery_filter) > > ++ continue; > > + > > +- set_discovery_discoverable(adapter, l ? true : false); > > ++ if (client->discovery_filter->discoverable) > > { > > ++ set_discovery_discoverable(adapter, > > true); > > ++ break; > > ++ } > > ++ } > > ++ } > > + > > + /* > > + * If filters are equal, then don't update scan, except for > > when > > +@@ -2216,8 +2225,7 @@ static int discovery_stop(struct > > discovery_client *client) > > + return 0; > > + } > > + > > +- if (adapter->discovery_discoverable) > > +- set_discovery_discoverable(adapter, false); > > ++ set_discovery_discoverable(adapter, false); > > + > > + /* > > + * In the idle phase of a discovery, there is no need to > > stop it > > +@@ -6913,6 +6921,7 @@ static void adapter_stop(struct btd_adapter > > *adapter) > > + g_free(adapter->current_discovery_filter); > > + adapter->current_discovery_filter = NULL; > > + > > ++ set_discovery_discoverable(adapter, false); > > + adapter->discovering = false; > > + > > + while (adapter->connections) { > > +-- > > +2.33.0 > > + > > > > > > > > > > >
-=-=-=-=-=-=-=-=-=-=-=- Links: You receive all messages sent to this group. View/Reply Online (#155833): https://lists.openembedded.org/g/openembedded-core/message/155833 Mute This Topic: https://lists.openembedded.org/mt/85310700/21656 Group Owner: openembedded-core+ow...@lists.openembedded.org Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [arch...@mail-archive.com] -=-=-=-=-=-=-=-=-=-=-=-