CC3000  1.12
 All Classes Functions Groups
security.h
1 /*****************************************************************************
2 *
3 * security.h - CC3000 Host Driver Implementation.
4 * Copyright (C) 2011 Texas Instruments Incorporated - https://www.ti.com/
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 *
13 * Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the
16 * distribution.
17 *
18 * Neither the name of Texas Instruments Incorporated nor the names of
19 * its contributors may be used to endorse or promote products derived
20 * from this software without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
25 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
26 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
27 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
28 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
29 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
30 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
32 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 *
34 *****************************************************************************/
35 #ifndef __SECURITY__
36 #define __SECURITY__
37 
38 #include "nvmem.h"
39 
40 //*****************************************************************************
41 //
42 // If building with a C++ compiler, make all of the definitions in this header
43 // have a C binding.
44 //
45 //*****************************************************************************
46 #ifdef __cplusplus
47 extern "C" {
48 #endif
49 
50 
51 #define AES128_KEY_SIZE 16
52 
53 #ifndef CC3000_UNENCRYPTED_SMART_CONFIG
54 
55 
56 //*****************************************************************************
57 //
71 //*****************************************************************************
72 extern void aes_encrypt(UINT8 *state, UINT8 *key);
73 
74 //*****************************************************************************
75 //
89 //*****************************************************************************
90 extern void aes_decrypt(UINT8 *state, UINT8 *key);
91 
92 
93 //*****************************************************************************
94 //
106 //*****************************************************************************
107 extern INT32 aes_read_key(UINT8 *key);
108 
109 //*****************************************************************************
110 //
121 //*****************************************************************************
122 extern INT32 aes_write_key(UINT8 *key);
123 
124 #endif //CC3000_UNENCRYPTED_SMART_CONFIG
125 
126 #ifdef __cplusplus
127 }
128 #endif // __cplusplus
129 
130 #endif
void aes_decrypt(UINT8 *state, UINT8 *key)
AES128 decryption: Given AES128 key and 16 bytes cipher text, plain text of 16 bytes is computed The ...
Definition: security.c:470
void aes_encrypt(UINT8 *state, UINT8 *key)
AES128 encryption: Given AES128 key and 16 bytes plain text, cipher text of 16 bytes is computed...
Definition: security.c:446
INT32 aes_write_key(UINT8 *key)
writes AES128 key from EEPROM Writes the AES128 key to fileID #12 in EEPROM
Definition: security.c:514
INT32 aes_read_key(UINT8 *key)
Reads AES128 key from EEPROM Reads the AES128 key from fileID #12 in EEPROM returns an error if the k...
Definition: security.c:491