Skip to content

Commit

Permalink
Bluetooth: SMP: Fix failing to pass SM/MAS/PROT/BV-01-C
Browse files Browse the repository at this point in the history
smp_pairing_complete does actually clears flags so setting
SMP_FLAG_TIMEOUT must come after that.

Fixes zephyrproject-rtos#22786

Signed-off-by: Luiz Augusto von Dentz <[email protected]>
  • Loading branch information
Vudentz authored and jhedberg committed Feb 14, 2020
1 parent 49bf8b1 commit 1156412
Showing 1 changed file with 8 additions and 2 deletions.
10 changes: 8 additions & 2 deletions subsys/bluetooth/host/smp.c
Original file line number Diff line number Diff line change
Expand Up @@ -1761,6 +1761,9 @@ static void smp_reset(struct bt_smp *smp)
}
}

/* Note: This function not only does set the status but also calls smp_reset
* at the end which clears any flags previously set.
*/
static void smp_pairing_complete(struct bt_smp *smp, u8_t status)
{
BT_DBG("status 0x%x", status);
Expand Down Expand Up @@ -1816,9 +1819,12 @@ static void smp_timeout(struct k_work *work)

BT_ERR("SMP Timeout");

atomic_set_bit(smp->flags, SMP_FLAG_TIMEOUT);

smp_pairing_complete(smp, BT_SMP_ERR_UNSPECIFIED);

/* smp_pairing_complete clears flags so setting timeout flag must come
* after it.
*/
atomic_set_bit(smp->flags, SMP_FLAG_TIMEOUT);
}

static void smp_send(struct bt_smp *smp, struct net_buf *buf,
Expand Down

0 comments on commit 1156412

Please sign in to comment.