Files
EPD-nRF5/components/libraries/fstorage/fstorage_internal_defs.h
2024-12-19 15:08:21 +08:00

167 lines
5.7 KiB
C

/**
* Copyright (c) 2015 - 2017, Nordic Semiconductor ASA
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form, except as embedded into a Nordic
* Semiconductor ASA integrated circuit in a product or a software update for
* such product, must reproduce the above copyright notice, this list of
* conditions and the following disclaimer in the documentation and/or other
* materials provided with the distribution.
*
* 3. Neither the name of Nordic Semiconductor ASA nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* 4. This software, with or without modification, must only be used with a
* Nordic Semiconductor ASA integrated circuit.
*
* 5. Any software provided in binary form under this license must not be reverse
* engineered, decompiled, modified and/or disassembled.
*
* THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*/
#ifndef FSTORAGE_INTERNAL_DEFS_H__
#define FSTORAGE_INTERNAL_DEFS_H__
#include "nrf.h"
#ifdef __cplusplus
extern "C" {
#endif
#define FS_FLAG_INITIALIZED (1 << 0) // The module has been initialized.
#define FS_FLAG_PROCESSING (1 << 1) // The module is processing flash operations.
// The module is waiting for a flash operation initiated by another module to complete.
#define FS_FLAG_FLASH_REQ_PENDING (1 << 2)
#define FS_ERASED_WORD (0xFFFFFFFF)
// Helper macros for section variables.
#define FS_SECTION_VARS_GET(i) NRF_SECTION_VARS_GET((i), fs_config_t, fs_data)
#define FS_SECTION_VARS_COUNT NRF_SECTION_VARS_COUNT(fs_config_t, fs_data)
#define FS_SECTION_VARS_START_ADDR NRF_SECTION_VARS_START_ADDR(fs_data)
#define FS_SECTION_VARS_END_ADDR NRF_SECTION_VARS_END_ADDR(fs_data)
// Create section 'fs_data'.
NRF_SECTION_VARS_CREATE_SECTION(fs_data, fs_config_t);
// fstorage op-codes.
typedef enum
{
FS_OP_NONE, // No operation.
FS_OP_STORE, // Store data.
FS_OP_ERASE // Erase one or more flash pages.
} fs_op_code_t;
#if defined(__CC_ARM)
#pragma push
#pragma anon_unions
#elif defined(__ICCARM__)
#pragma language=extended
#elif defined(__GNUC__)
// anonymous unions are enabled by default.
#endif
// fstorage operation.
// Encapsulates details of a flash operation to be executed by this module.
typedef struct
{
fs_config_t const * p_config; // Application-specific fstorage configuration.
void * p_context; // User-defined context passed to the interrupt handler.
fs_op_code_t op_code; // ID of the operation.
union
{
struct
{
uint32_t const * p_src; // Pointer to the data to be written to flash.
uint32_t const * p_dest; // Destination of the data in flash.
uint16_t length_words; // Length of the data to be written, in words.
uint16_t offset; // Write offset.
} store;
struct
{
uint16_t page;
uint16_t pages_erased;
uint16_t pages_to_erase;
} erase;
};
} fs_op_t;
#if defined(__CC_ARM)
#pragma pop
#elif defined(__ICCARM__)
// leave anonymous unions enabled.
#elif defined(__GNUC__)
// anonymous unions are enabled by default.
#endif
// Queue of requested operations.
// This queue holds flash operations requested to the module.
// The data to be written to flash must be kept in memory until the write operation
// is completed, i.e., an event indicating completion is received.
typedef struct
{
fs_op_t op[FS_QUEUE_SIZE]; // Queue elements.
uint32_t rp; // Index of the operation being processed.
uint32_t count; // Number of elements in the queue.
} fs_op_queue_t;
// Size of a flash page in bytes.
#if defined (NRF51)
#define FS_PAGE_SIZE (1024)
#elif (defined (NRF52) || defined(NRF52840_XXAA))
#define FS_PAGE_SIZE (4096)
#endif
// Size of a flash page in words.
#define FS_PAGE_SIZE_WORDS (FS_PAGE_SIZE / sizeof(uint32_t))
// Function to obtain the end of the flash space available to fstorage.
static uint32_t const * fs_flash_page_end_addr()
{
uint32_t const bootloader_addr = NRF_UICR->NRFFW[0];
return (uint32_t*)((bootloader_addr != FS_ERASED_WORD) ? bootloader_addr :
NRF_FICR->CODESIZE * FS_PAGE_SIZE);
}
// Macro to obtain the address of the last page.
// If there is a bootloader present the bootloader address read from UICR
// will act as the page beyond the end of the available flash storage.
#define FS_PAGE_END_ADDR (fs_flash_page_end_addr())
#ifdef __cplusplus
}
#endif
#endif //__FSTORAGE_INTERNAL_DEFS_H