rtt_board.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. /*
  2. * Copyright (c) 2021-2023 HPMicro
  3. * SPDX-License-Identifier: BSD-3-Clause
  4. *
  5. */
  6. #include "board.h"
  7. #include "rtt_board.h"
  8. #include "hpm_uart_drv.h"
  9. #include "hpm_gpio_drv.h"
  10. #include "hpm_mchtmr_drv.h"
  11. #include "hpm_pmp_drv.h"
  12. #include "assert.h"
  13. #include "hpm_clock_drv.h"
  14. #include "hpm_sysctl_drv.h"
  15. #include <rthw.h>
  16. #include <rtthread.h>
  17. #include "hpm_dma_mgr.h"
  18. #include "hpm_mchtmr_drv.h"
  19. extern int rt_hw_uart_init(void);
  20. void os_tick_config(void);
  21. void rtt_board_init(void);
  22. void rt_hw_board_init(void)
  23. {
  24. rtt_board_init();
  25. /* Call the RT-Thread Component Board Initialization */
  26. rt_components_board_init();
  27. }
  28. void os_tick_config(void)
  29. {
  30. sysctl_config_clock(HPM_SYSCTL, clock_node_mchtmr0, clock_source_osc0_clk0, 1);
  31. sysctl_add_resource_to_cpu0(HPM_SYSCTL, sysctl_resource_mchtmr0);
  32. mchtmr_set_compare_value(HPM_MCHTMR, BOARD_MCHTMR_FREQ_IN_HZ / RT_TICK_PER_SECOND);
  33. enable_mchtmr_irq();
  34. }
  35. void rtt_board_init(void)
  36. {
  37. board_init_clock();
  38. board_init_console();
  39. board_init_pmp();
  40. dma_mgr_init();
  41. /* initialize memory system */
  42. rt_system_heap_init(RT_HW_HEAP_BEGIN, RT_HW_HEAP_END);
  43. /* Configure the OS Tick */
  44. os_tick_config();
  45. /* Initialize the UART driver first, because later driver initialization may require the rt_kprintf */
  46. rt_hw_uart_init();
  47. /* Set console device */
  48. rt_console_set_device(RT_CONSOLE_DEVICE_NAME);
  49. }
  50. void app_init_led_pins(void)
  51. {
  52. gpio_set_pin_output(APP_LED0_GPIO_CTRL, APP_LED0_GPIO_INDEX, APP_LED0_GPIO_PIN);
  53. gpio_set_pin_output(APP_LED1_GPIO_CTRL, APP_LED1_GPIO_INDEX, APP_LED1_GPIO_PIN);
  54. gpio_set_pin_output(APP_LED2_GPIO_CTRL, APP_LED2_GPIO_INDEX, APP_LED2_GPIO_PIN);
  55. gpio_write_pin(APP_LED0_GPIO_CTRL, APP_LED0_GPIO_INDEX, APP_LED0_GPIO_PIN, APP_LED_OFF);
  56. gpio_write_pin(APP_LED1_GPIO_CTRL, APP_LED1_GPIO_INDEX, APP_LED1_GPIO_PIN, APP_LED_OFF);
  57. gpio_write_pin(APP_LED2_GPIO_CTRL, APP_LED2_GPIO_INDEX, APP_LED2_GPIO_PIN, APP_LED_OFF);
  58. }
  59. void app_led_write(uint32_t index, bool state)
  60. {
  61. switch (index)
  62. {
  63. case 0:
  64. gpio_write_pin(APP_LED0_GPIO_CTRL, APP_LED0_GPIO_INDEX, APP_LED0_GPIO_PIN, state);
  65. break;
  66. case 1:
  67. gpio_write_pin(APP_LED1_GPIO_CTRL, APP_LED1_GPIO_INDEX, APP_LED1_GPIO_PIN, state);
  68. break;
  69. case 2:
  70. gpio_write_pin(APP_LED2_GPIO_CTRL, APP_LED2_GPIO_INDEX, APP_LED2_GPIO_PIN, state);
  71. break;
  72. default:
  73. /* Suppress the toolchain warnings */
  74. break;
  75. }
  76. }
  77. void rt_hw_console_output(const char *str)
  78. {
  79. while (*str != '\0')
  80. {
  81. uart_send_byte(BOARD_APP_UART_BASE, *str++);
  82. }
  83. }
  84. void app_init_usb_pins(void)
  85. {
  86. board_init_usb_pins();
  87. }
  88. ATTR_PLACE_AT(".isr_vector") void mchtmr_isr(void)
  89. {
  90. HPM_MCHTMR->MTIMECMP = HPM_MCHTMR->MTIME + BOARD_MCHTMR_FREQ_IN_HZ / RT_TICK_PER_SECOND;
  91. rt_tick_increase();
  92. }
  93. void rt_hw_cpu_reset(void)
  94. {
  95. HPM_PPOR->RESET_ENABLE = (1UL << 31);
  96. HPM_PPOR->SOFTWARE_RESET = 1000U;
  97. while(1) {
  98. }
  99. }
  100. MSH_CMD_EXPORT_ALIAS(rt_hw_cpu_reset, reset, reset the board);
  101. #ifdef RT_USING_CACHE
  102. void rt_hw_cpu_dcache_ops(int ops, void *addr, int size)
  103. {
  104. if (ops == RT_HW_CACHE_FLUSH) {
  105. l1c_dc_flush((uint32_t)addr, size);
  106. } else {
  107. l1c_dc_invalidate((uint32_t)addr, size);
  108. }
  109. }
  110. #endif