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