Skip to content

Commit

Permalink
Bluetooth: Add skeleton for SMP self-tests
Browse files Browse the repository at this point in the history
This patch adds a basic skeleton for SMP self-tests. The tests are put
behind a new configuration option since running them will slow down the
boot process. For now there are no actual tests defined but those will
come in a subsequent patch.

Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
  • Loading branch information
Johan Hedberg authored and Marcel Holtmann committed Oct 25, 2014
1 parent e491eaf commit 4cd3362
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 0 deletions.
6 changes: 6 additions & 0 deletions net/bluetooth/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,12 @@ config BT_6LOWPAN
help
IPv6 compression over Bluetooth Low Energy.

config BT_SELFTEST
bool "Run self-tests on boot"
depends on BT && DEBUG_KERNEL
help
Run self-tests during boot. Currently limited to SMP.

source "net/bluetooth/rfcomm/Kconfig"

source "net/bluetooth/bnep/Kconfig"
Expand Down
33 changes: 33 additions & 0 deletions net/bluetooth/smp.c
Original file line number Diff line number Diff line change
Expand Up @@ -1743,3 +1743,36 @@ void smp_unregister(struct hci_dev *hdev)
hdev->smp_data = NULL;
l2cap_chan_put(chan);
}

#ifdef CONFIG_BT_SELFTEST

static int __init run_selftests(struct crypto_blkcipher *tfm_aes)
{
return 0;
}

static int __init test_smp(void)
{
struct crypto_blkcipher *tfm_aes;
int err;

tfm_aes = crypto_alloc_blkcipher("ecb(aes)", 0, CRYPTO_ALG_ASYNC);
if (IS_ERR(tfm_aes)) {
BT_ERR("Unable to create ECB crypto context");
return PTR_ERR(tfm_aes);
}

err = run_selftests(tfm_aes);
if (err < 0)
BT_ERR("Self tests failed");
else
BT_INFO("Self-tests passed");

crypto_free_blkcipher(tfm_aes);

return err;
}

module_init(test_smp);

#endif /* CONFIG_BT_SELFTEST */

0 comments on commit 4cd3362

Please sign in to comment.