rtt_board.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. /*
  2. * Copyright (c) 2021-2022 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_manager.h"
  18. void os_tick_config(void);
  19. extern int rt_hw_uart_init(void);
  20. void rtt_board_init(void)
  21. {
  22. board_init_clock();
  23. board_init_console();
  24. board_init_pmp();
  25. dma_manager_init();
  26. /* initialize memory system */
  27. rt_system_heap_init(RT_HW_HEAP_BEGIN, RT_HW_HEAP_END);
  28. /* Configure the OS Tick */
  29. os_tick_config();
  30. /* Initialize the UART driver first, because later driver initialization may require the rt_kprintf */
  31. rt_hw_uart_init();
  32. /* Set console device */
  33. rt_console_set_device(RT_CONSOLE_DEVICE_NAME);
  34. }
  35. void app_init_led_pins(void)
  36. {
  37. gpio_set_pin_output(BOARD_LED_GPIO_CTRL, BOARD_LED_GPIO_INDEX, BOARD_LED_GPIO_PIN);
  38. gpio_write_pin(BOARD_LED_GPIO_CTRL, BOARD_LED_GPIO_INDEX, BOARD_LED_GPIO_PIN, BOARD_LED_OFF_LEVEL);
  39. }
  40. void app_led_write(uint32_t index, bool state)
  41. {
  42. gpio_write_pin(BOARD_LED_GPIO_CTRL, BOARD_LED_GPIO_INDEX, BOARD_LED_GPIO_PIN, state);
  43. }
  44. void BOARD_LED_write(uint32_t index, bool state)
  45. {
  46. switch (index)
  47. {
  48. case 0:
  49. gpio_write_pin(BOARD_LED_GPIO_CTRL, BOARD_LED_GPIO_INDEX, BOARD_LED_GPIO_PIN, state);
  50. break;
  51. default:
  52. /* Suppress the toolchain warnings */
  53. break;
  54. }
  55. }
  56. void os_tick_config(void)
  57. {
  58. sysctl_config_clock(HPM_SYSCTL, clock_node_mchtmr0, clock_source_osc0_clk0, 1);
  59. sysctl_add_resource_to_cpu0(HPM_SYSCTL, sysctl_resource_mchtmr0);
  60. mchtmr_set_compare_value(HPM_MCHTMR, BOARD_MCHTMR_FREQ_IN_HZ / RT_TICK_PER_SECOND);
  61. enable_mchtmr_irq();
  62. }
  63. void rt_hw_board_init(void)
  64. {
  65. rtt_board_init();
  66. /* Call the RT-Thread Component Board Initialization */
  67. rt_components_board_init();
  68. }
  69. void rt_hw_console_output(const char *str)
  70. {
  71. while (*str != '\0')
  72. {
  73. uart_send_byte(BOARD_APP_UART_BASE, *str++);
  74. }
  75. }
  76. ATTR_PLACE_AT(".isr_vector") void mchtmr_isr(void)
  77. {
  78. HPM_MCHTMR->MTIMECMP = HPM_MCHTMR->MTIME + BOARD_MCHTMR_FREQ_IN_HZ / RT_TICK_PER_SECOND;
  79. rt_interrupt_enter();
  80. rt_tick_increase();
  81. rt_interrupt_leave();
  82. }
  83. void rt_hw_us_delay(rt_uint32_t us)
  84. {
  85. clock_cpu_delay_us(us);
  86. }
  87. void rt_hw_cpu_reset(void)
  88. {
  89. HPM_PPOR->RESET_ENABLE = (1UL << 31);
  90. HPM_PPOR->RESET_HOT &= ~(1UL << 31);
  91. HPM_PPOR->RESET_COLD |= (1UL << 31);
  92. HPM_PPOR->SOFTWARE_RESET = 1000U;
  93. while(1) {
  94. }
  95. }
  96. MSH_CMD_EXPORT_ALIAS(rt_hw_cpu_reset, reset, reset the board);