flash.h 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. /*************************************************************************************
  2. * Copyright (C) 2016, Huada Semiconductor Co.,Ltd All rights reserved.
  3. *
  4. * This software is owned and published by:
  5. * Huada Semiconductor Co.,Ltd ("HDSC").
  6. *
  7. * BY DOWNLOADING, INSTALLING OR USING THIS SOFTWARE, YOU AGREE TO BE BOUND
  8. * BY ALL THE TERMS AND CONDITIONS OF THIS AGREEMENT.
  9. *
  10. * This software contains source code for use with HDSC
  11. * components. This software is licensed by HDSC to be adapted only
  12. * for use in systems utilizing HDSC components. HDSC shall not be
  13. * responsible for misuse or illegal use of this software for devices not
  14. * supported herein. HDSC is providing this software "AS IS" and will
  15. * not be responsible for issues arising from incorrect user implementation
  16. * of the software.
  17. *
  18. * Disclaimer:
  19. * HDSC MAKES NO WARRANTY, EXPRESS OR IMPLIED, ARISING BY LAW OR OTHERWISE,
  20. * REGARDING THE SOFTWARE (INCLUDING ANY ACOOMPANYING WRITTEN MATERIALS),
  21. * ITS PERFORMANCE OR SUITABILITY FOR YOUR INTENDED USE, INCLUDING,
  22. * WITHOUT LIMITATION, THE IMPLIED WARRANTY OF MERCHANTABILITY, THE IMPLIED
  23. * WARRANTY OF FITNESS FOR A PARTICULAR PURPOSE OR USE, AND THE IMPLIED
  24. * WARRANTY OF NONINFRINGEMENT.
  25. * HDSC SHALL HAVE NO LIABILITY (WHETHER IN CONTRACT, WARRANTY, TORT,
  26. * NEGLIGENCE OR OTHERWISE) FOR ANY DAMAGES WHATSOEVER (INCLUDING, WITHOUT
  27. * LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS INTERRUPTION,
  28. * LOSS OF BUSINESS INFORMATION, OR OTHER PECUNIARY LOSS) ARISING FROM USE OR
  29. * INABILITY TO USE THE SOFTWARE, INCLUDING, WITHOUT LIMITATION, ANY DIRECT,
  30. * INDIRECT, INCIDENTAL, SPECIAL OR CONSEQUENTIAL DAMAGES OR LOSS OF DATA,
  31. * SAVINGS OR PROFITS,
  32. * EVEN IF Disclaimer HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
  33. * YOU ASSUME ALL RESPONSIBILITIES FOR SELECTION OF THE SOFTWARE TO ACHIEVE YOUR
  34. * INTENDED RESULTS, AND FOR THE INSTALLATION OF, USE OF, AND RESULTS OBTAINED
  35. * FROM, THE SOFTWARE.
  36. *
  37. * This software may be replicated in part or whole for the licensed use,
  38. * with the restriction that this Disclaimer and Copyright notice must be
  39. * included with each copy of this software, whether used in part or whole,
  40. * at all times.
  41. */
  42. /******************************************************************************/
  43. /** \file flash.h
  44. **
  45. ** FLASH 数据结构及API声明.
  46. **
  47. ** - 2017-05-02 LuX V1.0
  48. **
  49. ******************************************************************************/
  50. #ifndef __FLASH_H__
  51. #define __FLASH_H__
  52. /******************************************************************************/
  53. /* Include files */
  54. /******************************************************************************/
  55. #include "ddl.h"
  56. /* C binding of definitions if building with C++ compiler */
  57. #ifdef __cplusplus
  58. extern "C"
  59. {
  60. #endif
  61. /**
  62. ******************************************************************************
  63. ** \defgroup FlashGroup Flash Controller (Flash)
  64. **
  65. **
  66. ******************************************************************************/
  67. //@{
  68. /******************************************************************************
  69. * Global type definitions
  70. ******************************************************************************/
  71. /**
  72. ******************************************************************************
  73. ** \brief Flash中断类型重定义
  74. *****************************************************************************/
  75. typedef enum en_flash_int_type
  76. {
  77. FlashPCInt = 1u, ///<擦写PC地址报警中断
  78. FlashSlockInt = 0u, ///<擦写保护报警中断
  79. } en_flash_int_type_t;
  80. /**
  81. ******************************************************************************
  82. ** \brief Flash读等待周期类型重定义
  83. *****************************************************************************/
  84. typedef enum en_flash_waitcycle
  85. {
  86. FlashWaitCycle0 = 0u, ///< 读等待周期设置为0(当HCLK小于等于24MHz时)
  87. FlashWaitCycle1 = 1u, ///< 读等待周期设置为1(当HCLK大于24MHz时必须至少为1)
  88. FlashWaitCycle2 = 2u, ///< 读等待周期设置为2(当HCK大于48MHz时必须至少为2)
  89. } en_flash_waitcycle_t;
  90. /**
  91. ******************************************************************************
  92. ** \brief Flash擦写保护范围重定义
  93. *****************************************************************************/
  94. typedef enum en_flash_sector_lock
  95. {
  96. FlashSector0_3 = 0x00000001u, ///<Sector0_3
  97. FlashSector4_7 = 0x00000002u, ///<Sector4_7
  98. FlashSector8_11 = 0x00000004u, ///<Sector8_11
  99. FlashSector12_15 = 0x00000008u, ///<Sector12_15
  100. FlashSector16_19 = 0x00000010u, ///<Sector16_19
  101. FlashSector20_23 = 0x00000020u, ///<Sector20_23
  102. FlashSector24_27 = 0x00000040u, ///<Sector24_27
  103. FlashSector28_31 = 0x00000080u, ///<Sector28_31
  104. FlashSector32_35 = 0x00000100u, ///<Sector32_35
  105. FlashSector36_39 = 0x00000200u, ///<Sector36_39
  106. FlashSector40_43 = 0x00000400u, ///<Sector40_43
  107. FlashSector44_47 = 0x00000800u, ///<Sector44_47
  108. FlashSector48_51 = 0x00001000u, ///<Sector48_51
  109. FlashSector52_55 = 0x00002000u, ///<Sector52_55
  110. FlashSector56_59 = 0x00004000u, ///<Sector56_59
  111. FlashSector60_63 = 0x00008000u, ///<Sector60_63
  112. FlashSector64_67 = 0x00010000u, ///<Sector64_67
  113. FlashSector68_71 = 0x00020000u, ///<Sector68_71
  114. FlashSector72_75 = 0x00040000u, ///<Sector72_75
  115. FlashSector76_79 = 0x00080000u, ///<Sector76_79
  116. FlashSector80_83 = 0x00100000u, ///<Sector80_83
  117. FlashSector84_87 = 0x00200000u, ///<Sector84_87
  118. FlashSector88_91 = 0x00400000u, ///<Sector88_91
  119. FlashSector92_95 = 0x00800000u, ///<Sector92_95
  120. FlashSector96_99 = 0x01000000u, ///<Sector96_99
  121. FlashSector100_103 = 0x02000000u, ///<Sector100_103
  122. FlashSector104_107 = 0x04000000u, ///<Sector104_107
  123. FlashSector108_111 = 0x08000000u, ///<Sector108_111
  124. FlashSector112_115 = 0x10000000u, ///<Sector112_115
  125. FlashSector116_119 = 0x20000000u, ///<Sector116_119
  126. FlashSector120_123 = 0x40000000u, ///<Sector120_123
  127. FlashSector124_127 = (int)0x80000000u, ///<Sector124_127
  128. FlashSectorAll = (int)0xFFFFFFFFu, ///<SectorAll
  129. } en_flash_sector_lock_t;
  130. /**
  131. ******************************************************************************
  132. ** \brief Redefinition of FLASH register structure
  133. ******************************************************************************/
  134. /******************************************************************************
  135. * Global definitions
  136. ******************************************************************************/
  137. /******************************************************************************
  138. * Local type definitions ('typedef')
  139. ******************************************************************************/
  140. /******************************************************************************
  141. * Global variable definitions ('extern')
  142. ******************************************************************************/
  143. /******************************************************************************
  144. * Global function prototypes (definition in C source)
  145. ******************************************************************************/
  146. ///<Flash 初始化配置(中断函数、编程时间参数及休眠模式配置)
  147. en_result_t Flash_Init(func_ptr_t pfnFlashCb, uint8_t u8FreqCfg, boolean_t bDpstbEn);
  148. ///<Flash 页/全片擦除
  149. en_result_t Flash_SectorErase(uint32_t u32SectorAddr);
  150. en_result_t Flash_ChipErase(void);
  151. ///<Flash 字节/半字/字写
  152. en_result_t Flash_WriteByte(uint32_t u32Addr, uint8_t u8Data);
  153. en_result_t Flash_WriteHalfWord(uint32_t u32Addr, uint16_t u16Data);
  154. en_result_t Flash_WriteWord(uint32_t u32Addr, uint32_t u32Data);
  155. ///<Flash 编程保护加锁/解锁
  156. en_result_t Flash_Lock(en_flash_sector_lock_t enFlashSector);
  157. en_result_t Flash_Unlock(en_flash_sector_lock_t enFlashSector);
  158. ///<Flash 读等待周期设定
  159. en_result_t Flash_WaitCycle(en_flash_waitcycle_t enWaitCycle);
  160. ///<中断相关函数
  161. ///<中断使能/禁止
  162. en_result_t Flash_EnableIrq(en_flash_int_type_t enFlashIntType);
  163. en_result_t Flash_DisableIrq(en_flash_int_type_t enFlashIntType);
  164. ///<中断标志获取
  165. boolean_t Flash_GetIntFlag(en_flash_int_type_t enFlashIntType);
  166. ///<中断标志清除
  167. en_result_t Flash_ClearIntFlag(en_flash_int_type_t enFlashIntType);
  168. //@} // FlashGroup
  169. #ifdef __cplusplus
  170. }
  171. #endif
  172. #endif /* __FLASH_H__ */
  173. /******************************************************************************/
  174. /* EOF (not truncated) */
  175. /******************************************************************************/