Kinetis Bootloader  2.0.0
Common bootloader for Kinetis devices
apps/flash_driver_api/src/fsl_flash.h
1 /*
2  * Copyright (c) 2013-2016, Freescale Semiconductor, Inc.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without modification,
6  * are permitted provided that the following conditions are met:
7  *
8  * o Redistributions of source code must retain the above copyright notice, this list
9  * of conditions and the following disclaimer.
10  *
11  * o Redistributions in binary form must reproduce the above copyright notice, this
12  * list of conditions and the following disclaimer in the documentation and/or
13  * other materials provided with the distribution.
14  *
15  * o Neither the name of Freescale Semiconductor, Inc. nor the names of its
16  * contributors may be used to endorse or promote products derived from this
17  * software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
20  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
23  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
26  * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29  */
30 
31 #ifndef _FSL_FLASH_H_
32 #define _FSL_FLASH_H_
33 
34 #include <stdint.h>
35 
36 /*******************************************************************************
37  * Definitions
38  ******************************************************************************/
39 
50 #if !defined(MAKE_VERSION)
51 #define MAKE_VERSION(major, minor, bugfix) (((major) << 16) | ((minor) << 8) | (bugfix))
52 #endif
53 
55 #define FSL_FLASH_DRIVER_VERSION (MAKE_VERSION(2, 1, 0))
58 enum _flash_driver_version_constants
59 {
64 };
72 #if defined(kStatusGroup_FLASH)
73 #define kStatusGroupGeneric kStatusGroup_Generic
74 #define kStatusGroupFlashDriver kStatusGroup_FLASH
75 #define IS_GENERIC_STAUS_CODE_DEFINED 1
76 #else
77 #define kStatusGroupGeneric 0
78 #define kStatusGroupFlashDriver 1
79 #define IS_GENERIC_STAUS_CODE_DEFINED 0
80 #endif
81 
83 #if !defined(MAKE_STATUS)
84 #define MAKE_STATUS(group, code) ((((group)*100) + (code)))
85 #endif
86 
88 typedef int32_t status_t;
89 
90 #if !(IS_GENERIC_STAUS_CODE_DEFINED)
91 enum _generic_status
93 {
94  kStatus_Success = MAKE_STATUS(kStatusGroupGeneric, 0),
95  kStatus_Fail = MAKE_STATUS(kStatusGroupGeneric, 1),
96  kStatus_ReadOnly = MAKE_STATUS(kStatusGroupGeneric, 2),
97  kStatus_OutOfRange = MAKE_STATUS(kStatusGroupGeneric, 3),
98  kStatus_InvalidArgument = MAKE_STATUS(kStatusGroupGeneric, 4)
99 };
100 #endif
101 
106 {
107  kStatus_FLASH_Success = MAKE_STATUS(kStatusGroupGeneric, 0),
108  kStatus_FLASH_InvalidArgument = MAKE_STATUS(kStatusGroupGeneric, 4),
109  kStatus_FLASH_SizeError = MAKE_STATUS(kStatusGroupFlashDriver, 0),
111  MAKE_STATUS(kStatusGroupFlashDriver, 1),
112  kStatus_FLASH_AddressError = MAKE_STATUS(kStatusGroupFlashDriver, 2),
114  MAKE_STATUS(kStatusGroupFlashDriver, 3),
116  kStatusGroupFlashDriver, 4),
118  MAKE_STATUS(kStatusGroupFlashDriver, 5),
119  kStatus_FLASH_UnknownProperty = MAKE_STATUS(kStatusGroupFlashDriver, 6),
120  kStatus_FLASH_EraseKeyError = MAKE_STATUS(kStatusGroupFlashDriver, 7),
121  kStatus_FLASH_RegionExecuteOnly = MAKE_STATUS(kStatusGroupFlashDriver, 8),
123  MAKE_STATUS(kStatusGroupFlashDriver, 9),
125  MAKE_STATUS(kStatusGroupFlashDriver, 10),
127  MAKE_STATUS(kStatusGroupFlashDriver, 11),
129  MAKE_STATUS(kStatusGroupFlashDriver, 12),
130  kStatus_FLASH_SetFlexramAsRamError = MAKE_STATUS(kStatusGroupFlashDriver, 13),
132  MAKE_STATUS(kStatusGroupFlashDriver, 14),
133  kStatus_FLASH_CommandNotSupported = MAKE_STATUS(kStatusGroupFlashDriver, 15),
135  MAKE_STATUS(kStatusGroupFlashDriver, 16),
137  MAKE_STATUS(kStatusGroupFlashDriver, 17),
138 };
146 #if !defined(FOUR_CHAR_CODE)
147 #define FOUR_CHAR_CODE(a, b, c, d) (((d) << 24) | ((c) << 16) | ((b) << 8) | ((a)))
148 #endif
149 
158 {
159  kFLASH_ApiEraseKey = FOUR_CHAR_CODE('k', 'f', 'e', 'k')
160 };
166 typedef enum _flash_margin_value
167 {
173 
177 typedef enum _flash_security_state
178 {
183 
187 typedef enum _flash_protection_state
188 {
193 
197 typedef enum _flash_execute_only_access_state
198 {
203 
207 typedef enum _flash_property_tag
208 {
228 
233 {
236 };
237 
241 typedef struct _flash_execute_in_ram_function_config
242 {
243  uint32_t activeFunctionCount;
244  uint8_t *flashRunCommand;
245  uint8_t *flashCacheClearCommand;
247 
251 typedef enum _flash_read_resource_option
252 {
254  0x00U,
257 
259 typedef void (*flash_callback_t)(void);
260 
266 typedef struct _flash_config
267 {
268  uint32_t PFlashBlockBase;
269  uint32_t PFlashTotalSize;
270  uint32_t PFlashBlockCount;
271  uint32_t PFlashSectorSize;
272  flash_callback_t PFlashCallback;
273  uint32_t PFlashAccessSegmentSize;
274  uint32_t PFlashAccessSegmentCount;
275  uint32_t *flashExecuteInRamFunctionInfo;
276  uint32_t FlexRAMBlockBase;
278  uint32_t FlexRAMTotalSize;
280  uint32_t DFlashBlockBase;
282  uint32_t DFlashTotalSize;
284  uint32_t EEpromTotalSize;
288 
289 /*******************************************************************************
290  * API
291  ******************************************************************************/
292 
293 #if defined(__cplusplus)
294 extern "C" {
295 #endif
296 
315 
326 
336 
359 status_t FLASH_EraseAll(flash_config_t *config, uint32_t key);
360 
384 status_t FLASH_Erase(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, uint32_t key);
385 
401 status_t FLASH_EraseAllUnsecure(flash_config_t *config, uint32_t key);
417 
448 status_t FLASH_Program(flash_config_t *config, uint32_t start, uint32_t *src, uint32_t lengthInBytes);
449 
470 status_t FLASH_ProgramOnce(flash_config_t *config, uint32_t index, uint32_t *src, uint32_t lengthInBytes);
495  flash_config_t *config, uint32_t start, uint32_t *dst, uint32_t lengthInBytes, flash_read_resource_option_t option);
496 
516 status_t FLASH_ReadOnce(flash_config_t *config, uint32_t index, uint32_t *dst, uint32_t lengthInBytes);
517 
538 
556 status_t FLASH_SecurityBypass(flash_config_t *config, const uint8_t *backdoorKey);
557 
582 
606 status_t FLASH_VerifyErase(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, flash_margin_value_t margin);
607 
637  uint32_t start,
638  uint32_t lengthInBytes,
639  const uint32_t *expectedData,
640  flash_margin_value_t margin,
641  uint32_t *failedAddress,
642  uint32_t *failedData);
643 
659 
686  uint32_t start,
687  uint32_t lengthInBytes,
688  flash_execute_only_access_state_t *access_state);
689 
709 status_t FLASH_GetProperty(flash_config_t *config, flash_property_tag_t whichProperty, uint32_t *value);
710 
713 #if defined(__cplusplus)
714 }
715 #endif
716 
719 #endif /* _FSL_FLASH_H_ */
Definition: apps/flash_driver_api/src/fsl_flash.h:191
Definition: apps/flash_driver_api/src/fsl_flash.h:181
Definition: apps/flash_driver_api/src/fsl_flash.h:215
Definition: apps/flash_driver_api/src/fsl_flash.h:126
Definition: apps/flash_driver_api/src/fsl_flash.h:235
status_t FLASH_ReadOnce(flash_config_t *config, uint32_t index, uint32_t *dst, uint32_t lengthInBytes)
Read Program Once Field through parameters.
Definition: fsl_flash_api_tree.c:294
Definition: apps/flash_driver_api/src/fsl_flash.h:133
Definition: apps/flash_driver_api/src/fsl_flash.h:128
status_t FLASH_EraseAll(flash_config_t *config, uint32_t key)
Erases entire flash.
Definition: fsl_flash_api_tree.c:152
Definition: apps/flash_driver_api/src/fsl_flash.h:159
int32_t status_t
Type used for all status and error return values.
Definition: apps/flash_driver_api/src/fsl_flash.h:88
status_t FLASH_VerifyEraseAll(flash_config_t *config, flash_margin_value_t margin)
Verifies erasure of entire flash at specified margin level.
Definition: fsl_flash_api_tree.c:218
Definition: apps/flash_driver_api/src/fsl_flash.h:210
status_t FLASH_IsExecuteOnly(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, flash_execute_only_access_state_t *access_state)
Returns the access state of desired flash area via the pointer passed into the function.
Definition: fsl_flash.c:1505
Definition: apps/flash_driver_api/src/fsl_flash.h:234
Definition: apps/flash_driver_api/src/fsl_flash.h:121
Definition: apps/flash_driver_api/src/fsl_flash.h:169
status_t FLASH_Init(flash_config_t *config)
Initializes global flash properties structure members.
Definition: fsl_flash_api_tree.c:142
Definition: apps/flash_driver_api/src/fsl_flash.h:60
flash_read_resource_option_t
Enumeration for the two possible options of flash read resource command.
Definition: apps/flash_driver_api/src/fsl_flash.h:251
flash_margin_value_t
Enumeration for supported flash margin levels.
Definition: apps/flash_driver_api/src/fsl_flash.h:166
flash_read_resource_option_t
Enumeration for the two possible options of flash read resource command.
Definition: src/drivers/flash/fsl_flash.h:273
Definition: apps/flash_driver_api/src/fsl_flash.h:131
Definition: apps/flash_driver_api/src/fsl_flash.h:117
Definition: apps/flash_driver_api/src/fsl_flash.h:136
_flash_execute_in_ram_function_constants
Constants for execute-in-ram flash function.
Definition: src/drivers/flash/fsl_flash.h:254
Definition: apps/flash_driver_api/src/fsl_flash.h:223
status_t FLASH_Erase(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, uint32_t key)
Erases flash sectors encompassed by parameters passed into function.
Definition: fsl_flash_api_tree.c:167
Flash execute-in-ram function information.
Definition: src/drivers/flash/fsl_flash.h:263
Definition: apps/flash_driver_api/src/fsl_flash.h:209
status_t FLASH_EraseAllExecuteOnlySegments(flash_config_t *config, uint32_t key)
Erases all program flash execute-only segments defined by the FXACC registers.
Definition: fsl_flash.c:713
Definition: apps/flash_driver_api/src/fsl_flash.h:211
Definition: apps/flash_driver_api/src/fsl_flash.h:171
status_t FLASH_GetSecurityState(flash_config_t *config, flash_security_state_t *state)
Returns the security state via the pointer passed into the function.
Definition: fsl_flash_api_tree.c:204
Definition: apps/flash_driver_api/src/fsl_flash.h:219
status_t FLASH_VerifyErase(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, flash_margin_value_t margin)
Verifies erasure of desired flash area at specified margin level.
Definition: fsl_flash_api_tree.c:225
Definition: apps/flash_driver_api/src/fsl_flash.h:216
Definition: apps/flash_driver_api/src/fsl_flash.h:200
status_t FLASH_ReadResource(flash_config_t *config, uint32_t start, uint32_t *dst, uint32_t lengthInBytes, flash_read_resource_option_t option)
Read resource with data at locations passed in through parameters.
Definition: fsl_flash_api_tree.c:280
_generic_status
Generic status return codes.
Definition: fsl_common.h:109
Definition: apps/flash_driver_api/src/fsl_flash.h:109
status_t FLASH_SecurityBypass(flash_config_t *config, const uint8_t *backdoorKey)
Allows user to bypass security with a backdoor key.
Definition: fsl_flash_api_tree.c:211
Definition: apps/flash_driver_api/src/fsl_flash.h:119
_flash_status
Flash driver status codes.
Definition: src/drivers/flash/fsl_flash.h:129
Definition: apps/flash_driver_api/src/fsl_flash.h:222
Definition: apps/flash_driver_api/src/fsl_flash.h:217
status_t FLASH_GetProperty(flash_config_t *config, flash_property_tag_t whichProperty, uint32_t *value)
Returns the desired flash property.
Definition: fsl_flash_api_tree.c:246
Definition: apps/flash_driver_api/src/fsl_flash.h:213
status_t FLASH_PrepareExecuteInRamFunctions(flash_config_t *config)
Prepare flash execute-in-ram functions.
Definition: fsl_flash.c:549
status_t FLASH_Program(flash_config_t *config, uint32_t start, uint32_t *src, uint32_t lengthInBytes)
Programs flash with data at locations passed in through parameters.
Definition: fsl_flash_api_tree.c:197
Definition: apps/flash_driver_api/src/fsl_flash.h:214
flash_protection_state_t
Enumeration for the three possible flash protection levels.
Definition: apps/flash_driver_api/src/fsl_flash.h:187
Definition: apps/flash_driver_api/src/fsl_flash.h:253
Definition: apps/flash_driver_api/src/fsl_flash.h:108
flash_property_tag_t
Enumeration for various flash properties.
Definition: apps/flash_driver_api/src/fsl_flash.h:207
flash_execute_only_access_state_t
Enumeration for the three possible flash execute access levels.
Definition: apps/flash_driver_api/src/fsl_flash.h:197
Definition: apps/flash_driver_api/src/fsl_flash.h:218
flash_property_tag_t
Enumeration for various flash properties.
Definition: src/drivers/flash/fsl_flash.h:231
Definition: apps/flash_driver_api/src/fsl_flash.h:130
void(* flash_callback_t)(void)
callback type used for pflash block
Definition: apps/flash_driver_api/src/fsl_flash.h:259
status_t FLASH_VerifyProgram(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, const uint32_t *expectedData, flash_margin_value_t margin, uint32_t *failedAddress, uint32_t *failedData)
Verifies programming of desired flash area at specified margin level.
Definition: fsl_flash_api_tree.c:232
Definition: apps/flash_driver_api/src/fsl_flash.h:189
Definition: apps/flash_driver_api/src/fsl_flash.h:180
status_t FLASH_ProgramOnce(flash_config_t *config, uint32_t index, uint32_t *src, uint32_t lengthInBytes)
Programs Program Once Field through parameters.
Definition: fsl_flash_api_tree.c:267
flash_security_state_t
Enumeration for the three possible flash security states.
Definition: src/drivers/flash/fsl_flash.h:201
Definition: apps/flash_driver_api/src/fsl_flash.h:255
Definition: apps/flash_driver_api/src/fsl_flash.h:212
flash_margin_value_t
Enumeration for supported flash margin levels.
Definition: src/drivers/flash/fsl_flash.h:190
Definition: apps/flash_driver_api/src/fsl_flash.h:124
Definition: apps/flash_driver_api/src/fsl_flash.h:107
_flash_driver_api_keys
Enumeration for flash driver API keys.
Definition: src/drivers/flash/fsl_flash.h:181
Flash driver state information.
Definition: src/drivers/flash/fsl_flash.h:443
Definition: apps/flash_driver_api/src/fsl_flash.h:226
Definition: apps/flash_driver_api/src/fsl_flash.h:199
Definition: apps/flash_driver_api/src/fsl_flash.h:115
status_t FLASH_EraseAllUnsecure(flash_config_t *config, uint32_t key)
Erases entire flash, including protected sectors.
Definition: fsl_flash_api_tree.c:182
Definition: apps/flash_driver_api/src/fsl_flash.h:112
Definition: apps/flash_driver_api/src/fsl_flash.h:110
flash_execute_only_access_state_t
Enumeration for the three possible flash execute access levels.
Definition: src/drivers/flash/fsl_flash.h:221
Definition: apps/flash_driver_api/src/fsl_flash.h:179
Definition: apps/flash_driver_api/src/fsl_flash.h:134
Definition: apps/flash_driver_api/src/fsl_flash.h:224
Definition: apps/flash_driver_api/src/fsl_flash.h:170
Definition: apps/flash_driver_api/src/fsl_flash.h:113
Definition: apps/flash_driver_api/src/fsl_flash.h:168
Definition: apps/flash_driver_api/src/fsl_flash.h:201
status_t FLASH_VerifyEraseAllExecuteOnlySegments(flash_config_t *config, flash_margin_value_t margin)
Verifies if the program flash executeonly segments have been erased to the specified read margin leve...
Definition: fsl_flash.c:1353
Definition: apps/flash_driver_api/src/fsl_flash.h:61
int32_t status_t
Type used for all status and error return values.
Definition: fsl_common.h:121
Definition: apps/flash_driver_api/src/fsl_flash.h:122
Definition: apps/flash_driver_api/src/fsl_flash.h:120
Definition: apps/flash_driver_api/src/fsl_flash.h:62
Definition: apps/flash_driver_api/src/fsl_flash.h:190
Definition: apps/flash_driver_api/src/fsl_flash.h:220
status_t FLASH_SetCallback(flash_config_t *config, flash_callback_t callback)
Set the desired flash callback function.
Definition: fsl_flash_api_tree.c:307
Definition: apps/flash_driver_api/src/fsl_flash.h:221
flash_security_state_t
Enumeration for the three possible flash security states.
Definition: apps/flash_driver_api/src/fsl_flash.h:177
Definition: apps/flash_driver_api/src/fsl_flash.h:63