public inbox for linux-bluetooth@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH BlueZ v2 0/1] adapter: Allow broadcaster to be passed up to application
@ 2023-07-05  8:51 Claudia Draghicescu
  2023-07-05  8:51 ` [PATCH BlueZ v2 1/1] " Claudia Draghicescu
  0 siblings, 1 reply; 4+ messages in thread
From: Claudia Draghicescu @ 2023-07-05  8:51 UTC (permalink / raw)
  To: linux-bluetooth; +Cc: Claudia Draghicescu

Allow a broadcast advertiser to be passed up to application,
if the scanner is an ISO Sync Receiver capable device.
This allows for a broadcast sink to discover broadcast sources.

Claudia Draghicescu (1):
  adapter: Allow broadcaster to be passed up to application

 src/adapter.c | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)


base-commit: ddfa40977c7e7b8723fc3ba9389822631ddeeb5c
-- 
2.34.1


^ permalink raw reply	[flat|nested] 4+ messages in thread

* [PATCH BlueZ v2 1/1] adapter: Allow broadcaster to be passed up to application
  2023-07-05  8:51 [PATCH BlueZ v2 0/1] adapter: Allow broadcaster to be passed up to application Claudia Draghicescu
@ 2023-07-05  8:51 ` Claudia Draghicescu
  2023-07-05 10:14   ` bluez.test.bot
  2023-07-05 17:38   ` [PATCH BlueZ v2 1/1] " Luiz Augusto von Dentz
  0 siblings, 2 replies; 4+ messages in thread
From: Claudia Draghicescu @ 2023-07-05  8:51 UTC (permalink / raw)
  To: linux-bluetooth; +Cc: Claudia Draghicescu

Allow a broadcast advertiser to be passed up to application,
if the scanner is an ISO Sync Receiver capable device.
This allows for a broadcast sink to discover broadcast sources.

---
 src/adapter.c | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)

diff --git a/src/adapter.c b/src/adapter.c
index 2679d4302..9c971d488 100644
--- a/src/adapter.c
+++ b/src/adapter.c
@@ -7031,6 +7031,16 @@ static bool is_filter_match(GSList *discovery_filter, struct eir_data *eir_data,
 	return got_match;
 }
 
+static bool accept_bcast_adv(struct btd_adapter *adapter,
+				struct eir_data *eir_data)
+{
+	if ((btd_adapter_has_settings(adapter, MGMT_SETTING_ISO_SYNC_RECEIVER))
+		&& !(eir_data->flags & (EIR_LIM_DISC | EIR_GEN_DISC)))
+		return true;
+
+	return false;
+}
+
 static void filter_duplicate_data(void *data, void *user_data)
 {
 	struct discovery_client *client = data;
@@ -7154,12 +7164,18 @@ void btd_adapter_device_found(struct btd_adapter *adapter,
 			return;
 		}
 
+		if (accept_bcast_adv(adapter, &eir_data))
+			monitoring = true;
+
 		if (!discoverable && !monitoring && !eir_data.rsi) {
 			eir_data_free(&eir_data);
 			return;
 		}
 
 		dev = adapter_create_device(adapter, bdaddr, bdaddr_type);
+
+		if (accept_bcast_adv(adapter, &eir_data))
+			btd_device_set_temporary(dev, false);
 	}
 
 	if (!dev) {
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 4+ messages in thread

* RE: adapter: Allow broadcaster to be passed up to application
  2023-07-05  8:51 ` [PATCH BlueZ v2 1/1] " Claudia Draghicescu
@ 2023-07-05 10:14   ` bluez.test.bot
  2023-07-05 17:38   ` [PATCH BlueZ v2 1/1] " Luiz Augusto von Dentz
  1 sibling, 0 replies; 4+ messages in thread
From: bluez.test.bot @ 2023-07-05 10:14 UTC (permalink / raw)
  To: linux-bluetooth, claudia.rosu

[-- Attachment #1: Type: text/plain, Size: 947 bytes --]

This is automated email and please do not reply to this email!

Dear submitter,

Thank you for submitting the patches to the linux bluetooth mailing list.
This is a CI test results with your patch series:
PW Link:https://patchwork.kernel.org/project/bluetooth/list/?series=762577

---Test result---

Test Summary:
CheckPatch                    PASS      0.43 seconds
GitLint                       PASS      0.29 seconds
BuildEll                      PASS      27.33 seconds
BluezMake                     PASS      856.49 seconds
MakeCheck                     PASS      12.37 seconds
MakeDistcheck                 PASS      153.84 seconds
CheckValgrind                 PASS      253.53 seconds
CheckSmatch                   PASS      338.11 seconds
bluezmakeextell               PASS      102.16 seconds
IncrementalBuild              PASS      697.99 seconds
ScanBuild                     PASS      1043.87 seconds



---
Regards,
Linux Bluetooth


^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH BlueZ v2 1/1] adapter: Allow broadcaster to be passed up to application
  2023-07-05  8:51 ` [PATCH BlueZ v2 1/1] " Claudia Draghicescu
  2023-07-05 10:14   ` bluez.test.bot
@ 2023-07-05 17:38   ` Luiz Augusto von Dentz
  1 sibling, 0 replies; 4+ messages in thread
From: Luiz Augusto von Dentz @ 2023-07-05 17:38 UTC (permalink / raw)
  To: Claudia Draghicescu; +Cc: linux-bluetooth

Hi Claudia,

On Wed, Jul 5, 2023 at 2:02 AM Claudia Draghicescu <claudia.rosu@nxp.com> wrote:
>
> Allow a broadcast advertiser to be passed up to application,
> if the scanner is an ISO Sync Receiver capable device.
> This allows for a broadcast sink to discover broadcast sources.
>
> ---
>  src/adapter.c | 16 ++++++++++++++++
>  1 file changed, 16 insertions(+)
>
> diff --git a/src/adapter.c b/src/adapter.c
> index 2679d4302..9c971d488 100644
> --- a/src/adapter.c
> +++ b/src/adapter.c
> @@ -7031,6 +7031,16 @@ static bool is_filter_match(GSList *discovery_filter, struct eir_data *eir_data,
>         return got_match;
>  }
>
> +static bool accept_bcast_adv(struct btd_adapter *adapter,
> +                               struct eir_data *eir_data)
> +{
> +       if ((btd_adapter_has_settings(adapter, MGMT_SETTING_ISO_SYNC_RECEIVER))
> +               && !(eir_data->flags & (EIR_LIM_DISC | EIR_GEN_DISC)))
> +               return true;
> +
> +       return false;
> +}
> +
>  static void filter_duplicate_data(void *data, void *user_data)
>  {
>         struct discovery_client *client = data;
> @@ -7154,12 +7164,18 @@ void btd_adapter_device_found(struct btd_adapter *adapter,
>                         return;
>                 }
>
> +               if (accept_bcast_adv(adapter, &eir_data))
> +                       monitoring = true;
> +
>                 if (!discoverable && !monitoring && !eir_data.rsi) {
>                         eir_data_free(&eir_data);
>                         return;
>                 }

Lets match by advertising UUID since it should contain a broadcast
audio announcement to be considered a broadcaster.

>                 dev = adapter_create_device(adapter, bdaddr, bdaddr_type);
> +
> +               if (accept_bcast_adv(adapter, &eir_data))
> +                       btd_device_set_temporary(dev, false);

I wouldn't persist broadcasters like that, at least not until we
synchronize with it, that said, if it is using a random address it
probably cannot be stored anyway.

>         }
>
>         if (!dev) {
> --
> 2.34.1
>


-- 
Luiz Augusto von Dentz

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2023-07-05 17:39 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-07-05  8:51 [PATCH BlueZ v2 0/1] adapter: Allow broadcaster to be passed up to application Claudia Draghicescu
2023-07-05  8:51 ` [PATCH BlueZ v2 1/1] " Claudia Draghicescu
2023-07-05 10:14   ` bluez.test.bot
2023-07-05 17:38   ` [PATCH BlueZ v2 1/1] " Luiz Augusto von Dentz

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox