/* * This file is part of the EasyFlash Library. * * Copyright (c) 2014, Armink, * * Permission is hereby granted, free of charge, to any person obtaining * a copy of this software and associated documentation files (the * 'Software'), to deal in the Software without restriction, including * without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to * permit persons to whom the Software is furnished to do so, subject to * the following conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * * Function: Is is an head file for this library. You can see all be called functions. * Created on: 2014-09-10 */ #ifndef EASYFLASH_H_ #define EASYFLASH_H_ #include #include #include #ifdef __cplusplus extern "C" { #endif /* using ENV function */ #define EF_USING_ENV /* using IAP function */ #define EF_USING_IAP /* using save log function */ /* #define EF_USING_LOG */ /* the user setting size of ENV, must be word alignment */ #define EF_USER_SETTING_ENV_SIZE (2 * 1024) /* default 2K */ /* using wear leveling mode or normal mode */ /* #define EF_ENV_USING_WL_MODE */ #define EF_ENV_USING_NORMAL_MODE /* EasyFlash debug print function. Must be implement by user. */ #define EF_DEBUG(...) ef_log_debug(__FILE__, __LINE__, __VA_ARGS__) /* EasyFlash routine print function. Must be implement by user. */ #define EF_INFO(...) ef_log_info(__VA_ARGS__) /* EasyFlash assert for developer. */ #define EF_ASSERT(EXPR) \ if (!(EXPR)) \ { \ EF_DEBUG("(%s) has assert failed at %s.\n", #EXPR, __FUNCTION__); \ while (1); \ } /* EasyFlash software version number */ #define EF_SW_VERSION "1.07.06" typedef struct _eflash_env{ char *key; char *value; }ef_env, *ef_env_t; /* EasyFlash error code */ typedef enum { EF_NO_ERR, EF_ERASE_ERR, EF_WRITE_ERR, EF_ENV_NAME_ERR, EF_ENV_NAME_EXIST, EF_ENV_FULL, } EfErrCode; /* the flash sector current status */ typedef enum { FLASH_SECTOR_EMPTY, FLASH_SECTOR_USING, FLASH_SECTOR_FULL, }FlashSecrorStatus; /* easyflash.c */ EfErrCode easyflash_init(void); #ifdef EF_USING_ENV /* env.c env_wl.c */ void ef_load_env(void); void ef_print_env(void); char *ef_get_env(const char *key); EfErrCode ef_set_env(const char *key, const char *value); EfErrCode ef_save_env(void); EfErrCode ef_env_set_default(void); size_t ef_get_env_total_size(void); size_t ef_get_env_write_bytes(void); #endif #ifdef EF_USING_IAP /* iap.c */ EfErrCode ef_erase_bak_app(size_t app_size); EfErrCode ef_erase_user_app(uint32_t user_app_addr, size_t user_app_size); EfErrCode ef_erase_bl(uint32_t bl_addr, size_t bl_size); EfErrCode ef_write_data_to_bak(uint8_t *data, size_t size, size_t *cur_size, size_t total_size); EfErrCode ef_copy_app_from_bak(uint32_t user_app_addr, size_t app_size); EfErrCode ef_copy_bl_from_bak(uint32_t bl_addr, size_t bl_size); #endif #ifdef EF_USING_LOG /* log.c */ EfErrCode ef_log_read(size_t index, uint32_t *log, size_t size); EfErrCode ef_log_write(const uint32_t *log, size_t size); EfErrCode ef_log_clean(void); size_t ef_log_get_used_size(void); #endif /* utils.c */ uint32_t ef_calc_crc32(uint32_t crc, const void *buf, size_t size); FlashSecrorStatus ef_get_sector_status(uint32_t addr, size_t sec_size); uint32_t ef_find_sec_using_end_addr(uint32_t addr, size_t sec_size); /* port.c */ EfErrCode ef_port_read(uint32_t addr, uint32_t *buf, size_t size); EfErrCode ef_port_erase(uint32_t addr, size_t size); EfErrCode ef_port_write(uint32_t addr, const uint32_t *buf, size_t size); void ef_port_env_lock(void); void ef_port_env_unlock(void); void ef_log_debug(const char *file, const long line, const char *format, ...); void ef_log_info(const char *format, ...); void ef_print(const char *format, ...); #ifdef __cplusplus } #endif #endif /* EASYFLASH_H_ */