KKopyscinski commented on code in PR #1619:
URL: https://github.com/apache/mynewt-nimble/pull/1619#discussion_r1371212124


##########
nimble/host/include/host/ble_audio_broadcast.h:
##########
@@ -0,0 +1,271 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements.  See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership.  The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License.  You may obtain a copy of the License at
+ *
+ *  http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied.  See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+#ifndef H_BLE_AUDIO_BROADCAST_
+#define H_BLE_AUDIO_BROADCAST_
+
+#include <stdint.h>
+#include "host/ble_gap.h"
+#include "host/ble_iso.h"
+#include "host/ble_audio_common.h"
+
+struct ble_broadcast_create_params {
+    /** BASE to broadcast */
+    struct ble_audio_base *base;
+
+    /** Parameters used to configure Extended advertising */
+    struct ble_gap_ext_adv_params *extended_params;
+
+    /** Parameters used to configure Periodic advertising */
+    struct ble_gap_periodic_adv_params *periodic_params;
+
+    /** Broadcast name - null terminated.
+     * Set NULL to not include in advertising
+     */
+    const char *name;
+
+    /** Advertising instance */
+    uint8_t adv_instance;
+
+    /** BIG parameters */
+    struct ble_iso_big_params *big_params;
+
+    /** Additional data to include in Extended Advertising  */
+    uint8_t *svc_data;
+
+    /** Additional data length  */
+    uint16_t svc_data_len;
+};
+
+struct ble_broadcast_update_params {
+    /** Broadcast name - null terminated.
+     * Set NULL to not include in advertising
+     */
+    const char *name;
+
+    /** Advertising instance */
+    uint8_t adv_instance;
+
+    /** Additional data to include in Extended Advertising  */
+    uint8_t *svc_data;
+
+    /** Additional data length  */
+    uint16_t svc_data_len;
+
+    /** Broadcast ID */
+    uint32_t broadcast_id;
+};
+
+typedef int ble_audio_broadcast_destroy_fn(struct ble_audio_base *base,
+                                           void *args);
+
+/** BASE configuration describing broadcast advertisement */
+struct ble_broadcast_base_config {
+    /** Advertising instance used by broadcast */
+    uint8_t adv_instance;
+
+    /** Pointer to BASE configuration */
+    struct ble_audio_base *base;
+
+    /** BIG parameters */
+    struct ble_iso_big_params *big_params;
+
+    /**
+     * Optional callback associated with broadcasting instance, called on
+     * destroying broadcast
+     */
+    ble_audio_broadcast_destroy_fn *destroy_cb;
+
+    /** Pointer to args for `destroy_cb`  */
+    void *args;
+};
+
+/**
+ * @brief Create Broadcast Audio Source Endpoint and configure advertising
+ * instance
+ *
+ * This function configures advertising instance for extended and periodic
+ * advertisements to be ready for broadcast with BASE configuration.
+ *
+ * @param[in] params            Pointer to a `ble_broadcast_base_params`
+ *                              structure that defines BASE, extended
+ *                              advertising and periodic advertising
+ *                              configuration.
+ * @param[out] config_out       Pointer to a `ble_broadcast_base_config`
+ *                              structure to return configuration of created
+ *                              BASE advertisement.
+ * @param[in] destroy_cb        Optional callback to be called when BASE

Review Comment:
   I'm not sure either but this is how we discussed this offline. AFAIK it's 
the similar logic as with extended and periodic: periodic is auxilary of 
extended, and similary BIGInfo is auxilary of periodic. But when extended is 
stopped periodic is still being advertised. So when we want to stop all 
advertisements, we need to stop both extended, periodic and terminate BIG. 
Without it, extended and periodic would stop but BIGInfo would still advertise. 
Am I correct here @andrzej-kaczmarek ?



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: commits-unsubscr...@mynewt.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org

Reply via email to