application.c 3.5 KB

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