board.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. /*
  2. * Copyright (c) 2006-2018, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. *
  7. * Change Logs:
  8. * Date Author Notes
  9. * 2009-09-22 Bernard add board.h to this bsp
  10. * 2017-10-20 ZYH emmm...setup for HAL Libraries
  11. */
  12. // <<< Use Configuration Wizard in Context Menu >>>
  13. #ifndef __BOARD_H__
  14. #define __BOARD_H__
  15. #include "stm32f1xx_hal.h"
  16. /* board configuration */
  17. #if \
  18. defined(STM32F101TB)||\
  19. defined(STM32F103T8)||\
  20. defined(STM32F103TB)
  21. #define STM32F10X_PIN_NUMBERS 36
  22. #elif \
  23. defined(STM32F101CB)||\
  24. defined(STM32F102CB)||\
  25. defined(STM32F103C8)||\
  26. defined(STM32F103CB)
  27. #define STM32F10X_PIN_NUMBERS 48
  28. #elif \
  29. defined(STM32F100RC)||\
  30. defined(STM32F100RD)||\
  31. defined(STM32F100RE)||\
  32. defined(STM32F101RB)||\
  33. defined(STM32F101RC)||\
  34. defined(STM32F101RD)||\
  35. defined(STM32F101RE)||\
  36. defined(STM32F101RF)||\
  37. defined(STM32F101RG)||\
  38. defined(STM32F102RB)||\
  39. defined(STM32F103R8)||\
  40. defined(STM32F103RB)||\
  41. defined(STM32F103RC)||\
  42. defined(STM32F103RD)||\
  43. defined(STM32F103RE)||\
  44. defined(STM32F103RF)||\
  45. defined(STM32F103RG)||\
  46. defined(STM32F105R8)||\
  47. defined(STM32F105RB)||\
  48. defined(STM32F105RC)||\
  49. defined(STM32F107RB)||\
  50. defined(STM32F107RC)
  51. #define STM32F10X_PIN_NUMBERS 64
  52. #elif \
  53. defined(STM32F100VC)||\
  54. defined(STM32F100VD)||\
  55. defined(STM32F100VE)||\
  56. defined(STM32F101VB)||\
  57. defined(STM32F101VC)||\
  58. defined(STM32F101VD)||\
  59. defined(STM32F101VE)||\
  60. defined(STM32F101VF)||\
  61. defined(STM32F101VG)||\
  62. defined(STM32F103V8)||\
  63. defined(STM32F103VB)||\
  64. defined(STM32F103VC)||\
  65. defined(STM32F103VD)||\
  66. defined(STM32F103VE)||\
  67. defined(STM32F103VF)||\
  68. defined(STM32F103VG)||\
  69. defined(STM32F105V8)||\
  70. defined(STM32F105VB)||\
  71. defined(STM32F105VC)||\
  72. defined(STM32F107VB)||\
  73. defined(STM32F107VC)
  74. #define STM32F10X_PIN_NUMBERS 100
  75. #elif \
  76. defined(STM32F100ZC)||\
  77. defined(STM32F100ZD)||\
  78. defined(STM32F100ZE)||\
  79. defined(STM32F101ZC)||\
  80. defined(STM32F101ZD)||\
  81. defined(STM32F101ZE)||\
  82. defined(STM32F101ZF)||\
  83. defined(STM32F101ZG)||\
  84. defined(STM32F103ZC)||\
  85. defined(STM32F103ZD)||\
  86. defined(STM32F103ZE)||\
  87. defined(STM32F103ZF)||\
  88. defined(STM32F103ZG)
  89. #define STM32F10X_PIN_NUMBERS 144
  90. #endif
  91. #if \
  92. defined(STM32F100RC)||\
  93. defined(STM32F100VC)||\
  94. defined(STM32F100ZC)
  95. #define STM32_SRAM_SIZE 24
  96. //#define STM32F100xE
  97. #elif \
  98. defined(STM32F100RD)||\
  99. defined(STM32F100RE)||\
  100. defined(STM32F100VD)||\
  101. defined(STM32F100VE)||\
  102. defined(STM32F100ZD)||\
  103. defined(STM32F100ZE)
  104. #define STM32_SRAM_SIZE 32
  105. //#define STM32F100xE
  106. #elif \
  107. defined(STM32F101TB)||\
  108. defined(STM32F101CB)||\
  109. defined(STM32F101RB)||\
  110. defined(STM32F101VB)
  111. #define STM32_SRAM_SIZE 16
  112. //#define STM32F101xB
  113. #elif \
  114. defined(STM32F101RC)||\
  115. defined(STM32F101VC)||\
  116. defined(STM32F101ZC)
  117. #define STM32_SRAM_SIZE 32
  118. //#define STM32F101xE
  119. #elif \
  120. defined(STM32F101RD)||\
  121. defined(STM32F101RE)||\
  122. defined(STM32F101VD)||\
  123. defined(STM32F101VE)||\
  124. defined(STM32F101ZD)||\
  125. defined(STM32F101ZE)
  126. #define STM32_SRAM_SIZE 48
  127. //#define STM32F101xE
  128. #elif \
  129. defined(STM32F101RF)||\
  130. defined(STM32F101RG)||\
  131. defined(STM32F101VF)||\
  132. defined(STM32F101VG)||\
  133. defined(STM32F101ZF)||\
  134. defined(STM32F101ZG)
  135. #define STM32_SRAM_SIZE 80
  136. //#define STM32F101xG
  137. #elif \
  138. defined(STM32F102CB)||\
  139. defined(STM32F102RB)
  140. #define STM32_SRAM_SIZE 16
  141. //#define STM32F102xB
  142. #elif \
  143. defined(STM32F103T8)||\
  144. defined(STM32F103TB)||\
  145. defined(STM32F103C8)||\
  146. defined(STM32F103CB)||\
  147. defined(STM32F103R8)||\
  148. defined(STM32F103RB)||\
  149. defined(STM32F103V8)||\
  150. defined(STM32F103VB)
  151. #define STM32_SRAM_SIZE 20
  152. //#define STM32F103xB
  153. #elif \
  154. defined(STM32F103RC)||\
  155. defined(STM32F103VC)||\
  156. defined(STM32F103ZC)
  157. #define STM32_SRAM_SIZE 48
  158. //#define STM32F103xE
  159. #elif \
  160. defined(STM32F103RD)||\
  161. defined(STM32F103RE)||\
  162. defined(STM32F103VD)||\
  163. defined(STM32F103VE)||\
  164. defined(STM32F103ZD)||\
  165. defined(STM32F103ZE)
  166. #define STM32_SRAM_SIZE 64
  167. //#define STM32F103xE
  168. #elif \
  169. defined(STM32F103RF)||\
  170. defined(STM32F103RG)||\
  171. defined(STM32F103VF)||\
  172. defined(STM32F103VG)||\
  173. defined(STM32F103ZF)||\
  174. defined(STM32F103ZG)
  175. #define STM32_SRAM_SIZE 96
  176. //#define STM32F103xG
  177. #elif \
  178. defined(STM32F105R8)||\
  179. defined(STM32F105RB)||\
  180. defined(STM32F105RC)||\
  181. defined(STM32F105V8)||\
  182. defined(STM32F105VB)||\
  183. defined(STM32F105VC)
  184. #define STM32_SRAM_SIZE 64
  185. //#define STM32F105xC
  186. #elif \
  187. defined(STM32F107RB)||\
  188. defined(STM32F107RC)||\
  189. defined(STM32F107VB)||\
  190. defined(STM32F107VC)
  191. #define STM32_SRAM_SIZE 64
  192. //#define STM32F107xC
  193. #endif
  194. /* whether use board external SRAM memory */
  195. // <e>Use external SRAM memory on the board
  196. // <i>Enable External SRAM memory
  197. #define STM32_EXT_SRAM 0
  198. // <o>Begin Address of External SRAM
  199. // <i>Default: 0x68000000
  200. #define STM32_EXT_SRAM_BEGIN 0x68000000 /* the begining address of external SRAM */
  201. // <o>End Address of External SRAM
  202. // <i>Default: 0x68080000
  203. #define STM32_EXT_SRAM_END 0x68080000 /* the end address of external SRAM */
  204. // </e>
  205. // <o> Internal SRAM memory size[Kbytes] <8-64>
  206. // <i>Default: 64
  207. #define STM32_SRAM_END (0x20000000 + STM32_SRAM_SIZE * 1024)
  208. #ifdef __CC_ARM
  209. extern int Image$$RW_IRAM1$$ZI$$Limit;
  210. #define HEAP_BEGIN ((void *)&Image$$RW_IRAM1$$ZI$$Limit)
  211. #elif __ICCARM__
  212. #pragma section="HEAP"
  213. #define HEAP_BEGIN (__segment_end("HEAP"))
  214. #else
  215. extern int __bss_end;
  216. #define HEAP_BEGIN ((void *)&__bss_end)
  217. #endif
  218. #define HEAP_END STM32_SRAM_END
  219. void rt_hw_board_init(void);
  220. #endif /* __BOARD_H__ */