f51bce3fed
We currently only support building with CCS and SCons is not using. bsp/rm48x50/HALCoGen/HALCoGen.{hcg,dil} is the HALCoGen project file. You may need to regenerate the source file as you like, providing that: 1, IRQ is in Dispatch Mode and the table entry is IRQ_Handler. The channel 5 in enabled and connected to IRQ. 2, RTI driver is enabled and compare3 source is selected to counter1 and the compare3 will generate tick in the period of 10ms. This value is coresponding with RT_TICK_PER_SECOND in rtconfig.h. In CCS, you need to create a new CCS project and create link folders pointing at bsp/rm48x50, libcpu/arm/rm48x50 and src/, include/. Remember to add the include path to the Build Properties.
116 lines
2.1 KiB
C
116 lines
2.1 KiB
C
/*
|
|
* File : startup.c
|
|
* This file is part of RT-Thread RTOS
|
|
* COPYRIGHT (C) 2006-2013, RT-Thread Develop 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
|
|
* 2008-12-11 xuxinming first version
|
|
* 2010-4-3 LiJin add init soft timer thread
|
|
* 2013-05-24 Grissiom port to RM48x50
|
|
*/
|
|
|
|
#include <rthw.h>
|
|
#include <rtthread.h>
|
|
|
|
#ifdef RT_USING_FINSH
|
|
#include <finsh.h>
|
|
extern void finsh_system_init(void);
|
|
#endif
|
|
|
|
#include <board.h>
|
|
|
|
/**
|
|
* @addtogroup LPC2478
|
|
*/
|
|
/*@{*/
|
|
|
|
extern int rt_application_init(void);
|
|
#ifdef RT_USING_DEVICE
|
|
extern rt_err_t rt_hw_serial_init(void);
|
|
#endif
|
|
|
|
#ifdef __CC_ARM
|
|
extern int Image$$RW_IRAM1$$ZI$$Limit;
|
|
#elif defined(__GNUC__)
|
|
extern int __bss_end;
|
|
#else
|
|
extern unsigned char *__TI_DATA_Limit;
|
|
#endif
|
|
#define MEMEND 0x08040000
|
|
|
|
/**
|
|
* This function will startup RT-Thread RTOS.
|
|
*/
|
|
void rtthread_startup(void)
|
|
{
|
|
/* init hardware interrupt */
|
|
rt_hw_interrupt_init();
|
|
|
|
/* init board */
|
|
rt_hw_board_init();
|
|
|
|
/* init tick */
|
|
rt_system_tick_init();
|
|
|
|
/* init kernel object */
|
|
rt_system_object_init();
|
|
|
|
rt_show_version();
|
|
|
|
/* init timer system */
|
|
rt_system_timer_init();
|
|
|
|
/* init memory system */
|
|
#ifdef RT_USING_HEAP
|
|
#ifdef __CC_ARM
|
|
rt_system_heap_init((void*)&Image$$RW_IRAM1$$ZI$$Limit, (void*)MEMEND);
|
|
#elif defined(__GNUC__)
|
|
rt_system_heap_init((void*)&__bss_end, (void*)MEMEND);
|
|
#else
|
|
rt_system_heap_init((void*)&__TI_DATA_Limit, (void*)MEMEND);
|
|
#endif
|
|
#endif
|
|
|
|
/* init scheduler system */
|
|
rt_system_scheduler_init();
|
|
|
|
/* init application */
|
|
rt_application_init();
|
|
|
|
#ifdef RT_USING_FINSH
|
|
/* init finsh */
|
|
finsh_system_init();
|
|
finsh_set_device("uart1");
|
|
#endif
|
|
|
|
/* init soft timer thread */
|
|
rt_system_timer_thread_init();
|
|
|
|
/* init idle thread */
|
|
rt_thread_idle_init();
|
|
|
|
/* start scheduler */
|
|
rt_system_scheduler_start();
|
|
|
|
/* never reach here */
|
|
return ;
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
/* disable interrupt first */
|
|
rt_hw_interrupt_disable();
|
|
|
|
/* invoke rtthread_startup */
|
|
rtthread_startup();
|
|
|
|
return 0;
|
|
}
|
|
|
|
/*@}*/
|