board.c 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. /*
  2. * Copyright (c) 2006-2023, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2022/12/25 flyingcys first version
  9. * 2023/01/17 chushicheng add pin and i2c
  10. * 2023/03/15 flyingcys update bsp file structure
  11. */
  12. #include <rthw.h>
  13. #include <rtthread.h>
  14. #include "board.h"
  15. #include "drv_uart.h"
  16. static void system_clock_init(void)
  17. {
  18. /* wifipll/audiopll */
  19. GLB_Power_On_XTAL_And_PLL_CLK(GLB_XTAL_40M, GLB_PLL_WIFIPLL |
  20. GLB_PLL_CPUPLL |
  21. GLB_PLL_UHSPLL |
  22. GLB_PLL_MIPIPLL);
  23. GLB_Set_MCU_System_CLK(GLB_MCU_SYS_CLK_WIFIPLL_320M);
  24. GLB_Set_DSP_System_CLK(GLB_DSP_SYS_CLK_CPUPLL_400M);
  25. GLB_Config_CPU_PLL(GLB_XTAL_40M, cpuPllCfg_480M);
  26. CPU_Set_MTimer_CLK(ENABLE, CPU_Get_MTimer_Source_Clock() / 1000 / 1000 - 1);
  27. }
  28. static void peripheral_clock_init(void)
  29. {
  30. PERIPHERAL_CLOCK_ADC_DAC_ENABLE();
  31. PERIPHERAL_CLOCK_SEC_ENABLE();
  32. PERIPHERAL_CLOCK_DMA0_ENABLE();
  33. PERIPHERAL_CLOCK_UART0_ENABLE();
  34. PERIPHERAL_CLOCK_UART1_ENABLE();
  35. PERIPHERAL_CLOCK_SPI0_1_ENABLE();
  36. PERIPHERAL_CLOCK_I2C0_ENABLE();
  37. PERIPHERAL_CLOCK_PWM0_ENABLE();
  38. PERIPHERAL_CLOCK_TIMER0_1_WDG_ENABLE();
  39. PERIPHERAL_CLOCK_IR_ENABLE();
  40. PERIPHERAL_CLOCK_I2S_ENABLE();
  41. PERIPHERAL_CLOCK_USB_ENABLE();
  42. PERIPHERAL_CLOCK_CAN_UART2_ENABLE();
  43. GLB_Set_ADC_CLK(ENABLE, GLB_ADC_CLK_XCLK, 4);
  44. GLB_Set_UART_CLK(ENABLE, HBN_UART_CLK_XCLK, 0);
  45. GLB_Set_DSP_UART0_CLK(ENABLE, GLB_DSP_UART_CLK_DSP_XCLK, 0);
  46. GLB_Set_SPI_CLK(ENABLE, GLB_SPI_CLK_MCU_MUXPLL_160M, 0);
  47. GLB_Set_I2C_CLK(ENABLE, GLB_I2C_CLK_XCLK, 0);
  48. GLB_Set_IR_CLK(ENABLE, GLB_IR_CLK_SRC_XCLK, 19);
  49. GLB_Set_ADC_CLK(ENABLE, GLB_ADC_CLK_XCLK, 1);
  50. GLB_Set_DIG_CLK_Sel(GLB_DIG_CLK_XCLK);
  51. GLB_Set_DIG_512K_CLK(ENABLE, ENABLE, 0x4E);
  52. GLB_Set_PWM1_IO_Sel(GLB_PWM1_IO_DIFF_END);
  53. GLB_Set_CAM_CLK(ENABLE, GLB_CAM_CLK_WIFIPLL_96M, 3);
  54. GLB_Set_PKA_CLK_Sel(GLB_PKA_CLK_MCU_MUXPLL_160M);
  55. #ifdef BSP_USING_CSI
  56. GLB_CSI_Config_MIPIPLL(2, 0x21000);
  57. GLB_CSI_Power_Up_MIPIPLL();
  58. GLB_Set_DSP_CLK(ENABLE, GLB_DSP_CLK_MUXPLL_160M, 1);
  59. #endif
  60. GLB_Set_USB_CLK_From_WIFIPLL(1);
  61. }
  62. #ifdef BSP_USING_PSRAM
  63. #define WB_4MB_PSRAM (1)
  64. #define UHS_32MB_PSRAM (2)
  65. #define UHS_64MB_PSRAM (3)
  66. #define WB_32MB_PSRAM (4)
  67. #define NONE_UHS_PSRAM (-1)
  68. int uhs_psram_init(void)
  69. {
  70. PSRAM_UHS_Cfg_Type psramDefaultCfg = {
  71. 2000,
  72. PSRAM_MEM_SIZE_32MB,
  73. PSRAM_PAGE_SIZE_2KB,
  74. PSRAM_UHS_NORMAL_TEMP,
  75. };
  76. bflb_efuse_device_info_type chip_info;
  77. bflb_ef_ctrl_get_device_info(&chip_info);
  78. if (chip_info.psramInfo == UHS_32MB_PSRAM) {
  79. psramDefaultCfg.psramMemSize = PSRAM_MEM_SIZE_32MB;
  80. } else if (chip_info.psramInfo == UHS_64MB_PSRAM) {
  81. psramDefaultCfg.psramMemSize = PSRAM_MEM_SIZE_64MB;
  82. } else {
  83. return -1;
  84. }
  85. //init uhs PLL; Must open uhs pll first, and then initialize uhs psram
  86. GLB_Config_UHS_PLL(GLB_XTAL_40M, uhsPllCfg_2000M);
  87. //init uhs psram ;
  88. // Psram_UHS_x16_Init(Clock_Peripheral_Clock_Get(BL_PERIPHERAL_CLOCK_PSRAMA) / 1000000);
  89. Psram_UHS_x16_Init_Override(&psramDefaultCfg);
  90. Tzc_Sec_PSRAMA_Access_Release();
  91. // example: 2000Mbps typical cal values
  92. uhs_phy_cal_res->rl = 39;
  93. uhs_phy_cal_res->rdqs = 3;
  94. uhs_phy_cal_res->rdq = 0;
  95. uhs_phy_cal_res->wl = 13;
  96. uhs_phy_cal_res->wdqs = 4;
  97. uhs_phy_cal_res->wdq = 5;
  98. uhs_phy_cal_res->ck = 9;
  99. /* TODO: use uhs psram trim update */
  100. set_uhs_latency_r(uhs_phy_cal_res->rl);
  101. cfg_dqs_rx(uhs_phy_cal_res->rdqs);
  102. cfg_dq_rx(uhs_phy_cal_res->rdq);
  103. set_uhs_latency_w(uhs_phy_cal_res->wl);
  104. cfg_dq_drv(uhs_phy_cal_res->wdq);
  105. cfg_ck_cen_drv(uhs_phy_cal_res->wdq + 4, uhs_phy_cal_res->wdq + 1);
  106. cfg_dqs_drv(uhs_phy_cal_res->wdqs);
  107. // set_odt_en();
  108. mr_read_back();
  109. return 0;
  110. }
  111. #endif
  112. /* This is the timer interrupt service routine. */
  113. static void systick_isr(void)
  114. {
  115. rt_tick_increase();
  116. }
  117. void rt_hw_board_init(void)
  118. {
  119. GLB_Halt_CPU(GLB_CORE_ID_D0);
  120. GLB_Halt_CPU(GLB_CORE_ID_LP);
  121. bflb_flash_init();
  122. system_clock_init();
  123. peripheral_clock_init();
  124. bflb_irq_initialize();
  125. bflb_mtimer_config(CPU_Get_MTimer_Clock() / RT_TICK_PER_SECOND, systick_isr);
  126. #ifdef BSP_USING_PSRAM
  127. if (uhs_psram_init() < 0)
  128. {
  129. rt_kprintf("uhs_psram_init failed!\n");
  130. return;
  131. }
  132. extern uint32_t __psrambss_start__;
  133. extern uint32_t __psrambss_end__;
  134. uint32_t *pDest;
  135. pDest = &__psrambss_start__;
  136. for (; pDest < &__psrambss_end__;) {
  137. *pDest++ = 0ul;
  138. }
  139. #endif
  140. #ifdef RT_USING_HEAP
  141. /* initialize memory system */
  142. rt_system_heap_init(RT_HW_HEAP_BEGIN, RT_HW_HEAP_END);
  143. #endif
  144. /* UART driver initialization is open by default */
  145. #ifdef RT_USING_SERIAL
  146. rt_hw_uart_init();
  147. #endif
  148. /* Set the shell console output device */
  149. #if defined(RT_USING_CONSOLE) && defined(RT_USING_DEVICE)
  150. rt_console_set_device(RT_CONSOLE_DEVICE_NAME);
  151. #endif
  152. #ifdef RT_USING_COMPONENTS_INIT
  153. rt_components_board_init();
  154. #endif
  155. #ifdef BSP_USING_TRIPLECORE
  156. /* set CPU D0 boot XIP address and flash address */
  157. Tzc_Sec_Set_CPU_Group(GLB_CORE_ID_D0, 1);
  158. /* D0 boot from 0x58000000 */
  159. GLB_Set_CPU_Reset_Address(GLB_CORE_ID_D0, 0x58000000);
  160. /* D0 image offset on flash is CONFIG_D0_FLASH_ADDR */
  161. bflb_sf_ctrl_set_flash_image_offset(CONFIG_D0_FLASH_ADDR, 1, SF_CTRL_FLASH_BANK0);
  162. Tzc_Sec_Set_CPU_Group(GLB_CORE_ID_LP, 0);
  163. /* LP boot from 0x580C0000 */
  164. GLB_Set_CPU_Reset_Address(GLB_CORE_ID_LP, 0x58000000 + CONFIG_LP_FLASH_ADDR);
  165. GLB_Release_CPU(GLB_CORE_ID_D0);
  166. GLB_Release_CPU(GLB_CORE_ID_LP);
  167. /* release d0 and then do can run */
  168. BL_WR_WORD(IPC_SYNC_ADDR1, IPC_SYNC_FLAG);
  169. BL_WR_WORD(IPC_SYNC_ADDR2, IPC_SYNC_FLAG);
  170. L1C_DCache_Clean_By_Addr(IPC_SYNC_ADDR1, 8);
  171. #endif
  172. #ifdef RT_USING_HEAP
  173. rt_kprintf("RT_HW_HEAP_BEGIN:%x RT_HW_HEAP_END:%x size: %d\r\n", RT_HW_HEAP_BEGIN, RT_HW_HEAP_END, RT_HW_HEAP_END - RT_HW_HEAP_BEGIN);
  174. #endif
  175. }
  176. void rt_hw_cpu_reset(void)
  177. {
  178. GLB_SW_POR_Reset();
  179. }
  180. MSH_CMD_EXPORT_ALIAS(rt_hw_cpu_reset, reboot, reset machine);