board.c 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. /*
  2. * Copyright (c) 2006-2019, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2019-12-04 Jiaxun Yang Initial version
  9. */
  10. /**
  11. * @addtogroup mipssim
  12. */
  13. /*@{*/
  14. #include <rtthread.h>
  15. #include <rthw.h>
  16. #include "mips_regs.h"
  17. #include "exception.h"
  18. #include "drv_uart.h"
  19. #define CPU_HZ (100 * 1000 * 1000)
  20. #define RT_HW_HEAP_END (0x80000000 + 64 * 1024 * 1024)
  21. extern unsigned char __bss_end;
  22. /**
  23. * This is the timer interrupt service routine.
  24. */
  25. void rt_hw_timer_handler(void)
  26. {
  27. unsigned int count;
  28. count = read_c0_compare();
  29. write_c0_compare(count);
  30. write_c0_count(0);
  31. /* increase a OS tick */
  32. rt_tick_increase();
  33. }
  34. /**
  35. * This function will initial OS timer
  36. */
  37. void rt_hw_timer_init(void)
  38. {
  39. write_c0_compare(CPU_HZ/2/RT_TICK_PER_SECOND);
  40. write_c0_count(0);
  41. mips_unmask_cpu_irq(7);
  42. }
  43. /**
  44. * Board level initialization
  45. */
  46. void rt_hw_board_init(void)
  47. {
  48. rt_hw_exception_init();
  49. /* init hardware interrupt */
  50. rt_hw_interrupt_init();
  51. #ifdef RT_USING_FPU
  52. /* init hardware fpu */
  53. rt_hw_fpu_init();
  54. #endif
  55. #ifdef RT_USING_SERIAL
  56. /* init hardware UART device */
  57. rt_hw_uart_init();
  58. /* set console device */
  59. rt_console_set_device("uart");
  60. #endif
  61. #ifdef RT_USING_HEAP
  62. rt_system_heap_init((void*)&__bss_end, (void*)RT_HW_HEAP_END);
  63. #endif
  64. /* init operating system timer */
  65. rt_hw_timer_init();
  66. #ifdef RT_USING_COMPONENTS_INIT
  67. rt_components_board_init();
  68. #endif
  69. rt_kprintf("Current SR: 0x%08x\n", read_c0_status());
  70. }
  71. /*@}*/