CC3000  1.12
 All Classes Functions Groups
nvmem.h
1 /*****************************************************************************
2 *
3 * nvmem.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 __NVRAM_H__
36 #define __NVRAM_H__
37 
38 #include "cc3000_common.h"
39 
40 
41 //*****************************************************************************
42 //
43 // If building with a C++ compiler, make all of the definitions in this header
44 // have a C binding.
45 //
46 //*****************************************************************************
47 #ifdef __cplusplus
48 extern "C" {
49 #endif
50 
51 
52 //*****************************************************************************
53 //
56 //
57 //*****************************************************************************
58 
59 /****************************************************************************
60 **
61 ** Definitions for File IDs
62 **
63 ****************************************************************************/
64 /* NVMEM file ID - system files*/
65 #define NVMEM_NVS_FILEID (0)
66 #define NVMEM_NVS_SHADOW_FILEID (1)
67 #define NVMEM_WLAN_CONFIG_FILEID (2)
68 #define NVMEM_WLAN_CONFIG_SHADOW_FILEID (3)
69 #define NVMEM_WLAN_DRIVER_SP_FILEID (4)
70 #define NVMEM_WLAN_FW_SP_FILEID (5)
71 #define NVMEM_MAC_FILEID (6)
72 #define NVMEM_FRONTEND_VARS_FILEID (7)
73 #define NVMEM_IP_CONFIG_FILEID (8)
74 #define NVMEM_IP_CONFIG_SHADOW_FILEID (9)
75 #define NVMEM_BOOTLOADER_SP_FILEID (10)
76 #define NVMEM_RM_FILEID (11)
77 
78 /* NVMEM file ID - user files*/
79 #define NVMEM_AES128_KEY_FILEID (12)
80 #define NVMEM_SHARED_MEM_FILEID (13)
81 
82 /* max entry in order to invalid nvmem */
83 #define NVMEM_MAX_ENTRY (16)
84 
85 
86 //*****************************************************************************
87 //
108 //*****************************************************************************
109 
110 extern INT32 nvmem_read(UINT32 file_id, UINT32 length, UINT32 offset, UINT8 *buff);
111 
112 //*****************************************************************************
113 //
132 //*****************************************************************************
133 
134 extern INT32 nvmem_write(UINT32 ulFileId, UINT32 ulLength, UINT32 ulEntryOffset, UINT8 *buff);
135 
136 
137 //*****************************************************************************
138 //
148 //*****************************************************************************
149 extern UINT8 nvmem_set_mac_address(UINT8 *mac);
150 
151 
152 //*****************************************************************************
153 //
163 //*****************************************************************************
164 extern UINT8 nvmem_get_mac_address(UINT8 *mac);
165 
166 
167 //*****************************************************************************
168 //
183 //*****************************************************************************
184 extern UINT8 nvmem_write_patch(UINT32 ulFileId, UINT32 spLength, const UINT8 *spData);
185 
186 
187 //*****************************************************************************
188 //
199 //*****************************************************************************
200 #ifndef CC3000_TINY_DRIVER
201 extern UINT8 nvmem_read_sp_version(UINT8* patchVer);
202 #endif
203 
204 //*****************************************************************************
205 //
225 //*****************************************************************************
226 extern INT32 nvmem_create_entry(UINT32 file_id, UINT32 newlen);
227 
228 
229 //*****************************************************************************
230 //
231 // Mark the end of the C bindings section for C++ compilers.
232 //
233 //*****************************************************************************
234 
235 
236 //*****************************************************************************
237 //
238 // Close the Doxygen group.
240 //
241 //*****************************************************************************
242 
243 
244 #ifdef __cplusplus
245 }
246 #endif // __cplusplus
247 
248 #endif // __NVRAM_H__
INT32 nvmem_write(UINT32 ulFileId, UINT32 ulLength, UINT32 ulEntryOffset, UINT8 *buff)
Write data to nvmem. writes data to file referred by the ulFileId parameter. Writes data to file ulOf...
Definition: nvmem.c:135
UINT8 nvmem_set_mac_address(UINT8 *mac)
Write MAC address to EEPROM. mac address as appears over the air (OUI first)
Definition: nvmem.c:178
UINT8 nvmem_write_patch(UINT32 ulFileId, UINT32 spLength, const UINT8 *spData)
program a patch to a specific file ID. The SP data is assumed to be organized in 2-dimensional. Each line is SP_PORTION_SIZE bytes long. Actual programming is applied in SP_PORTION_SIZE bytes portions.
Definition: nvmem.c:219
UINT8 nvmem_read_sp_version(UINT8 *patchVer)
Read patch version. read package version (WiFi FW patch, driver-supplicant-NS patch, bootloader patch)
Definition: nvmem.c:263
INT32 nvmem_create_entry(UINT32 ulFileId, UINT32 ulNewLen)
Create new file entry and allocate space on the NVMEM. Applies only to user files. Modify the size of file. If the entry is unallocated - allocate it to size ulNewLen (marked invalid). If it is allocated then deallocate it first. To just mark the file as invalid without resizing - set ulNewLen=0.
Definition: nvmem.c:307
UINT8 nvmem_get_mac_address(UINT8 *mac)
Read MAC address from EEPROM. mac address as appears over the air (OUI first)
Definition: nvmem.c:196
INT32 nvmem_read(UINT32 ulFileId, UINT32 ulLength, UINT32 ulOffset, UINT8 *buff)
Reads data from the file referred by the ulFileId parameter. Reads data from file ulOffset till lengt...
Definition: nvmem.c:84