rymanluk commented on a change in pull request #283: Adding Periodic 
Advertising Feature
URL: https://github.com/apache/mynewt-nimble/pull/283#discussion_r246773258
 
 

 ##########
 File path: nimble/host/src/ble_gap.c
 ##########
 @@ -2915,8 +2985,515 @@ ble_gap_ext_adv_remove(uint8_t instance)
 
     memset(&ble_gap_slave[instance], 0, sizeof(struct ble_gap_slave_state));
     ble_hs_unlock();
+}
+
+#if MYNEWT_VAL(BLE_PERIODIC_ADV)
+static int
+ble_gap_per_adv_params_tx(uint8_t instance,
+               const struct ble_gap_per_adv_params *params)
+
+{
+       struct hci_per_adv_params hci_adv_params;
+       uint8_t buf[BLE_HCI_LE_SET_PER_ADV_PARAMS_LEN];
+       int rc;
+
+       memset(&hci_adv_params, 0, sizeof(hci_adv_params));
+
+       if (params->include_tx_power) {
+               hci_adv_params.properties |= 
BLE_HCI_LE_SET_PER_ADV_PROP_INC_TX_PWR;
+       }
+
+       /* Fill optional fields if application did not specify them. */
+       if (params->itvl_min == 0 && params->itvl_max == 0) {
+               hci_adv_params.min_interval = 30 / 1.25;   //30 ms
+               hci_adv_params.max_interval = 60 / 1.25;   //150 ms
+
+       } else {
+               hci_adv_params.min_interval = params->itvl_min;
+               hci_adv_params.max_interval = params->itvl_max;
+       }
+
+       rc = ble_hs_hci_cmd_build_le_per_adv_params(instance, &hci_adv_params, 
buf,
+                       sizeof(buf));
+       if (rc != 0) {
+               return rc;
+       }
+
+       rc = ble_hs_hci_cmd_tx_empty_ack(
+                       BLE_HCI_OP(BLE_HCI_OGF_LE, 
BLE_HCI_OCF_LE_SET_PER_ADV_PARAMS), buf,
+                       sizeof(buf));
+
+       if (rc != 0) {
+               return rc;
+       }
+
+       return 0;
+}
+
+static int
+ble_gap_per_adv_params_validate(
+               const struct ble_gap_per_adv_params *params) {
+       if (!params) {
+               return BLE_HS_EINVAL;
+       }
+
+       // 1- if anonymous return BLE_HS_EINVAL
 
 Review comment:
   looks like this function should  take instance and do full validation.

----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on GitHub and use the
URL above to go to the specific comment.
 
For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


With regards,
Apache Git Services

Reply via email to