py32f002b_ll_utils.h 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. /**
  2. ******************************************************************************
  3. * @file py32f002b_ll_utils.h
  4. * @author MCU Application Team
  5. * @brief Header file of UTILS LL module.
  6. @verbatim
  7. ==============================================================================
  8. ##### How to use this driver #####
  9. ==============================================================================
  10. [..]
  11. The LL UTILS driver contains a set of generic APIs that can be
  12. used by user:
  13. (+) Device electronic signature
  14. (+) Timing functions
  15. (+) PLL configuration functions
  16. @endverbatim
  17. ******************************************************************************
  18. * @attention
  19. *
  20. * <h2><center>&copy; Copyright (c) 2023 Puya Semiconductor Co.
  21. * All rights reserved.</center></h2>
  22. *
  23. * This software component is licensed by Puya under BSD 3-Clause license,
  24. * the "License"; You may not use this file except in compliance with the
  25. * License. You may obtain a copy of the License at:
  26. * opensource.org/licenses/BSD-3-Clause
  27. *
  28. ******************************************************************************
  29. * @attention
  30. *
  31. * <h2><center>&copy; Copyright (c) 2016 STMicroelectronics.
  32. * All rights reserved.</center></h2>
  33. *
  34. * This software component is licensed by ST under BSD 3-Clause license,
  35. * the "License"; You may not use this file except in compliance with the
  36. * License. You may obtain a copy of the License at:
  37. * opensource.org/licenses/BSD-3-Clause
  38. *
  39. ******************************************************************************
  40. */
  41. /* Define to prevent recursive inclusion -------------------------------------*/
  42. #ifndef __PY32F002B_LL_UTILS_H
  43. #define __PY32F002B_LL_UTILS_H
  44. #ifdef __cplusplus
  45. extern "C" {
  46. #endif
  47. /* Includes ------------------------------------------------------------------*/
  48. #include "py32f0xx.h"
  49. /** @addtogroup PY32F002B_LL_Driver
  50. * @{
  51. */
  52. /** @defgroup UTILS_LL UTILS
  53. * @{
  54. */
  55. /* Private types -------------------------------------------------------------*/
  56. /* Private variables ---------------------------------------------------------*/
  57. /* Private constants ---------------------------------------------------------*/
  58. /** @defgroup UTILS_LL_Private_Constants UTILS Private Constants
  59. * @{
  60. */
  61. /* Max delay can be used in LL_mDelay */
  62. #define LL_MAX_DELAY 0xFFFFFFFFU
  63. /**
  64. * @brief Unique device ID register base address
  65. */
  66. #define UID_BASE_ADDRESS UID_BASE
  67. /**
  68. * @brief Flash size data register base address
  69. */
  70. #define FLASHSIZE_BASE_ADDRESS FLASHSIZE_BASE
  71. /**
  72. * @}
  73. */
  74. /* Private macros ------------------------------------------------------------*/
  75. /** @defgroup UTILS_LL_Private_Macros UTILS Private Macros
  76. * @{
  77. */
  78. /**
  79. * @}
  80. */
  81. /* Exported types ------------------------------------------------------------*/
  82. /** @defgroup UTILS_LL_ES_INIT UTILS Exported structures
  83. * @{
  84. */
  85. /**
  86. * @brief UTILS System, AHB and APB1 buses clock configuration structure definition
  87. */
  88. typedef struct
  89. {
  90. uint32_t AHBCLKDivider; /*!< The AHB clock (HCLK) divider. This clock is derived from the system clock (SYSCLK).
  91. This parameter can be a value of @ref RCC_LL_EC_SYSCLK_DIV
  92. This feature can be modified afterwards using unitary function
  93. @ref LL_RCC_SetAHBPrescaler(). */
  94. uint32_t APB1CLKDivider; /*!< The APB1 clock (PCLK1) divider. This clock is derived from the AHB clock (HCLK).
  95. This parameter can be a value of @ref RCC_LL_EC_APB1_DIV
  96. This feature can be modified afterwards using unitary function
  97. @ref LL_RCC_SetAPB1Prescaler(). */
  98. } LL_UTILS_ClkInitTypeDef;
  99. /**
  100. * @}
  101. */
  102. /* Exported constants --------------------------------------------------------*/
  103. /** @defgroup UTILS_LL_Exported_Constants UTILS Exported Constants
  104. * @{
  105. */
  106. /** @defgroup UTILS_EC_HSE_BYPASS HSE Bypass activation
  107. * @{
  108. */
  109. #define LL_UTILS_HSEBYPASS_OFF 0x00000000U /*!< HSE Bypass is not enabled */
  110. #define LL_UTILS_HSEBYPASS_ON 0x00000001U /*!< HSE Bypass is enabled */
  111. /**
  112. * @}
  113. */
  114. /**
  115. * @}
  116. */
  117. /* Exported macro ------------------------------------------------------------*/
  118. /* Exported functions --------------------------------------------------------*/
  119. /** @defgroup UTILS_LL_Exported_Functions UTILS Exported Functions
  120. * @{
  121. */
  122. /** @defgroup UTILS_EF_DEVICE_ELECTRONIC_SIGNATURE DEVICE ELECTRONIC SIGNATURE
  123. * @{
  124. */
  125. /**
  126. * @brief Get Word0 of the unique device identifier (UID based on 96 bits)
  127. * @retval UID[31:0]
  128. */
  129. __STATIC_INLINE uint32_t LL_GetUID_Word0(void)
  130. {
  131. return (uint32_t)(READ_REG(*((uint32_t *)UID_BASE_ADDRESS)));
  132. }
  133. /**
  134. * @brief Get Word1 of the unique device identifier (UID based on 96 bits)
  135. * @retval UID[63:32]
  136. */
  137. __STATIC_INLINE uint32_t LL_GetUID_Word1(void)
  138. {
  139. return (uint32_t)(READ_REG(*((uint32_t *)(UID_BASE_ADDRESS + 4U))));
  140. }
  141. /**
  142. * @brief Get Word2 of the unique device identifier (UID based on 96 bits)
  143. * @retval UID[95:64]
  144. */
  145. __STATIC_INLINE uint32_t LL_GetUID_Word2(void)
  146. {
  147. return (uint32_t)(READ_REG(*((uint32_t *)(UID_BASE_ADDRESS + 8U))));
  148. }
  149. /**
  150. * @brief Get Flash memory size
  151. * @retval Flash memory size(Bytes)
  152. */
  153. __STATIC_INLINE uint32_t LL_GetFlashSize(void)
  154. {
  155. return (uint32_t)(FLASH_SIZE);
  156. }
  157. /**
  158. * @brief Get SRAM memory size
  159. * @retval SRAM memory size(Bytes)
  160. */
  161. __STATIC_INLINE uint32_t LL_GetSramSize(void)
  162. {
  163. return (uint32_t)(SRAM_END - SRAM_BASE + 1);
  164. }
  165. /**
  166. * @}
  167. */
  168. /** @defgroup UTILS_LL_EF_DELAY DELAY
  169. * @{
  170. */
  171. /**
  172. * @brief This function configures the Cortex-M SysTick source of the time base.
  173. * @param HCLKFrequency HCLK frequency in Hz (can be calculated thanks to RCC helper macro)
  174. * @note When a RTOS is used, it is recommended to avoid changing the SysTick
  175. * configuration by calling this function, for a delay use rather osDelay RTOS service.
  176. * @param Ticks Number of ticks
  177. * @retval None
  178. */
  179. __STATIC_INLINE void LL_InitTick(uint32_t HCLKFrequency, uint32_t Ticks)
  180. {
  181. /* Configure the SysTick to have interrupt in 1ms time base */
  182. SysTick->LOAD = (uint32_t)((HCLKFrequency / Ticks) - 1UL); /* set reload register */
  183. SysTick->VAL = 0UL; /* Load the SysTick Counter Value */
  184. SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk |
  185. SysTick_CTRL_ENABLE_Msk; /* Enable the Systick Timer */
  186. }
  187. void LL_Init1msTick(uint32_t HCLKFrequency);
  188. void LL_mDelay(uint32_t Delay);
  189. /**
  190. * @}
  191. */
  192. /** @defgroup UTILS_EF_SYSTEM SYSTEM
  193. * @{
  194. */
  195. void LL_SetSystemCoreClock(uint32_t HCLKFrequency);
  196. ErrorStatus LL_SetFlashLatency(uint32_t HCLKFrequency);
  197. /**
  198. * @}
  199. */
  200. /**
  201. * @}
  202. */
  203. /**
  204. * @}
  205. */
  206. /**
  207. * @}
  208. */
  209. #ifdef __cplusplus
  210. }
  211. #endif
  212. #endif /* PY32F002B_LL_UTILS_H */
  213. /************************ (C) COPYRIGHT Puya *****END OF FILE****/