xref: /btstack/src/mesh/mesh_crypto.h (revision 77ba3d3f9fd2c90e975cda31e3c706784e95d43a)
1*77ba3d3fSMatthias Ringwald /*
2*77ba3d3fSMatthias Ringwald  * Copyright (C) 2017 BlueKitchen GmbH
3*77ba3d3fSMatthias Ringwald  *
4*77ba3d3fSMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
5*77ba3d3fSMatthias Ringwald  * modification, are permitted provided that the following conditions
6*77ba3d3fSMatthias Ringwald  * are met:
7*77ba3d3fSMatthias Ringwald  *
8*77ba3d3fSMatthias Ringwald  * 1. Redistributions of source code must retain the above copyright
9*77ba3d3fSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
10*77ba3d3fSMatthias Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
11*77ba3d3fSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
12*77ba3d3fSMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
13*77ba3d3fSMatthias Ringwald  * 3. Neither the name of the copyright holders nor the names of
14*77ba3d3fSMatthias Ringwald  *    contributors may be used to endorse or promote products derived
15*77ba3d3fSMatthias Ringwald  *    from this software without specific prior written permission.
16*77ba3d3fSMatthias Ringwald  * 4. Any redistribution, use, or modification is done solely for
17*77ba3d3fSMatthias Ringwald  *    personal benefit and not for any commercial purpose or for
18*77ba3d3fSMatthias Ringwald  *    monetary gain.
19*77ba3d3fSMatthias Ringwald  *
20*77ba3d3fSMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
21*77ba3d3fSMatthias Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22*77ba3d3fSMatthias Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23*77ba3d3fSMatthias Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
24*77ba3d3fSMatthias Ringwald  * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25*77ba3d3fSMatthias Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26*77ba3d3fSMatthias Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
27*77ba3d3fSMatthias Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
28*77ba3d3fSMatthias Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
29*77ba3d3fSMatthias Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
30*77ba3d3fSMatthias Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31*77ba3d3fSMatthias Ringwald  * SUCH DAMAGE.
32*77ba3d3fSMatthias Ringwald  *
33*77ba3d3fSMatthias Ringwald  * Please inquire about commercial licensing options at
34*77ba3d3fSMatthias Ringwald  * [email protected]
35*77ba3d3fSMatthias Ringwald  *
36*77ba3d3fSMatthias Ringwald  */
37*77ba3d3fSMatthias Ringwald 
38*77ba3d3fSMatthias Ringwald /*
39*77ba3d3fSMatthias Ringwald  *  provisioning.h
40*77ba3d3fSMatthias Ringwald  */
41*77ba3d3fSMatthias Ringwald 
42*77ba3d3fSMatthias Ringwald #ifndef __MESH_CRYPTO_H
43*77ba3d3fSMatthias Ringwald #define __MESH_CRYPTO_H
44*77ba3d3fSMatthias Ringwald 
45*77ba3d3fSMatthias Ringwald #include <stdint.h>
46*77ba3d3fSMatthias Ringwald #include "btstack_defines.h"
47*77ba3d3fSMatthias Ringwald #include "btstack_crypto.h"
48*77ba3d3fSMatthias Ringwald #include "mesh_keys.h"
49*77ba3d3fSMatthias Ringwald 
50*77ba3d3fSMatthias Ringwald #ifdef __cplusplus
51*77ba3d3fSMatthias Ringwald extern "C"
52*77ba3d3fSMatthias Ringwald {
53*77ba3d3fSMatthias Ringwald #endif
54*77ba3d3fSMatthias Ringwald 
55*77ba3d3fSMatthias Ringwald /**
56*77ba3d3fSMatthias Ringwald  * Calculate mesh k1 function
57*77ba3d3fSMatthias Ringwald  */
58*77ba3d3fSMatthias Ringwald void mesh_k1(btstack_crypto_aes128_cmac_t * request, const uint8_t * n, uint16_t n_len, const uint8_t * salt,
59*77ba3d3fSMatthias Ringwald     const uint8_t * p, const uint16_t p_len, uint8_t * result, void (* callback)(void * arg), void * callback_arg);
60*77ba3d3fSMatthias Ringwald 
61*77ba3d3fSMatthias Ringwald /**
62*77ba3d3fSMatthias Ringwald  * Calculate mesh k2 function
63*77ba3d3fSMatthias Ringwald  * @param result 33 bytes (7 bit NID + 16 byte Encryption Key + 16 byte Privacy Key)
64*77ba3d3fSMatthias Ringwald  */
65*77ba3d3fSMatthias Ringwald void mesh_k2(btstack_crypto_aes128_cmac_t * request, const uint8_t * n, uint8_t * result, void (* callback)(void * arg), void * callback_arg);
66*77ba3d3fSMatthias Ringwald 
67*77ba3d3fSMatthias Ringwald /**
68*77ba3d3fSMatthias Ringwald  * Calculate mesh k3 function
69*77ba3d3fSMatthias Ringwald  */
70*77ba3d3fSMatthias Ringwald void mesh_k3(btstack_crypto_aes128_cmac_t * request, const uint8_t * n, uint8_t * result, void (* callback)(void * arg), void * callback_arg);
71*77ba3d3fSMatthias Ringwald 
72*77ba3d3fSMatthias Ringwald /**
73*77ba3d3fSMatthias Ringwald  * Calculate mesh k4 function
74*77ba3d3fSMatthias Ringwald  */
75*77ba3d3fSMatthias Ringwald void mesh_k4(btstack_crypto_aes128_cmac_t * request, const uint8_t * n, uint8_t * result, void (* callback)(void * arg), void * callback_arg);
76*77ba3d3fSMatthias Ringwald 
77*77ba3d3fSMatthias Ringwald /**
78*77ba3d3fSMatthias Ringwald  * Calculate mesh virtual address hash
79*77ba3d3fSMatthias Ringwald  * @param request
80*77ba3d3fSMatthias Ringwald  * @param label_uuid
81*77ba3d3fSMatthias Ringwald  * @param addr
82*77ba3d3fSMatthias Ringwald  * @param callback
83*77ba3d3fSMatthias Ringwald  * @param callback_arg
84*77ba3d3fSMatthias Ringwald  */
85*77ba3d3fSMatthias Ringwald void mesh_virtual_address(btstack_crypto_aes128_cmac_t * request, const uint8_t * label_uuid, uint16_t * addr, void (* callback)(void * arg), void * callback_arg);
86*77ba3d3fSMatthias Ringwald 
87*77ba3d3fSMatthias Ringwald /**
88*77ba3d3fSMatthias Ringwald  * Derive security material from netkey
89*77ba3d3fSMatthias Ringwald  * @param request
90*77ba3d3fSMatthias Ringwald  * @param network_key
91*77ba3d3fSMatthias Ringwald  * @param callback
92*77ba3d3fSMatthias Ringwald  * @param callback_arg
93*77ba3d3fSMatthias Ringwald  */
94*77ba3d3fSMatthias Ringwald void mesh_network_key_derive(btstack_crypto_aes128_cmac_t * request, mesh_network_key_t * network_key, void (* callback)(void * arg), void * callback_arg);
95*77ba3d3fSMatthias Ringwald 
96*77ba3d3fSMatthias Ringwald /**
97*77ba3d3fSMatthias Ringwald  * Calc AID from AppKey
98*77ba3d3fSMatthias Ringwald  * @param request
99*77ba3d3fSMatthias Ringwald  * @param transport_key
100*77ba3d3fSMatthias Ringwald  * @param callback
101*77ba3d3fSMatthias Ringwald  * @param callback_arg
102*77ba3d3fSMatthias Ringwald  */
103*77ba3d3fSMatthias Ringwald void mesh_transport_key_calc_aid(btstack_crypto_aes128_cmac_t * request, mesh_transport_key_t * app_key, void (* callback)(void * arg), void * callback_arg);
104*77ba3d3fSMatthias Ringwald 
105*77ba3d3fSMatthias Ringwald 
106*77ba3d3fSMatthias Ringwald #ifdef __cplusplus
107*77ba3d3fSMatthias Ringwald } /* end of extern "C" */
108*77ba3d3fSMatthias Ringwald #endif
109*77ba3d3fSMatthias Ringwald 
110*77ba3d3fSMatthias Ringwald #endif
111