component/bt: support BLE Application Layer Encryption key size check

This commit is contained in:
XieWenxiang 2020-09-15 17:25:50 +08:00 committed by xiewenxiang
parent a6ea010898
commit 8e08156141
7 changed files with 33 additions and 0 deletions

View File

@ -292,6 +292,8 @@ typedef enum {
ESP_BLE_SM_ONLY_ACCEPT_SPECIFIED_SEC_AUTH, ESP_BLE_SM_ONLY_ACCEPT_SPECIFIED_SEC_AUTH,
/* Enable/Disable OOB support */ /* Enable/Disable OOB support */
ESP_BLE_SM_OOB_SUPPORT, ESP_BLE_SM_OOB_SUPPORT,
/* Appl encryption key size */
ESP_BLE_APP_ENC_KEY_SIZE,
ESP_BLE_SM_MAX_PARAM, ESP_BLE_SM_MAX_PARAM,
} esp_ble_sm_param_t; } esp_ble_sm_param_t;

View File

@ -51,6 +51,7 @@ tBTE_APPL_CFG bte_appl_cfg = {
BTM_BLE_MIN_KEY_SIZE, BTM_BLE_MIN_KEY_SIZE,
BTM_BLE_ONLY_ACCEPT_SPECIFIED_SEC_AUTH_DISABLE, BTM_BLE_ONLY_ACCEPT_SPECIFIED_SEC_AUTH_DISABLE,
BTM_BLE_OOB_DISABLE, BTM_BLE_OOB_DISABLE,
BTM_BLE_APPL_ENC_KEY_SIZE,
}; };
#endif #endif
@ -427,6 +428,17 @@ void bta_dm_co_ble_set_min_key_size(UINT8 ble_key_size)
#endif ///SMP_INCLUDED == TRUE #endif ///SMP_INCLUDED == TRUE
} }
void bta_dm_co_ble_set_appl_enc_key_size(UINT8 ble_key_size)
{
#if (SMP_INCLUDED == TRUE)
if(ble_key_size >= bte_appl_cfg.ble_min_key_size && ble_key_size <= bte_appl_cfg.ble_max_key_size) {
bte_appl_cfg.ble_appl_enc_key_size = ble_key_size;
} else {
APPL_TRACE_ERROR("%s error:Invalid key size value, key_size =%d",__func__, ble_key_size);
}
#endif ///SMP_INCLUDED == TRUE
}
void bta_dm_co_ble_set_accept_auth_enable(UINT8 enable) void bta_dm_co_ble_set_accept_auth_enable(UINT8 enable)
{ {
#if (SMP_INCLUDED == TRUE) #if (SMP_INCLUDED == TRUE)

View File

@ -215,4 +215,6 @@ extern UINT8 bta_dm_co_ble_get_accept_auth_enable(void);
extern UINT8 bta_dm_co_ble_get_auth_req(void); extern UINT8 bta_dm_co_ble_get_auth_req(void);
extern void bta_dm_co_ble_oob_support(UINT8 enable); extern void bta_dm_co_ble_oob_support(UINT8 enable);
extern void bta_dm_co_ble_set_appl_enc_key_size(UINT8 ble_key_size);
#endif #endif

View File

@ -1254,6 +1254,12 @@ void btc_gap_ble_call_handler(btc_msg_t *msg)
bta_dm_co_ble_oob_support(enable); bta_dm_co_ble_oob_support(enable);
break; break;
} }
case ESP_BLE_APP_ENC_KEY_SIZE: {
uint8_t key_size = 0;
STREAM_TO_UINT8(key_size, value);
bta_dm_co_ble_set_appl_enc_key_size(key_size);
break;
}
default: default:
break; break;
} }

View File

@ -34,6 +34,7 @@ typedef struct {
UINT8 ble_min_key_size; UINT8 ble_min_key_size;
UINT8 ble_accept_auth_enable; UINT8 ble_accept_auth_enable;
UINT8 oob_support; UINT8 oob_support;
UINT8 ble_appl_enc_key_size;
#endif #endif
} tBTE_APPL_CFG; } tBTE_APPL_CFG;

View File

@ -34,6 +34,7 @@
#include "gatt_int.h" #include "gatt_int.h"
#include "stack/l2c_api.h" #include "stack/l2c_api.h"
#include "btm_int.h" #include "btm_int.h"
#include "common/bte_appl.h"
/******************************************************************************** /********************************************************************************
** L O C A L F U N C T I O N P R O T O T Y P E S * ** L O C A L F U N C T I O N P R O T O T Y P E S *
@ -124,10 +125,14 @@ static tGATT_STATUS gatts_check_attr_readability(tGATT_ATTR16 *p_attr,
tGATT_PERM perm = p_attr->permission; tGATT_PERM perm = p_attr->permission;
UNUSED(offset); UNUSED(offset);
#if SMP_INCLUDED == TRUE
min_key_size = bte_appl_cfg.ble_appl_enc_key_size;
#else
min_key_size = (((perm & GATT_ENCRYPT_KEY_SIZE_MASK) >> 12)); min_key_size = (((perm & GATT_ENCRYPT_KEY_SIZE_MASK) >> 12));
if (min_key_size != 0 ) { if (min_key_size != 0 ) {
min_key_size += 6; min_key_size += 6;
} }
#endif
if (!(perm & GATT_READ_ALLOWED)) { if (!(perm & GATT_READ_ALLOWED)) {
GATT_TRACE_ERROR( "GATT_READ_NOT_PERMIT\n"); GATT_TRACE_ERROR( "GATT_READ_NOT_PERMIT\n");
@ -1072,10 +1077,14 @@ tGATT_STATUS gatts_write_attr_perm_check (tGATT_SVC_DB *p_db, UINT8 op_code,
while (p_attr != NULL) { while (p_attr != NULL) {
if (p_attr->handle == handle) { if (p_attr->handle == handle) {
perm = p_attr->permission; perm = p_attr->permission;
#if SMP_INCLUDED == TRUE
min_key_size = bte_appl_cfg.ble_appl_enc_key_size;
#else
min_key_size = (((perm & GATT_ENCRYPT_KEY_SIZE_MASK) >> 12)); min_key_size = (((perm & GATT_ENCRYPT_KEY_SIZE_MASK) >> 12));
if (min_key_size != 0 ) { if (min_key_size != 0 ) {
min_key_size += 6; min_key_size += 6;
} }
#endif
GATT_TRACE_DEBUG( "gatts_write_attr_perm_check p_attr->permission =0x%04x min_key_size==0x%04x", GATT_TRACE_DEBUG( "gatts_write_attr_perm_check p_attr->permission =0x%04x min_key_size==0x%04x",
p_attr->permission, p_attr->permission,
min_key_size); min_key_size);

View File

@ -1450,6 +1450,7 @@ typedef UINT8 tBTM_IO_CAP;
#define BTM_BLE_RESPONDER_KEY_SIZE 15 #define BTM_BLE_RESPONDER_KEY_SIZE 15
#define BTM_BLE_MAX_KEY_SIZE 16 #define BTM_BLE_MAX_KEY_SIZE 16
#define BTM_BLE_MIN_KEY_SIZE 7 #define BTM_BLE_MIN_KEY_SIZE 7
#define BTM_BLE_APPL_ENC_KEY_SIZE 7
typedef UINT8 tBTM_AUTH_REQ; typedef UINT8 tBTM_AUTH_REQ;