mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
fix(ble-mesh): don't use dangling pointer in nimble gatt service
This commit is contained in:
parent
1cb4f3468d
commit
9a34a1f0ad
@ -1309,7 +1309,6 @@ int bt_mesh_gatts_service_stop(struct bt_mesh_gatt_service *svc)
|
||||
{
|
||||
int rc;
|
||||
uint16_t handle;
|
||||
const ble_uuid_t *uuid;
|
||||
|
||||
if (!svc) {
|
||||
BT_ERR("%s, Invalid parameter", __func__);
|
||||
@ -1317,12 +1316,11 @@ int bt_mesh_gatts_service_stop(struct bt_mesh_gatt_service *svc)
|
||||
}
|
||||
|
||||
if (BLE_MESH_UUID_16(svc->attrs[0].user_data)->val == BT_UUID_MESH_PROXY_VAL) {
|
||||
uuid = BLE_UUID16_DECLARE(BT_UUID_MESH_PROXY_VAL);
|
||||
rc = ble_gatts_find_svc(BLE_UUID16_DECLARE(BT_UUID_MESH_PROXY_VAL), &handle);
|
||||
} else {
|
||||
uuid = BLE_UUID16_DECLARE(BT_UUID_MESH_PROV_VAL);
|
||||
rc = ble_gatts_find_svc(BLE_UUID16_DECLARE(BT_UUID_MESH_PROV_VAL), &handle);
|
||||
}
|
||||
|
||||
rc = ble_gatts_find_svc(uuid, &handle);
|
||||
assert(rc == 0);
|
||||
ble_gatts_svc_set_visibility(handle, 0);
|
||||
|
||||
@ -1336,15 +1334,13 @@ int bt_mesh_gatts_service_start(struct bt_mesh_gatt_service *svc)
|
||||
{
|
||||
int rc;
|
||||
uint16_t handle;
|
||||
const ble_uuid_t *uuid;
|
||||
|
||||
if (BLE_MESH_UUID_16(svc->attrs[0].user_data)->val == BT_UUID_MESH_PROXY_VAL) {
|
||||
uuid = BLE_UUID16_DECLARE(BT_UUID_MESH_PROXY_VAL);
|
||||
rc = ble_gatts_find_svc(BLE_UUID16_DECLARE(BT_UUID_MESH_PROXY_VAL), &handle);
|
||||
} else {
|
||||
uuid = BLE_UUID16_DECLARE(BT_UUID_MESH_PROV_VAL);
|
||||
rc = ble_gatts_find_svc(BLE_UUID16_DECLARE(BT_UUID_MESH_PROV_VAL), &handle);
|
||||
}
|
||||
|
||||
rc = ble_gatts_find_svc(uuid, &handle);
|
||||
assert(rc == 0);
|
||||
ble_gatts_svc_set_visibility(handle, 1);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user