application.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. /*
  2. * Copyright (c) 2006-2018, 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[] 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. finsh_set_device(RT_CONSOLE_DEVICE_NAME);
  52. #endif
  53. #ifdef RT_USING_VBUS
  54. rt_vbus_do_init();
  55. #endif
  56. _boot_M0();
  57. }
  58. /*the led thread*/
  59. ALIGN(RT_ALIGN_SIZE)
  60. static rt_uint8_t led_stack[ 512 ];
  61. static struct rt_thread led_thread;
  62. static void led_thread_entry(void *parameter)
  63. {
  64. rt_uint8_t led_value;
  65. rt_device_t led_dev;
  66. rt_device_t vbus_dev;
  67. rt_err_t err;
  68. rt_led_hw_init();
  69. led_dev = rt_device_find("led");
  70. if (led_dev == RT_NULL)
  71. {
  72. rt_kprintf("can not find the led device\n");
  73. return;
  74. }
  75. vbus_dev = rt_device_find("vecho");
  76. if (vbus_dev == RT_NULL)
  77. {
  78. rt_kprintf("can not find the vbus device\n");
  79. return;
  80. }
  81. err = rt_device_open(vbus_dev, RT_DEVICE_OFLAG_RDWR);
  82. if (err != RT_EOK)
  83. {
  84. rt_kprintf("open vbus failed: %d\n", err);
  85. return;
  86. }
  87. led_value = 0;
  88. while (1)
  89. {
  90. int len;
  91. led_dev->write(led_dev, 0, &led_value, sizeof(led_value));
  92. led_value = !led_value;
  93. len = rt_device_write(vbus_dev, 0, &led_value, sizeof(led_value));
  94. if (len <= 0)
  95. {
  96. rt_kprintf("vbus write err: %d, %d\n", len, rt_get_errno());
  97. }
  98. rt_thread_delay(1000);
  99. }
  100. }
  101. int rt_application_init(void)
  102. {
  103. rt_thread_t tid;
  104. rt_err_t result;
  105. tid = rt_thread_create("init",
  106. rt_init_thread_entry, RT_NULL,
  107. 2048, 3, 20);
  108. if (tid != RT_NULL)
  109. rt_thread_startup(tid);
  110. /* init led thread */
  111. result = rt_thread_init(&led_thread, "led",
  112. led_thread_entry, RT_NULL,
  113. (rt_uint8_t *)&led_stack[0], sizeof(led_stack),
  114. 20, 5);
  115. if (result == RT_EOK)
  116. {
  117. rt_thread_startup(&led_thread);
  118. }
  119. return 0;
  120. }