Kinetis Bootloader  2.0.0
Common bootloader for Kinetis devices
qspi_memory.h
1 /*
2  * Copyright (c) 2014, 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 #if !defined(__QSPI_MEMORY_INTERFACE_H__)
31 #define __QSPI_MEMORY_INTERFACE_H__
32 
33 #include "memory/memory.h"
34 
36 // Prototypes
38 
39 #if defined(__cplusplus)
40 extern "C" {
41 #endif // __cplusplus
42 
43 enum
44 {
45  kQspiMemoryId_QuadSpiMemory = 0,
46  kQspiMemoryId_AliasArea = 1,
47 };
48 
51 
52 
54 status_t qspi_mem_init(uint32_t memoryId);
55 
57 status_t qspi_mem_read(uint32_t address, uint32_t length, uint8_t *restrict buffer);
58 
60 status_t qspi_mem_write(uint32_t memoryId, uint32_t address, uint32_t length, const uint8_t *buffer);
61 
63 status_t qspi_mem_fill(uint32_t memoryId, uint32_t address, uint32_t length, uint32_t pattern);
64 
66 status_t qspi_mem_erase(uint32_t memoryId, uint32_t address, uint32_t length);
67 
70 
72 status_t qspi_mem_flush(void);
73 
75 
76 #if defined(__cplusplus)
77 }
78 #endif // __cplusplus
79 
80 #endif // __QSPI_MEMORY_INTERFACE_H__
81 // EOF
status_t qspi_mem_erase_all(void)
Erase all QSPI memory.
Definition: qspi_memory.c:491
int32_t status_t
Type used for all status and error return values.
Definition: fsl_common.h:121