145 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			145 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|  | /****************************************************************************
 | ||
|  | 
 | ||
|  | Copyright(c) 2024 by Aerospace C.Power (Chongqing) Microelectronics. ALL RIGHTS RESERVED. | ||
|  | 
 | ||
|  | This Information is proprietary to Aerospace C.Power (Chongqing) Microelectronics and MAY NOT | ||
|  | be copied by any method or incorporated into another program without | ||
|  | the express written consent of Aerospace C.Power. This Information or any portion | ||
|  | thereof remains the property of Aerospace C.Power. The Information contained herein | ||
|  | is believed to be accurate and Aerospace C.Power assumes no responsibility or | ||
|  | liability for its use in any way and conveys no license or title under | ||
|  | any patent or copyright and makes no representation or warranty that this | ||
|  | Information is free from patent or copyright infringement. | ||
|  | 
 | ||
|  | ****************************************************************************/ | ||
|  | #ifndef IOT_SUNSOLAR_FLASH_H
 | ||
|  | #define IOT_SUNSOLAR_FLASH_H
 | ||
|  | 
 | ||
|  | /* os shim includes */ | ||
|  | #include "os_types_api.h"
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /* custom flash total size */ | ||
|  | #define IOT_SOLR_FLASH_TOTAL_SIZE           custom_dev_query_rw_size()
 | ||
|  | 
 | ||
|  | /* custom flash start position */ | ||
|  | #define IOT_SOLR_FLASH_START_ADDR           0x00
 | ||
|  | 
 | ||
|  | /* define the size of flash erase unit: 4096 Byte */ | ||
|  | #define IOT_SOLR_FLASH_ERASE_SIZE_4K        (0x1000)
 | ||
|  | 
 | ||
|  | /*-------------------------------------------
 | ||
|  |  *  sta custom flash layout shows like below | ||
|  |  *------------------------------------------- | ||
|  |  *    |-----------------------------| | ||
|  |  *    |                             | | ||
|  |  *    |  non-volatile data region   |  16k bytes | ||
|  |  *    |                             | | ||
|  |  *    |-----------------------------| | ||
|  |  *    |                             | | ||
|  |  *    |     frozen data region      |  68k bytes | ||
|  |  *    |                             | | ||
|  |  *    |-----------------------------| | ||
|  |  *    |                             | | ||
|  |  *    |          reserve            |  36k bytes | ||
|  |  *    |                             | | ||
|  |  *    |-----------------------------| | ||
|  |  */ | ||
|  | 
 | ||
|  | #define IOT_SOLR_STA_NV_REGION_START        IOT_SOLR_FLASH_START_ADDR
 | ||
|  | #define IOT_SOLR_STA_NV_REGION_SIZE         (16 * 1024)
 | ||
|  | #define IOT_SOLR_STA_NV_REGION_END          \
 | ||
|  |     (IOT_SOLR_STA_NV_REGION_START + IOT_SOLR_STA_NV_REGION_SIZE) | ||
|  | 
 | ||
|  | #define IOT_SOLR_STA_FROZEN_REGION_START    IOT_SOLR_STA_NV_REGION_END
 | ||
|  | #define IOT_SOLR_STA_FROZEN_REGION_SIZE     (68 * 1024)
 | ||
|  | #define IOT_SOLR_STA_FROZEN_REGION_END      \
 | ||
|  |     (IOT_SOLR_STA_FROZEN_REGION_START + IOT_SOLR_STA_FROZEN_REGION_SIZE) | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief iot_sunsolar_flash_read - read data from customer flash area. | ||
|  |  * @param read_offset: read data offset. | ||
|  |  * @param read_len: length of read data. | ||
|  |  * @param p_read_buf: the pointer to read data cache. | ||
|  |  * @retval: ERR_OK - for success case. | ||
|  |  * @retval: otherwise - error code. | ||
|  |  */ | ||
|  | uint32_t iot_sunsolar_flash_read(uint32_t read_offset, uint32_t read_len, | ||
|  |     void *p_read_buf); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief iot_sunsolar_flash_write - write data into customer flash area. | ||
|  |  * @param write_offset: write data offset. | ||
|  |  * @param write_len: length of write data. | ||
|  |  * @param p_write_buf: the pointer to write data. | ||
|  |  * @retval: ERR_OK - for success case. | ||
|  |  * @retval: otherwise - error code. | ||
|  |  */ | ||
|  | uint32_t iot_sunsolar_flash_write(uint32_t write_offset, uint32_t write_len, | ||
|  |     void *p_write_buf); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief iot_sunsolar_flash_erase - erase customer flash area. | ||
|  |  * @param erase_offset: erase offset. | ||
|  |  * @param erase_len: length of erase data. | ||
|  |  * @retval: ERR_OK - for success case. | ||
|  |  * @retval: otherwise - error code. | ||
|  |  */ | ||
|  | uint32_t iot_sunsolar_flash_erase(uint32_t erase_offset, uint32_t erase_len); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief iot_sunsolar_flash_write - write data into customer flash area without | ||
|  |  *                                    erase. | ||
|  |  * @param write_offset: write data offset. | ||
|  |  * @param write_len: length of write data. | ||
|  |  * @param p_write_buf: the pointer to write data. | ||
|  |  * @retval: ERR_OK - for success case. | ||
|  |  * @retval: otherwise - error code. | ||
|  |  */ | ||
|  | uint32_t iot_sunsolar_flash_write_without_erase(uint32_t write_offset, | ||
|  |     uint32_t write_len, uint8_t *p_write_buf); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief iot_sunsolar_flash_data_erase_check - erase check for the data to be | ||
|  |  *                                              writen. | ||
|  |  * @param offset: write data offset. | ||
|  |  * @param data_len: length of write data. | ||
|  |  * @retval: ERR_OK - for success case, already erased. | ||
|  |  * @retval: otherwise - error code. | ||
|  |  */ | ||
|  | uint32_t iot_sunsolar_flash_data_erase_check(uint32_t offset, | ||
|  |     uint32_t data_len); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief iot_sunsolar_flash_data_erase_handle - check if sector is need to | ||
|  |  *                                              erase, if so, erase it | ||
|  |  * @param write_offset: write data offset. | ||
|  |  * @param write_len: length of write data. | ||
|  |  * @param p_write_buf: the pointer to write data. | ||
|  |  * @retval: ERR_OK - for success case. | ||
|  |  * @retval: otherwise - error code. | ||
|  |  */ | ||
|  | uint32_t iot_sunsolar_flash_data_erase_handle(uint32_t offset, | ||
|  |     uint32_t data_len); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief    iot_sunsolar_flash_init() - init sunsolar flash. | ||
|  |  * @return:  0    -   for success case | ||
|  |  * @return:  otherwise   -   error number | ||
|  |  */ | ||
|  | uint32_t iot_sunsolar_flash_init(void); | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief iot_sunsolar_flash_deinit() - deinit sunsolar flash. | ||
|  |  */ | ||
|  | void iot_sunsolar_flash_deinit(void); | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #endif /* IOT_SUNSOLAR_FLASH_H */
 |