1
0

application.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2014-07-13 xiaonong port for lpc43xx
  9. */
  10. #include <rtthread.h>
  11. #include <board.h>
  12. #include <rtdevice.h>
  13. #include "drv_led.h"
  14. #ifdef RT_USING_FINSH
  15. #include <finsh.h>
  16. #include <shell.h>
  17. #endif
  18. #ifdef RT_USING_VBUS
  19. #include <vbus.h>
  20. #endif
  21. static const unsigned char _M0_CODE[] RT_SECTION("M0_CODE") = {
  22. #include "M0_CODE.h"
  23. };
  24. static void _boot_M0(void)
  25. {
  26. volatile uint32_t u32REG, u32Val;
  27. LPC_CREG->M0APPMEMMAP = (uint32_t)&_M0_CODE[0];
  28. // Release Slave from reset, first read status
  29. u32REG = LPC_RGU->RESET_ACTIVE_STATUS1;
  30. // If the M0 is being held in reset, release it...
  31. // 1 = no reset, 0 = reset
  32. while(!(u32REG & (1u << 24)))
  33. {
  34. u32Val = (~(u32REG) & (~(1 << 24)));
  35. LPC_RGU->RESET_CTRL1 = u32Val;
  36. u32REG = LPC_RGU->RESET_ACTIVE_STATUS1;
  37. }
  38. rt_kprintf("M0 boot to %p\n", &_M0_CODE[0]);
  39. }
  40. /* thread phase init */
  41. void rt_init_thread_entry(void *parameter)
  42. {
  43. /*
  44. *register unsigned int _msp __asm("msp");
  45. *register unsigned int _psp __asm("psp");
  46. *rt_kprintf("msp@ %p, psp@ %p\n", _msp, _psp);
  47. */
  48. #ifdef RT_USING_FINSH
  49. /* initialize finsh */
  50. finsh_system_init();
  51. #if !defined(RT_USING_POSIX_STDIO) && defined(RT_USING_DEVICE)
  52. finsh_set_device(RT_CONSOLE_DEVICE_NAME);
  53. #endif
  54. #endif
  55. #ifdef RT_USING_VBUS
  56. rt_vbus_do_init();
  57. #endif
  58. _boot_M0();
  59. }
  60. /*the led thread*/
  61. ALIGN(RT_ALIGN_SIZE)
  62. static rt_uint8_t led_stack[ 512 ];
  63. static struct rt_thread led_thread;
  64. static void led_thread_entry(void *parameter)
  65. {
  66. rt_uint8_t led_value;
  67. rt_device_t led_dev;
  68. rt_device_t vbus_dev;
  69. rt_err_t err;
  70. rt_led_hw_init();
  71. led_dev = rt_device_find("led");
  72. if (led_dev == RT_NULL)
  73. {
  74. rt_kprintf("can not find the led device\n");
  75. return;
  76. }
  77. vbus_dev = rt_device_find("vecho");
  78. if (vbus_dev == RT_NULL)
  79. {
  80. rt_kprintf("can not find the vbus device\n");
  81. return;
  82. }
  83. err = rt_device_open(vbus_dev, RT_DEVICE_OFLAG_RDWR);
  84. if (err != RT_EOK)
  85. {
  86. rt_kprintf("open vbus failed: %d\n", err);
  87. return;
  88. }
  89. led_value = 0;
  90. while (1)
  91. {
  92. int len;
  93. led_dev->write(led_dev, 0, &led_value, sizeof(led_value));
  94. led_value = !led_value;
  95. len = rt_device_write(vbus_dev, 0, &led_value, sizeof(led_value));
  96. if (len <= 0)
  97. {
  98. rt_kprintf("vbus write err: %d, %d\n", len, rt_get_errno());
  99. }
  100. rt_thread_delay(1000);
  101. }
  102. }
  103. int rt_application_init(void)
  104. {
  105. rt_thread_t tid;
  106. rt_err_t result;
  107. tid = rt_thread_create("init",
  108. rt_init_thread_entry, RT_NULL,
  109. 2048, 3, 20);
  110. if (tid != RT_NULL)
  111. rt_thread_startup(tid);
  112. /* init led thread */
  113. result = rt_thread_init(&led_thread, "led",
  114. led_thread_entry, RT_NULL,
  115. (rt_uint8_t *)&led_stack[0], sizeof(led_stack),
  116. 20, 5);
  117. if (result == RT_EOK)
  118. {
  119. rt_thread_startup(&led_thread);
  120. }
  121. return 0;
  122. }