btstack_posix_tlv: use max value size of 2048, assert if size is larger in store

This commit is contained in:
Matthias Ringwald 2021-11-20 20:34:09 +01:00
parent 0d37aff3fe
commit c78b4f699d
2 changed files with 9 additions and 2 deletions

View File

@ -66,6 +66,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.
- *btstack_run_loop_execute_on_main_thread*: schedule code execution on main thread from other thread - *btstack_run_loop_execute_on_main_thread*: schedule code execution on main thread from other thread
- *btstack_run_loop_trigger_exit*: trigger run loop exit - *btstack_run_loop_trigger_exit*: trigger run loop exit
- POSIX / Windows / Raspi / Qt: use updated ctrl-c handling - POSIX / Windows / Raspi / Qt: use updated ctrl-c handling
- POSIX TLV: use max value size of 2048, assert if size is larger in store
## Release v1.4.1 ## Release v1.4.1

View File

@ -54,6 +54,9 @@
// - Value: Len in bytes // - Value: Len in bytes
#define BTSTACK_TLV_HEADER_LEN 8 #define BTSTACK_TLV_HEADER_LEN 8
#define MAX_TLV_VALUE_SIZE 2048
static const char * btstack_tlv_header_magic = "BTstack"; static const char * btstack_tlv_header_magic = "BTstack";
#define DUMMY_SIZE 4 #define DUMMY_SIZE 4
@ -141,6 +144,9 @@ static int btstack_tlv_posix_get_tag(void * context, uint32_t tag, uint8_t * buf
static int btstack_tlv_posix_store_tag(void * context, uint32_t tag, const uint8_t * data, uint32_t data_size){ static int btstack_tlv_posix_store_tag(void * context, uint32_t tag, const uint8_t * data, uint32_t data_size){
btstack_tlv_posix_t * self = (btstack_tlv_posix_t *) context; btstack_tlv_posix_t * self = (btstack_tlv_posix_t *) context;
// enforce arbitrary max value size
btstack_assert(data_size <= MAX_TLV_VALUE_SIZE);
// remove old entry // remove old entry
tlv_entry_t * old_entry = btstack_tlv_posix_find_entry(self, tag); tlv_entry_t * old_entry = btstack_tlv_posix_find_entry(self, tag);
if (old_entry){ if (old_entry){
@ -193,8 +199,8 @@ static int btstack_tlv_posix_read_db(btstack_tlv_posix_t * self){
uint32_t tag = big_endian_read_32(entry, 0); uint32_t tag = big_endian_read_32(entry, 0);
uint32_t len = big_endian_read_32(entry, 4); uint32_t len = big_endian_read_32(entry, 4);
// arbitrary safety check: values < 1000 bytes each // arbitrary safety check: values <= MAX_TLV_VALUE_SIZE
if (len > 1000) break; if (len > MAX_TLV_VALUE_SIZE) break;
// create new entry for regular tag // create new entry for regular tag
tlv_entry_t * new_entry = NULL; tlv_entry_t * new_entry = NULL;