提交 6c0dcc50 编写于 作者: J Johan Hedberg 提交者: Marcel Holtmann

Bluetooth: Add check for accidentally generating a debug key

It is very unlikely, but to have a 100% guarantee of the generated key
type we need to reject any keys which happen to match the debug key.
Signed-off-by: NJohan Hedberg <johan.hedberg@intel.com>
Signed-off-by: NMarcel Holtmann <marcel@holtmann.org>
上级 aeb7d461
...@@ -1399,9 +1399,17 @@ static u8 sc_send_public_key(struct smp_chan *smp) ...@@ -1399,9 +1399,17 @@ static u8 sc_send_public_key(struct smp_chan *smp)
{ {
BT_DBG(""); BT_DBG("");
/* Generate local key pair for Secure Connections */ while (true) {
if (!ecc_make_key(smp->local_pk, smp->local_sk)) /* Generate local key pair for Secure Connections */
return SMP_UNSPECIFIED; if (!ecc_make_key(smp->local_pk, smp->local_sk))
return SMP_UNSPECIFIED;
/* This is unlikely, but we need to check that we didn't
* accidentially generate a debug key.
*/
if (memcmp(smp->local_sk, debug_sk, 32))
break;
}
BT_DBG("Local Public Key X: %32phN", smp->local_pk); BT_DBG("Local Public Key X: %32phN", smp->local_pk);
BT_DBG("Local Public Key Y: %32phN", &smp->local_pk[32]); BT_DBG("Local Public Key Y: %32phN", &smp->local_pk[32]);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册