xref: /btstack/src/mesh/mesh_crypto.h (revision 2fca4dad957cd7b88f4657ed51e89c12615dda72)
177ba3d3fSMatthias Ringwald /*
277ba3d3fSMatthias Ringwald  * Copyright (C) 2017 BlueKitchen GmbH
377ba3d3fSMatthias Ringwald  *
477ba3d3fSMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
577ba3d3fSMatthias Ringwald  * modification, are permitted provided that the following conditions
677ba3d3fSMatthias Ringwald  * are met:
777ba3d3fSMatthias Ringwald  *
877ba3d3fSMatthias Ringwald  * 1. Redistributions of source code must retain the above copyright
977ba3d3fSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
1077ba3d3fSMatthias Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
1177ba3d3fSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
1277ba3d3fSMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
1377ba3d3fSMatthias Ringwald  * 3. Neither the name of the copyright holders nor the names of
1477ba3d3fSMatthias Ringwald  *    contributors may be used to endorse or promote products derived
1577ba3d3fSMatthias Ringwald  *    from this software without specific prior written permission.
1677ba3d3fSMatthias Ringwald  * 4. Any redistribution, use, or modification is done solely for
1777ba3d3fSMatthias Ringwald  *    personal benefit and not for any commercial purpose or for
1877ba3d3fSMatthias Ringwald  *    monetary gain.
1977ba3d3fSMatthias Ringwald  *
2077ba3d3fSMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
2177ba3d3fSMatthias Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
2277ba3d3fSMatthias Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23*2fca4dadSMilanka Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BLUEKITCHEN
24*2fca4dadSMilanka Ringwald  * GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
2577ba3d3fSMatthias Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
2677ba3d3fSMatthias Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
2777ba3d3fSMatthias Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
2877ba3d3fSMatthias Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
2977ba3d3fSMatthias Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
3077ba3d3fSMatthias Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
3177ba3d3fSMatthias Ringwald  * SUCH DAMAGE.
3277ba3d3fSMatthias Ringwald  *
3377ba3d3fSMatthias Ringwald  * Please inquire about commercial licensing options at
3477ba3d3fSMatthias Ringwald  * [email protected]
3577ba3d3fSMatthias Ringwald  *
3677ba3d3fSMatthias Ringwald  */
3777ba3d3fSMatthias Ringwald 
3877ba3d3fSMatthias Ringwald /*
3977ba3d3fSMatthias Ringwald  *  provisioning.h
4077ba3d3fSMatthias Ringwald  */
4177ba3d3fSMatthias Ringwald 
4277ba3d3fSMatthias Ringwald #ifndef __MESH_CRYPTO_H
4377ba3d3fSMatthias Ringwald #define __MESH_CRYPTO_H
4477ba3d3fSMatthias Ringwald 
4577ba3d3fSMatthias Ringwald #include <stdint.h>
46f4854a5eSMatthias Ringwald 
4777ba3d3fSMatthias Ringwald #include "btstack_defines.h"
4877ba3d3fSMatthias Ringwald #include "btstack_crypto.h"
49f4854a5eSMatthias Ringwald 
50f4854a5eSMatthias Ringwald #include "mesh/mesh_keys.h"
5177ba3d3fSMatthias Ringwald 
5277ba3d3fSMatthias Ringwald #ifdef __cplusplus
5377ba3d3fSMatthias Ringwald extern "C"
5477ba3d3fSMatthias Ringwald {
5577ba3d3fSMatthias Ringwald #endif
5677ba3d3fSMatthias Ringwald 
5777ba3d3fSMatthias Ringwald /**
5877ba3d3fSMatthias Ringwald  * Calculate mesh k1 function
5977ba3d3fSMatthias Ringwald  */
6077ba3d3fSMatthias Ringwald void mesh_k1(btstack_crypto_aes128_cmac_t * request, const uint8_t * n, uint16_t n_len, const uint8_t * salt,
6177ba3d3fSMatthias Ringwald     const uint8_t * p, const uint16_t p_len, uint8_t * result, void (* callback)(void * arg), void * callback_arg);
6277ba3d3fSMatthias Ringwald 
6377ba3d3fSMatthias Ringwald /**
6477ba3d3fSMatthias Ringwald  * Calculate mesh k2 function
6577ba3d3fSMatthias Ringwald  * @param result 33 bytes (7 bit NID + 16 byte Encryption Key + 16 byte Privacy Key)
6677ba3d3fSMatthias Ringwald  */
6777ba3d3fSMatthias Ringwald void mesh_k2(btstack_crypto_aes128_cmac_t * request, const uint8_t * n, uint8_t * result, void (* callback)(void * arg), void * callback_arg);
6877ba3d3fSMatthias Ringwald 
6977ba3d3fSMatthias Ringwald /**
7077ba3d3fSMatthias Ringwald  * Calculate mesh k3 function
7177ba3d3fSMatthias Ringwald  */
7277ba3d3fSMatthias Ringwald void mesh_k3(btstack_crypto_aes128_cmac_t * request, const uint8_t * n, uint8_t * result, void (* callback)(void * arg), void * callback_arg);
7377ba3d3fSMatthias Ringwald 
7477ba3d3fSMatthias Ringwald /**
7577ba3d3fSMatthias Ringwald  * Calculate mesh k4 function
7677ba3d3fSMatthias Ringwald  */
7777ba3d3fSMatthias Ringwald void mesh_k4(btstack_crypto_aes128_cmac_t * request, const uint8_t * n, uint8_t * result, void (* callback)(void * arg), void * callback_arg);
7877ba3d3fSMatthias Ringwald 
7977ba3d3fSMatthias Ringwald /**
8077ba3d3fSMatthias Ringwald  * Calculate mesh virtual address hash
8177ba3d3fSMatthias Ringwald  * @param request
8277ba3d3fSMatthias Ringwald  * @param label_uuid
8377ba3d3fSMatthias Ringwald  * @param addr
8477ba3d3fSMatthias Ringwald  * @param callback
8577ba3d3fSMatthias Ringwald  * @param callback_arg
8677ba3d3fSMatthias Ringwald  */
8777ba3d3fSMatthias 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);
8877ba3d3fSMatthias Ringwald 
8977ba3d3fSMatthias Ringwald /**
9077ba3d3fSMatthias Ringwald  * Derive security material from netkey
9177ba3d3fSMatthias Ringwald  * @param request
9277ba3d3fSMatthias Ringwald  * @param network_key
9377ba3d3fSMatthias Ringwald  * @param callback
9477ba3d3fSMatthias Ringwald  * @param callback_arg
9577ba3d3fSMatthias Ringwald  */
9677ba3d3fSMatthias 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);
9777ba3d3fSMatthias Ringwald 
9877ba3d3fSMatthias Ringwald /**
9977ba3d3fSMatthias Ringwald  * Calc AID from AppKey
10077ba3d3fSMatthias Ringwald  * @param request
10177ba3d3fSMatthias Ringwald  * @param transport_key
10277ba3d3fSMatthias Ringwald  * @param callback
10377ba3d3fSMatthias Ringwald  * @param callback_arg
10477ba3d3fSMatthias Ringwald  */
10577ba3d3fSMatthias 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);
10677ba3d3fSMatthias Ringwald 
10777ba3d3fSMatthias Ringwald 
10877ba3d3fSMatthias Ringwald #ifdef __cplusplus
10977ba3d3fSMatthias Ringwald } /* end of extern "C" */
11077ba3d3fSMatthias Ringwald #endif
11177ba3d3fSMatthias Ringwald 
11277ba3d3fSMatthias Ringwald #endif
113