123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- /*
- * File : application.c
- * This file is part of RT-Thread RTOS
- * COPYRIGHT (C) 2014, RT-Thread Development Team
- *
- * The license and distribution terms for this file may be
- * found in the file LICENSE in this distribution or at
- * http://www.rt-thread.org/license/LICENSE
- *
- * Change Logs:
- * Date Author Notes
- * 2014-07-13 xiaonong port for lpc43xx
- */
- #include <rtthread.h>
- #include <board.h>
- #include <rtdevice.h>
- #include "drv_led.h"
- #ifdef RT_USING_FINSH
- #include <finsh.h>
- #include <shell.h>
- #endif
- #ifdef RT_USING_LOGTRACE
- #include <log_trace.h>
- #endif
- #ifdef RT_USING_VBUS
- #include <vbus.h>
- #endif
- static const unsigned char _M0_CODE[] SECTION("M0_CODE") = {
- #include "M0_CODE.h"
- };
- static void _boot_M0(void)
- {
- volatile uint32_t u32REG, u32Val;
- LPC_CREG->M0APPMEMMAP = (uint32_t)&_M0_CODE[0];
- // Release Slave from reset, first read status
- u32REG = LPC_RGU->RESET_ACTIVE_STATUS1;
- // If the M0 is being held in reset, release it...
- // 1 = no reset, 0 = reset
- while(!(u32REG & (1u << 24)))
- {
- u32Val = (~(u32REG) & (~(1 << 24)));
- LPC_RGU->RESET_CTRL1 = u32Val;
- u32REG = LPC_RGU->RESET_ACTIVE_STATUS1;
- }
- rt_kprintf("M0 boot to %p\n", &_M0_CODE[0]);
- }
- /* thread phase init */
- void rt_init_thread_entry(void *parameter)
- {
- /*
- *register unsigned int _msp __asm("msp");
- *register unsigned int _psp __asm("psp");
- *rt_kprintf("msp@ %p, psp@ %p\n", _msp, _psp);
- */
- #ifdef RT_USING_LOGTRACE
- log_trace_init();
- log_trace_set_device(RT_CONSOLE_DEVICE_NAME);
- #endif
- #ifdef RT_USING_FINSH
- /* initialize finsh */
- finsh_system_init();
- finsh_set_device(RT_CONSOLE_DEVICE_NAME);
- #endif
- #ifdef RT_USING_VBUS
- rt_vbus_do_init();
- #endif
- _boot_M0();
- }
- /*the led thread*/
- ALIGN(RT_ALIGN_SIZE)
- static rt_uint8_t led_stack[ 512 ];
- static struct rt_thread led_thread;
- static void led_thread_entry(void *parameter)
- {
- rt_uint8_t led_value;
- rt_device_t led_dev;
- rt_device_t vbus_dev;
- rt_err_t err;
- rt_led_hw_init();
- led_dev = rt_device_find("led");
- if (led_dev == RT_NULL)
- {
- rt_kprintf("can not find the led device\n");
- return;
- }
- vbus_dev = rt_device_find("vecho");
- if (vbus_dev == RT_NULL)
- {
- rt_kprintf("can not find the vbus device\n");
- return;
- }
- err = rt_device_open(vbus_dev, RT_DEVICE_OFLAG_RDWR);
- if (err != RT_EOK)
- {
- rt_kprintf("open vbus failed: %d\n", err);
- return;
- }
- led_value = 0;
- while (1)
- {
- int len;
- led_dev->write(led_dev, 0, &led_value, sizeof(led_value));
- led_value = !led_value;
- len = rt_device_write(vbus_dev, 0, &led_value, sizeof(led_value));
- if (len <= 0)
- {
- rt_kprintf("vbus write err: %d, %d\n", len, rt_get_errno());
- }
- rt_thread_delay(1000);
- }
- }
- int rt_application_init(void)
- {
- rt_thread_t tid;
- rt_err_t result;
- tid = rt_thread_create("init",
- rt_init_thread_entry, RT_NULL,
- 2048, 3, 20);
- if (tid != RT_NULL)
- rt_thread_startup(tid);
- /* init led thread */
- result = rt_thread_init(&led_thread, "led",
- led_thread_entry, RT_NULL,
- (rt_uint8_t *)&led_stack[0], sizeof(led_stack),
- 20, 5);
- if (result == RT_EOK)
- {
- rt_thread_startup(&led_thread);
- }
- return 0;
- }
|