extmod/modbluetooth: Fix descriptor registration with empty tuple.

Incorrect use of "continue" when the tuple was length zero meant it
broke the rest of the argument handling.

Signed-off-by: Jim Mussared <jim.mussared@gmail.com>
This commit is contained in:
Jim Mussared 2022-08-09 16:48:04 +10:00 committed by Damien George
parent 6e75d177e7
commit 82fc16f298

View File

@ -529,12 +529,9 @@ STATIC int bluetooth_gatts_register_service(mp_obj_t uuid_in, mp_obj_t character
// Optional third element, iterable of descriptors. // Optional third element, iterable of descriptors.
if (characteristic_len >= 3) { if (characteristic_len >= 3) {
mp_obj_t descriptors_len_in = mp_obj_len(characteristic_items[2]); mp_int_t n = mp_obj_get_int(mp_obj_len(characteristic_items[2]));
num_descriptors[characteristic_index] = mp_obj_get_int(descriptors_len_in); if (n) {
num_descriptors[characteristic_index] = n;
if (num_descriptors[characteristic_index] == 0) {
continue;
}
// Grow the flattened uuids and flags arrays with this many more descriptors. // Grow the flattened uuids and flags arrays with this many more descriptors.
descriptor_uuids = m_renew(mp_obj_bluetooth_uuid_t *, descriptor_uuids, descriptor_index, descriptor_index + num_descriptors[characteristic_index]); descriptor_uuids = m_renew(mp_obj_bluetooth_uuid_t *, descriptor_uuids, descriptor_index, descriptor_index + num_descriptors[characteristic_index]);
@ -567,6 +564,7 @@ STATIC int bluetooth_gatts_register_service(mp_obj_t uuid_in, mp_obj_t character
// Reflect that we've grown the handles array. // Reflect that we've grown the handles array.
*num_handles += num_descriptors[characteristic_index]; *num_handles += num_descriptors[characteristic_index];
} }
}
characteristic_uuids[characteristic_index] = MP_OBJ_TO_PTR(uuid_obj); characteristic_uuids[characteristic_index] = MP_OBJ_TO_PTR(uuid_obj);
characteristic_flags[characteristic_index] = mp_obj_get_int(characteristic_items[1]); characteristic_flags[characteristic_index] = mp_obj_get_int(characteristic_items[1]);