xref: /btstack/src/ble/le_device_db.h (revision 3deb3ec68039c68a16974dffc53343233662f909)
1*3deb3ec6SMatthias Ringwald /*
2*3deb3ec6SMatthias Ringwald  * Copyright (C) 2014 BlueKitchen GmbH
3*3deb3ec6SMatthias Ringwald  *
4*3deb3ec6SMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
5*3deb3ec6SMatthias Ringwald  * modification, are permitted provided that the following conditions
6*3deb3ec6SMatthias Ringwald  * are met:
7*3deb3ec6SMatthias Ringwald  *
8*3deb3ec6SMatthias Ringwald  * 1. Redistributions of source code must retain the above copyright
9*3deb3ec6SMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
10*3deb3ec6SMatthias Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
11*3deb3ec6SMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
12*3deb3ec6SMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
13*3deb3ec6SMatthias Ringwald  * 3. Neither the name of the copyright holders nor the names of
14*3deb3ec6SMatthias Ringwald  *    contributors may be used to endorse or promote products derived
15*3deb3ec6SMatthias Ringwald  *    from this software without specific prior written permission.
16*3deb3ec6SMatthias Ringwald  * 4. Any redistribution, use, or modification is done solely for
17*3deb3ec6SMatthias Ringwald  *    personal benefit and not for any commercial purpose or for
18*3deb3ec6SMatthias Ringwald  *    monetary gain.
19*3deb3ec6SMatthias Ringwald  *
20*3deb3ec6SMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
21*3deb3ec6SMatthias Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22*3deb3ec6SMatthias Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23*3deb3ec6SMatthias Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
24*3deb3ec6SMatthias Ringwald  * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25*3deb3ec6SMatthias Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26*3deb3ec6SMatthias Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
27*3deb3ec6SMatthias Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
28*3deb3ec6SMatthias Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
29*3deb3ec6SMatthias Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
30*3deb3ec6SMatthias Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31*3deb3ec6SMatthias Ringwald  * SUCH DAMAGE.
32*3deb3ec6SMatthias Ringwald  *
33*3deb3ec6SMatthias Ringwald  * Please inquire about commercial licensing options at
34*3deb3ec6SMatthias Ringwald  * [email protected]
35*3deb3ec6SMatthias Ringwald  *
36*3deb3ec6SMatthias Ringwald  */
37*3deb3ec6SMatthias Ringwald 
38*3deb3ec6SMatthias Ringwald #ifndef __LE_DEVICE_DB_H
39*3deb3ec6SMatthias Ringwald #define __LE_DEVICE_DB_H
40*3deb3ec6SMatthias Ringwald 
41*3deb3ec6SMatthias Ringwald #include "utils.h"
42*3deb3ec6SMatthias Ringwald 
43*3deb3ec6SMatthias Ringwald #if defined __cplusplus
44*3deb3ec6SMatthias Ringwald extern "C" {
45*3deb3ec6SMatthias Ringwald #endif
46*3deb3ec6SMatthias Ringwald 
47*3deb3ec6SMatthias Ringwald /**
48*3deb3ec6SMatthias Ringwald 
49*3deb3ec6SMatthias Ringwald 	LE Device DB for pure LE Peripherals is only required for signed writes
50*3deb3ec6SMatthias Ringwald 
51*3deb3ec6SMatthias Ringwald 	Per bonded device, it can store
52*3deb3ec6SMatthias Ringwald 	- it stores the Identity Resolving Key (IRK) and its address to resolve private addresses
53*3deb3ec6SMatthias Ringwald     - it stores the LTK + EDIV, RAND. EDIV + RAND allow a LE Perihperal to reconstruct the LTK
54*3deb3ec6SMatthias Ringwald     - it stores the Connection Signature Resolving Key (CSRK) and the last used counter.
55*3deb3ec6SMatthias Ringwald     	The CSRK is used to generate the signatur on the remote device and is needed to verify the signature itself
56*3deb3ec6SMatthias Ringwald 		The Counter is necessary to prevent reply attacks
57*3deb3ec6SMatthias Ringwald 
58*3deb3ec6SMatthias Ringwald */
59*3deb3ec6SMatthias Ringwald 
60*3deb3ec6SMatthias Ringwald 
61*3deb3ec6SMatthias Ringwald // LE Device db interface
62*3deb3ec6SMatthias Ringwald 
63*3deb3ec6SMatthias Ringwald /* API_START */
64*3deb3ec6SMatthias Ringwald 
65*3deb3ec6SMatthias Ringwald /**
66*3deb3ec6SMatthias Ringwald  * @brief init
67*3deb3ec6SMatthias Ringwald  */
68*3deb3ec6SMatthias Ringwald void le_device_db_init(void);
69*3deb3ec6SMatthias Ringwald 
70*3deb3ec6SMatthias Ringwald /**
71*3deb3ec6SMatthias Ringwald  * @brief add device to db
72*3deb3ec6SMatthias Ringwald  * @param addr_type, address of the device
73*3deb3ec6SMatthias Ringwald  * @param irk of the device
74*3deb3ec6SMatthias Ringwald  * @returns index if successful, -1 otherwise
75*3deb3ec6SMatthias Ringwald  */
76*3deb3ec6SMatthias Ringwald int le_device_db_add(int addr_type, bd_addr_t addr, sm_key_t irk);
77*3deb3ec6SMatthias Ringwald 
78*3deb3ec6SMatthias Ringwald /**
79*3deb3ec6SMatthias Ringwald  * @brief get number of devices in db for enumeration
80*3deb3ec6SMatthias Ringwald  * @returns number of device in db
81*3deb3ec6SMatthias Ringwald  */
82*3deb3ec6SMatthias Ringwald int le_device_db_count(void);
83*3deb3ec6SMatthias Ringwald 
84*3deb3ec6SMatthias Ringwald /**
85*3deb3ec6SMatthias Ringwald  * @brief get device information: addr type and address needed to identify device
86*3deb3ec6SMatthias Ringwald  * @param index
87*3deb3ec6SMatthias Ringwald  * @param addr_type, address of the device as output
88*3deb3ec6SMatthias Ringwald  * @param irk of the device
89*3deb3ec6SMatthias Ringwald  */
90*3deb3ec6SMatthias Ringwald void le_device_db_info(int index, int * addr_type, bd_addr_t addr, sm_key_t irk);
91*3deb3ec6SMatthias Ringwald 
92*3deb3ec6SMatthias Ringwald 
93*3deb3ec6SMatthias Ringwald /**
94*3deb3ec6SMatthias Ringwald  * @brief set remote encryption info
95*3deb3ec6SMatthias Ringwald  * @brief index
96*3deb3ec6SMatthias Ringwald  * @brief ediv
97*3deb3ec6SMatthias Ringwald  * @brief rand
98*3deb3ec6SMatthias Ringwald  * @brief ltk
99*3deb3ec6SMatthias Ringwald  * @brief key size
100*3deb3ec6SMatthias Ringwald  * @brief authenticated
101*3deb3ec6SMatthias Ringwald  * @brief authorized
102*3deb3ec6SMatthias Ringwald  */
103*3deb3ec6SMatthias Ringwald void le_device_db_encryption_set(int index, uint16_t ediv, uint8_t rand[8], sm_key_t ltk, int key_size, int authenticated, int authorized);
104*3deb3ec6SMatthias Ringwald 
105*3deb3ec6SMatthias Ringwald /**
106*3deb3ec6SMatthias Ringwald  * @brief get remote encryption info
107*3deb3ec6SMatthias Ringwald  * @brief index
108*3deb3ec6SMatthias Ringwald  * @brief ediv
109*3deb3ec6SMatthias Ringwald  * @brief rand
110*3deb3ec6SMatthias Ringwald  * @brief ltk
111*3deb3ec6SMatthias Ringwald  * @brief key size
112*3deb3ec6SMatthias Ringwald  * @brief authenticated
113*3deb3ec6SMatthias Ringwald  * @brief authorized
114*3deb3ec6SMatthias Ringwald  */
115*3deb3ec6SMatthias Ringwald void le_device_db_encryption_get(int index, uint16_t * ediv, uint8_t rand[8], sm_key_t ltk,  int * key_size, int * authenticated, int * authorized);
116*3deb3ec6SMatthias Ringwald 
117*3deb3ec6SMatthias Ringwald /**
118*3deb3ec6SMatthias Ringwald  * @brief set local signing key for this device
119*3deb3ec6SMatthias Ringwald  * @param index
120*3deb3ec6SMatthias Ringwald  * @param signing key as input
121*3deb3ec6SMatthias Ringwald  */
122*3deb3ec6SMatthias Ringwald void le_device_db_local_csrk_set(int index, sm_key_t csrk);
123*3deb3ec6SMatthias Ringwald 
124*3deb3ec6SMatthias Ringwald /**
125*3deb3ec6SMatthias Ringwald  * @brief get local signing key for this device
126*3deb3ec6SMatthias Ringwald  * @param index
127*3deb3ec6SMatthias Ringwald  * @param signing key as output
128*3deb3ec6SMatthias Ringwald  */
129*3deb3ec6SMatthias Ringwald void le_device_db_local_csrk_get(int index, sm_key_t csrk);
130*3deb3ec6SMatthias Ringwald 
131*3deb3ec6SMatthias Ringwald /**
132*3deb3ec6SMatthias Ringwald  * @brief set remote signing key for this device
133*3deb3ec6SMatthias Ringwald  * @param index
134*3deb3ec6SMatthias Ringwald  * @param signing key as input
135*3deb3ec6SMatthias Ringwald  */
136*3deb3ec6SMatthias Ringwald void le_device_db_remote_csrk_set(int index, sm_key_t csrk);
137*3deb3ec6SMatthias Ringwald 
138*3deb3ec6SMatthias Ringwald /**
139*3deb3ec6SMatthias Ringwald  * @brief get remote signing key for this device
140*3deb3ec6SMatthias Ringwald  * @param index
141*3deb3ec6SMatthias Ringwald  * @param signing key as output
142*3deb3ec6SMatthias Ringwald  */
143*3deb3ec6SMatthias Ringwald void le_device_db_remote_csrk_get(int index, sm_key_t csrk);
144*3deb3ec6SMatthias Ringwald 
145*3deb3ec6SMatthias Ringwald /**
146*3deb3ec6SMatthias Ringwald  * @brief query last used/seen signing counter
147*3deb3ec6SMatthias Ringwald  * @param index
148*3deb3ec6SMatthias Ringwald  * @returns next expected counter, 0 after devices was added
149*3deb3ec6SMatthias Ringwald  */
150*3deb3ec6SMatthias Ringwald uint32_t le_device_db_remote_counter_get(int index);
151*3deb3ec6SMatthias Ringwald 
152*3deb3ec6SMatthias Ringwald /**
153*3deb3ec6SMatthias Ringwald  * @brief update signing counter
154*3deb3ec6SMatthias Ringwald  * @param index
155*3deb3ec6SMatthias Ringwald  * @param counter to store
156*3deb3ec6SMatthias Ringwald  */
157*3deb3ec6SMatthias Ringwald void le_device_db_remote_counter_set(int index, uint32_t counter);
158*3deb3ec6SMatthias Ringwald 
159*3deb3ec6SMatthias Ringwald /**
160*3deb3ec6SMatthias Ringwald  * @brief query last used/seen signing counter
161*3deb3ec6SMatthias Ringwald  * @param index
162*3deb3ec6SMatthias Ringwald  * @returns next expected counter, 0 after devices was added
163*3deb3ec6SMatthias Ringwald  */
164*3deb3ec6SMatthias Ringwald uint32_t le_device_db_local_counter_get(int index);
165*3deb3ec6SMatthias Ringwald 
166*3deb3ec6SMatthias Ringwald /**
167*3deb3ec6SMatthias Ringwald  * @brief update signing counter
168*3deb3ec6SMatthias Ringwald  * @param index
169*3deb3ec6SMatthias Ringwald  * @param counter to store
170*3deb3ec6SMatthias Ringwald  */
171*3deb3ec6SMatthias Ringwald void le_device_db_local_counter_set(int index, uint32_t counter);
172*3deb3ec6SMatthias Ringwald 
173*3deb3ec6SMatthias Ringwald /**
174*3deb3ec6SMatthias Ringwald  * @brief free device
175*3deb3ec6SMatthias Ringwald  * @param index
176*3deb3ec6SMatthias Ringwald  */
177*3deb3ec6SMatthias Ringwald void le_device_db_remove(int index);
178*3deb3ec6SMatthias Ringwald 
179*3deb3ec6SMatthias Ringwald void le_device_db_dump(void);
180*3deb3ec6SMatthias Ringwald 
181*3deb3ec6SMatthias Ringwald /* API_END */
182*3deb3ec6SMatthias Ringwald 
183*3deb3ec6SMatthias Ringwald #if defined __cplusplus
184*3deb3ec6SMatthias Ringwald }
185*3deb3ec6SMatthias Ringwald #endif
186*3deb3ec6SMatthias Ringwald 
187*3deb3ec6SMatthias Ringwald #endif // __LE_DEVICE_DB_H
188