board.c 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  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. * 2023/03/15 flyingcys first version
  9. */
  10. #include <rthw.h>
  11. #include <rtthread.h>
  12. #include "board.h"
  13. #include "drv_uart.h"
  14. static void system_clock_init(void)
  15. {
  16. #if 1
  17. /* wifipll/audiopll */
  18. GLB_Power_On_XTAL_And_PLL_CLK(GLB_XTAL_40M, GLB_PLL_WIFIPLL | GLB_PLL_AUPLL);
  19. GLB_Set_MCU_System_CLK(GLB_MCU_SYS_CLK_TOP_WIFIPLL_320M);
  20. #else
  21. GLB_Set_MCU_System_CLK(GLB_MCU_SYS_CLK_RC32M);
  22. GLB_Power_On_XTAL_And_PLL_CLK(GLB_XTAL_40M, GLB_PLL_WIFIPLL);
  23. GLB_Config_AUDIO_PLL_To_384M();
  24. GLB_Set_MCU_System_CLK(GLB_MCU_SYS_CLK_TOP_AUPLL_DIV1);
  25. GLB_Set_MCU_System_CLK_Div(0, 3);
  26. #endif
  27. CPU_Set_MTimer_CLK(ENABLE, BL_MTIMER_SOURCE_CLOCK_MCU_XCLK, Clock_System_Clock_Get(BL_SYSTEM_CLOCK_XCLK) / 1000000 - 1);
  28. }
  29. static void peripheral_clock_init(void)
  30. {
  31. PERIPHERAL_CLOCK_ADC_DAC_ENABLE();
  32. PERIPHERAL_CLOCK_SEC_ENABLE();
  33. PERIPHERAL_CLOCK_DMA0_ENABLE();
  34. PERIPHERAL_CLOCK_UART0_ENABLE();
  35. PERIPHERAL_CLOCK_UART1_ENABLE();
  36. PERIPHERAL_CLOCK_SPI0_ENABLE();
  37. PERIPHERAL_CLOCK_I2C0_ENABLE();
  38. PERIPHERAL_CLOCK_PWM0_ENABLE();
  39. PERIPHERAL_CLOCK_TIMER0_1_WDG_ENABLE();
  40. PERIPHERAL_CLOCK_IR_ENABLE();
  41. PERIPHERAL_CLOCK_I2S_ENABLE();
  42. PERIPHERAL_CLOCK_USB_ENABLE();
  43. PERIPHERAL_CLOCK_CAN_ENABLE();
  44. GLB_Set_UART_CLK(ENABLE, HBN_UART_CLK_XCLK, 0);
  45. GLB_Set_SPI_CLK(ENABLE, GLB_SPI_CLK_MCU_MUXPLL_160M, 0);
  46. GLB_Set_I2C_CLK(ENABLE, GLB_I2C_CLK_XCLK, 0);
  47. GLB_Set_ADC_CLK(ENABLE, GLB_ADC_CLK_XCLK, 1);
  48. GLB_Set_DIG_CLK_Sel(GLB_DIG_CLK_XCLK);
  49. GLB_Set_DIG_512K_CLK(ENABLE, ENABLE, 0x4E);
  50. GLB_Set_PWM1_IO_Sel(GLB_PWM1_IO_DIFF_END);
  51. GLB_Set_IR_CLK(ENABLE, GLB_IR_CLK_SRC_XCLK, 19);
  52. GLB_Set_CAM_CLK(ENABLE, GLB_CAM_CLK_WIFIPLL_96M, 3);
  53. GLB_Set_PKA_CLK_Sel(GLB_PKA_CLK_MCU_MUXPLL_160M);
  54. #ifdef CONFIG_BSP_SDH_SDCARD
  55. PERIPHERAL_CLOCK_SDH_ENABLE();
  56. GLB_AHB_MCU_Software_Reset(GLB_AHB_MCU_SW_EXT_SDH);
  57. #endif
  58. GLB_Set_USB_CLK_From_WIFIPLL(1);
  59. GLB_Swap_MCU_SPI_0_MOSI_With_MISO(0);
  60. }
  61. #ifdef BSP_USING_PSRAM
  62. static void bflb_init_psram_gpio(void)
  63. {
  64. struct bflb_device_s *gpio;
  65. gpio = bflb_device_get_by_name("gpio");
  66. for (uint8_t i = 0; i < 12; i++) {
  67. bflb_gpio_init(gpio, (41 + i), GPIO_INPUT | GPIO_FLOAT | GPIO_SMT_EN | GPIO_DRV_0);
  68. }
  69. }
  70. static void psram_winbond_default_init(void)
  71. {
  72. PSRAM_Ctrl_Cfg_Type default_psram_ctrl_cfg = {
  73. .vendor = PSRAM_CTRL_VENDOR_WINBOND,
  74. .ioMode = PSRAM_CTRL_X8_MODE,
  75. .size = PSRAM_SIZE_4MB,
  76. .dqs_delay = 0xfff0,
  77. };
  78. PSRAM_Winbond_Cfg_Type default_winbond_cfg = {
  79. .rst = DISABLE,
  80. .clockType = PSRAM_CLOCK_DIFF,
  81. .inputPowerDownMode = DISABLE,
  82. .hybridSleepMode = DISABLE,
  83. .linear_dis = ENABLE,
  84. .PASR = PSRAM_PARTIAL_REFRESH_FULL,
  85. .disDeepPowerDownMode = ENABLE,
  86. .fixedLatency = DISABLE,
  87. .brustLen = PSRAM_WINBOND_BURST_LENGTH_64_BYTES,
  88. .brustType = PSRAM_WRAPPED_BURST,
  89. .latency = PSRAM_WINBOND_6_CLOCKS_LATENCY,
  90. .driveStrength = PSRAM_WINBOND_DRIVE_STRENGTH_35_OHMS_FOR_4M_115_OHMS_FOR_8M,
  91. };
  92. PSram_Ctrl_Init(PSRAM0_ID, &default_psram_ctrl_cfg);
  93. // PSram_Ctrl_Winbond_Reset(PSRAM0_ID);
  94. PSram_Ctrl_Winbond_Write_Reg(PSRAM0_ID, PSRAM_WINBOND_REG_CR0, &default_winbond_cfg);
  95. }
  96. static uint32_t board_psram_x8_init(void)
  97. {
  98. uint16_t reg_read = 0;
  99. GLB_Set_PSRAMB_CLK_Sel(ENABLE, GLB_PSRAMB_EMI_WIFIPLL_320M, 0);
  100. bflb_init_psram_gpio();
  101. /* psram init*/
  102. psram_winbond_default_init();
  103. /* check psram work or not */
  104. PSram_Ctrl_Winbond_Read_Reg(PSRAM0_ID, PSRAM_WINBOND_REG_ID0, &reg_read);
  105. return reg_read;
  106. }
  107. #endif
  108. /* This is the timer interrupt service routine. */
  109. static void systick_isr(void)
  110. {
  111. rt_tick_increase();
  112. }
  113. void rt_hw_board_init(void)
  114. {
  115. bflb_flash_init();
  116. system_clock_init();
  117. peripheral_clock_init();
  118. bflb_irq_initialize();
  119. bflb_mtimer_config(HW_MTIMER_CLOCK / RT_TICK_PER_SECOND, systick_isr);
  120. #ifdef RT_USING_HEAP
  121. /* initialize memory system */
  122. 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);
  123. rt_system_heap_init(RT_HW_HEAP_BEGIN, RT_HW_HEAP_END);
  124. #endif
  125. /* UART driver initialization is open by default */
  126. #ifdef RT_USING_SERIAL
  127. rt_hw_uart_init();
  128. #endif
  129. #ifdef BSP_USING_PSRAM
  130. board_psram_x8_init();
  131. Tzc_Sec_PSRAMB_Access_Release();
  132. #endif
  133. /* Set the shell console output device */
  134. #if defined(RT_USING_CONSOLE) && defined(RT_USING_DEVICE)
  135. rt_console_set_device(RT_CONSOLE_DEVICE_NAME);
  136. #endif
  137. #ifdef RT_USING_COMPONENTS_INIT
  138. rt_components_board_init();
  139. #endif
  140. }
  141. void rt_hw_cpu_reset(void)
  142. {
  143. GLB_SW_POR_Reset();
  144. }
  145. MSH_CMD_EXPORT_ALIAS(rt_hw_cpu_reset, reboot, reset machine);