Merge branch 'bufix/btdm_fix_save_key_when_auth_mode_without_bond' into 'master'

Component/bt: fix save keys when auth mode without bond

See merge request idf/esp-idf!3782
This commit is contained in:
Jiang Jiang Jian 2018-12-14 10:35:14 +08:00
commit bc30569842
2 changed files with 59 additions and 95 deletions

View File

@ -262,6 +262,10 @@ static void btc_dm_ble_auth_cmpl_evt (tBTA_DM_AUTH_CMPL *p_auth_cmpl)
BTC_TRACE_DEBUG ("%s, - pairing_cb.bd_addr: %08x%04x", __func__, BTC_TRACE_DEBUG ("%s, - pairing_cb.bd_addr: %08x%04x", __func__,
(pairing_cb.bd_addr[0] << 24) + (pairing_cb.bd_addr[1] << 16) + (pairing_cb.bd_addr[2] << 8) + pairing_cb.bd_addr[3], (pairing_cb.bd_addr[0] << 24) + (pairing_cb.bd_addr[1] << 16) + (pairing_cb.bd_addr[2] << 8) + pairing_cb.bd_addr[3],
(pairing_cb.bd_addr[4] << 8) + pairing_cb.bd_addr[5]); (pairing_cb.bd_addr[4] << 8) + pairing_cb.bd_addr[5]);
// Check if need to save BLE keys
if((p_auth_cmpl->auth_mode & SMP_AUTH_GEN_BOND) == 0) {
return;
}
if (btc_storage_get_remote_addr_type(&bdaddr, &addr_type) != BT_STATUS_SUCCESS) { if (btc_storage_get_remote_addr_type(&bdaddr, &addr_type) != BT_STATUS_SUCCESS) {
btc_storage_set_remote_addr_type(&bdaddr, p_auth_cmpl->addr_type, true); btc_storage_set_remote_addr_type(&bdaddr, p_auth_cmpl->addr_type, true);
} }

View File

@ -2028,22 +2028,18 @@ test cases:
- ['P SSC2 C +BLE:GattsDisconnect', 'P SSC1 C +BLE:GattcDisconnect,OK'] - ['P SSC2 C +BLE:GattsDisconnect', 'P SSC1 C +BLE:GattcDisconnect,OK']
- ID: BTSTK_SMP_07001 - ID: BTSTK_SMP_07001
<<: *SMP_CASE <<: *SMP_CASE
test point 2: BLE SMP bond and NVS test test point 2: BLE SMP no bond test and reconnect
summary: BLE SMP initiator bond with lagecy pairing summary: BLE SMP initiator with master passkey entry and reconnect
steps: | steps: |
1. DUT1 and DUT2 SMP bond with lagecy pairing 1. DUT1 and DUT2 SMP with master passkey entry
2. DUT1 disconnect 2. DUT1 disconnect
3. DUT1 connect to DUT2 3. DUT1 connect to DUT2
4. DUT1 disconnect 4. DUT2 send auth request
5. DUT1 reboot
6. DUT1 connect to DUT2
expected result: | expected result: |
1. succeed 1. succeed
2. succeed 2. succeed
3. connect succeed without pairing again 3. connect succeed
4. succeed 4. succeed
5. succeed
6. connect succeed without pairing again
cmd set: cmd set:
- "" - ""
- *config_master_passkey_entry - *config_master_passkey_entry
@ -2059,6 +2055,31 @@ test cases:
- - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>" - - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>"
- ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect'] - ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect']
- - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc" - - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc"
- ['P SSC[1-2] C +BLESMP:AuthComplete,Success']
- ID: BTSTK_SMP_07002
<<: *SMP_CASE
test point 2: BLE SMP no bond test and reboot
summary: BLE SMP initiator with master passkey entry and reboot
steps: |
1. DUT1 and DUT2 SMP bond with lagecy pairing
2. DUT1 reboot
3. DUT1 connect to DUT2
4. DUT2 send auth requst
expected result: |
1. succeed
2. succeed
3. connect succeed
4. fail
cmd set:
- ""
- *config_master_passkey_entry
- - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>"
- ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect']
- - "SSC SSC1 blesmp -E -r <dut2_bt_mac> -z Enc"
- ['P SSC2 C +BLESMP:SecReq']
- - "SSC SSC2 blesmp -R -a 1 -r <dut1_bt_mac>"
- ['P SSC1 C +BLESMP:PassKeyReq', 'P SSC2 A <key>:BLESMP:PassKeyNotify,(\d+)']
- - "SSC SSC1 blesmp -K -r <dut2_bt_mac> -a 1 -k <key>"
- ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0'] - ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0']
- - "SSC SSC[1-2] reboot" - - "SSC SSC[1-2] reboot"
- ['P SSC[1-2] C !!!ready!!!'] - ['P SSC[1-2] C !!!ready!!!']
@ -2075,25 +2096,23 @@ test cases:
- - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>" - - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>"
- ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect'] - ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect']
- - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc" - - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc"
- ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0'] - ['P SSC2 C +BLESMP:OK']
- ID: BTSTK_SMP_07002 - - DELAY 10
- ['P SSC[1-2] C +BLESMP:AuthComplete,Fail']
- ID: BTSTK_SMP_07003
<<: *SMP_CASE <<: *SMP_CASE
test point 2: BLE SMP bond and NVS test test point 2: BLE SMP no bond test and reconnect
summary: BLE SMP initiator bond with secure connection pairing summary: BLE SMP initiator numberic comparision and reconnect
steps: | steps: |
1. DUT1 and DUT2 SMP bond with secure connection pairing 1. DUT1 and DUT2 SMP with numberic comparision
2. DUT1 disconnect 2. DUT1 disconnect
3. DUT1 connect to DUT2 3. DUT1 connect to DUT2
4. DUT1 disconnect 4. DUT2 send auth requst
5. DUT1 reboot
6. DUT1 connect to DUT2
expected result: | expected result: |
1. succeed 1. succeed
2. succeed 2. succeed
3. connect succeed without pairing again 3. connect succeed
4. succeed 4. succeed
5. succeed
6. connect succeed without pairing again
cmd set: cmd set:
- "" - ""
- *config_numberic_comparision - *config_numberic_comparision
@ -2109,92 +2128,31 @@ test cases:
- - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>" - - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>"
- ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect'] - ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect']
- - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc" - - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc"
- ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0'] - ['P SSC[1-2] C +BLESMP:AuthComplete,Success']
- - "SSC SSC[1-2] reboot"
- ['P SSC[1-2] C !!!ready!!!']
- - "SSC SSC[1-2] ble -R"
- ['R SSC[1-2] C +BLE:']
- - "SSC SSC2 gatts -S -z load -p 0xA0"
- ['R SSC2 C +GATTS:StartService,OK,A000']
- - "SSC SSC2 bleadv -L -c 0 -t 3"
- ['R SSC2 C +BLEADV:SetAdv,OK']
- - "SSC SSC2 bleadv -D -z start"
- ['R SSC2 C +BLEADV:OK']
- - "SSC SSC[1-2] blesmp -L -c [1,0]"
- ['R SSC[1-2] C +BLESMP:OK']
- - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>"
- ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect']
- - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc"
- ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0']
- ID: BTSTK_SMP_07003
<<: *SMP_CASE
test point 2: BLE SMP bond and NVS test
summary: BLE SMP responder bond with lagecy pairing
steps: |
1. DUT1 and DUT2 SMP bond with lagecy pairing
2. DUT1 disconnect
3. DUT1 connect to DUT2
4. DUT1 disconnect
5. DUT1 reboot
6. DUT1 connect to DUT2
expected result: |
1. succeed
2. succeed
3. connect succeed without pairing again
4. succeed
5. succeed
6. connect succeed without pairing again
cmd set:
- ""
- *config_master_passkey_entry
- *master_passkey_entry_pair
- *disconnect
- - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>"
- ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect']
- - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc"
- ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0']
- - "SSC SSC[1-2] reboot"
- ['P SSC[1-2] C !!!ready!!!']
- - "SSC SSC[1-2] ble -R"
- ['R SSC[1-2] C +BLE:']
- - "SSC SSC2 gatts -S -z load -p 0xA0"
- ['R SSC2 C +GATTS:StartService,OK,A000']
- - "SSC SSC2 bleadv -L -c 0 -t 3"
- ['R SSC2 C +BLEADV:SetAdv,OK']
- - "SSC SSC2 bleadv -D -z start"
- ['R SSC2 C +BLEADV:OK']
- - "SSC SSC[1-2] blesmp -L -c [1,0]"
- ['R SSC[1-2] C +BLESMP:OK']
- - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>"
- ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect']
- - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc"
- ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0']
- ID: BTSTK_SMP_07004 - ID: BTSTK_SMP_07004
<<: *SMP_CASE <<: *SMP_CASE
test point 2: BLE SMP bond and NVS test test point 2: BLE SMP no bond test and reconnect
summary: BLE SMP responder bond with secure connection pairing summary: BLE SMP initiator numberic comparision and reconnect
steps: | steps: |
1. DUT1 and DUT2 SMP bond with secure connection pairing 1. DUT1 and DUT2 SMP with numberic comparision
2. DUT1 disconnect 2. DUT1 disconnect
3. DUT1 connect to DUT2 3. DUT1 and DUT2 reboot
4. DUT1 disconnect 4. DUT2 send auth requst
5. DUT1 reboot
6. DUT1 connect to DUT2
expected result: | expected result: |
1. succeed 1. succeed
2. succeed 2. succeed
3. connect succeed without pairing again 3. connect succeed
4. succeed 4. failed
5. succeed
6. connect succeed without pairing again
cmd set: cmd set:
- "" - ""
- *config_numberic_comparision - *config_numberic_comparision
- *numberic_comparision_pair
- *disconnect
- - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>" - - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>"
- ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect'] - ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect']
- - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc" - - "SSC SSC1 blesmp -E -r <dut2_bt_mac> -z Enc"
- ['P SSC2 C +BLESMP:SecReq']
- - "SSC SSC2 blesmp -R -a 1 -r <dut1_bt_mac>"
- ['R SSC2 A <key>:BLESMP:NCReq,(\d+)', 'R SSC1 C NCReq P <key>']
- - "SSC SSC[1-2] blesmp -C -r <dut[2,1]_bt_mac> -a 1"
- ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0'] - ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0']
- - "SSC SSC[1-2] reboot" - - "SSC SSC[1-2] reboot"
- ['P SSC[1-2] C !!!ready!!!'] - ['P SSC[1-2] C !!!ready!!!']
@ -2211,7 +2169,9 @@ test cases:
- - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>" - - "SSC SSC1 bleconn -C -p 0x10 -a <dut2_bt_mac>"
- ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect'] - ['P SSC1 C +BLE:GattcConnect,OK', 'P SSC2 C +BLE:GattsConnect']
- - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc" - - "SSC SSC2 blesmp -E -r <dut1_bt_mac> -z Enc"
- ['P SSC[1-2] C +BLESMP:AuthComplete,Success,0'] - ['P SSC2 C +BLESMP:OK']
- - DELAY 10
- ['P SSC[1-2] C +BLESMP:AuthComplete,Fail']
- ID: BTSTK_SMP_08001 - ID: BTSTK_SMP_08001
<<: *SMP_CASE <<: *SMP_CASE
test point 2: BLE SMP bond item management test test point 2: BLE SMP bond item management test