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