aboutsummaryrefslogtreecommitdiffstats
path: root/net/bluetooth/amp.c
diff options
context:
space:
mode:
authorDmitry Kasatkin <dmitry.kasatkin@intel.com>2012-09-27 10:26:17 -0400
committerGustavo Padovan <gustavo.padovan@collabora.co.uk>2012-09-27 16:18:40 -0400
commitba221bbabadd5fc2c80677b52178138fd694cc26 (patch)
tree1da965299f2089b603d57e123129c83df79528c2 /net/bluetooth/amp.c
parent93c3e8f5c9a0e4dc6b6c93108dcf3ec54ab1191a (diff)
Bluetooth: Add function to derive AMP key using hmac
hmac(sha256) will be used for AMP key generation. Signed-off-by: Dmitry Kasatkin <dmitry.kasatkin@intel.com> Signed-off-by: Andrei Emeltchenko <andrei.emeltchenko@intel.com> Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
Diffstat (limited to 'net/bluetooth/amp.c')
-rw-r--r--net/bluetooth/amp.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/net/bluetooth/amp.c b/net/bluetooth/amp.c
index 8ef912c36224..ea4d5ffc1151 100644
--- a/net/bluetooth/amp.c
+++ b/net/bluetooth/amp.c
@@ -16,6 +16,7 @@
16#include <net/bluetooth/hci_core.h> 16#include <net/bluetooth/hci_core.h>
17#include <net/bluetooth/a2mp.h> 17#include <net/bluetooth/a2mp.h>
18#include <net/bluetooth/amp.h> 18#include <net/bluetooth/amp.h>
19#include <crypto/hash.h>
19 20
20/* Remote AMP Controllers interface */ 21/* Remote AMP Controllers interface */
21static void amp_ctrl_get(struct amp_ctrl *ctrl) 22static void amp_ctrl_get(struct amp_ctrl *ctrl)
@@ -125,6 +126,41 @@ struct hci_conn *phylink_add(struct hci_dev *hdev, struct amp_mgr *mgr,
125 return hcon; 126 return hcon;
126} 127}
127 128
129/* AMP crypto key generation interface */
130static int hmac_sha256(u8 *key, u8 ksize, char *plaintext, u8 psize, u8 *output)
131{
132 int ret = 0;
133 struct crypto_shash *tfm;
134
135 if (!ksize)
136 return -EINVAL;
137
138 tfm = crypto_alloc_shash("hmac(sha256)", 0, 0);
139 if (IS_ERR(tfm)) {
140 BT_DBG("crypto_alloc_ahash failed: err %ld", PTR_ERR(tfm));
141 return PTR_ERR(tfm);
142 }
143
144 ret = crypto_shash_setkey(tfm, key, ksize);
145 if (ret) {
146 BT_DBG("crypto_ahash_setkey failed: err %d", ret);
147 } else {
148 struct {
149 struct shash_desc shash;
150 char ctx[crypto_shash_descsize(tfm)];
151 } desc;
152
153 desc.shash.tfm = tfm;
154 desc.shash.flags = CRYPTO_TFM_REQ_MAY_SLEEP;
155
156 ret = crypto_shash_digest(&desc.shash, plaintext, psize,
157 output);
158 }
159
160 crypto_free_shash(tfm);
161 return ret;
162}
163
128void amp_read_loc_assoc_frag(struct hci_dev *hdev, u8 phy_handle) 164void amp_read_loc_assoc_frag(struct hci_dev *hdev, u8 phy_handle)
129{ 165{
130 struct hci_cp_read_local_amp_assoc cp; 166 struct hci_cp_read_local_amp_assoc cp;