|
@@ -1,7 +1,7 @@
|
|
|
/*
|
|
|
* File : startup.c
|
|
|
* This file is part of RT-Thread RTOS
|
|
|
- * COPYRIGHT (C) 2006, RT-Thread Develop Team
|
|
|
+ * 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
|
|
@@ -15,8 +15,6 @@
|
|
|
|
|
|
#include <rthw.h>
|
|
|
#include <rtthread.h>
|
|
|
-
|
|
|
-#include "stm32f10x.h"
|
|
|
#include "board.h"
|
|
|
|
|
|
/**
|
|
@@ -26,17 +24,16 @@
|
|
|
/*@{*/
|
|
|
|
|
|
extern int rt_application_init(void);
|
|
|
-#ifdef RT_USING_FINSH
|
|
|
-extern void finsh_system_init(void);
|
|
|
-extern void finsh_set_device(const char* device);
|
|
|
-#endif
|
|
|
|
|
|
#ifdef __CC_ARM
|
|
|
extern int Image$$RW_IRAM1$$ZI$$Limit;
|
|
|
+#define STM32_SRAM_BEGIN (&Image$$RW_IRAM1$$ZI$$Limit)
|
|
|
#elif __ICCARM__
|
|
|
#pragma section="HEAP"
|
|
|
+#define STM32_SRAM_BEGIN (__segment_end("HEAP"))
|
|
|
#else
|
|
|
extern int __bss_end;
|
|
|
+#define STM32_SRAM_BEGIN (&__bss_end)
|
|
|
#endif
|
|
|
|
|
|
/*******************************************************************************
|
|
@@ -50,11 +47,11 @@ extern int __bss_end;
|
|
|
*******************************************************************************/
|
|
|
void assert_failed(u8* file, u32 line)
|
|
|
{
|
|
|
- rt_kprintf("\n\r Wrong parameter value detected on\r\n");
|
|
|
- rt_kprintf(" file %s\r\n", file);
|
|
|
- rt_kprintf(" line %d\r\n", line);
|
|
|
+ rt_kprintf("\n\r Wrong parameter value detected on\r\n");
|
|
|
+ rt_kprintf(" file %s\r\n", file);
|
|
|
+ rt_kprintf(" line %d\r\n", line);
|
|
|
|
|
|
- while (1) ;
|
|
|
+ while (1) ;
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -62,69 +59,56 @@ void assert_failed(u8* file, u32 line)
|
|
|
*/
|
|
|
void rtthread_startup(void)
|
|
|
{
|
|
|
- /* init board */
|
|
|
- rt_hw_board_init();
|
|
|
+ /* init board */
|
|
|
+ rt_hw_board_init();
|
|
|
|
|
|
- /* show version */
|
|
|
- rt_show_version();
|
|
|
+ /* show version */
|
|
|
+ rt_show_version();
|
|
|
|
|
|
- /* init tick */
|
|
|
- rt_system_tick_init();
|
|
|
+ /* init tick */
|
|
|
+ rt_system_tick_init();
|
|
|
|
|
|
- /* init kernel object */
|
|
|
- rt_system_object_init();
|
|
|
+ /* init kernel object */
|
|
|
+ rt_system_object_init();
|
|
|
|
|
|
- /* init timer system */
|
|
|
- rt_system_timer_init();
|
|
|
+ /* init timer system */
|
|
|
+ rt_system_timer_init();
|
|
|
|
|
|
#ifdef RT_USING_HEAP
|
|
|
- #ifdef __CC_ARM
|
|
|
- rt_system_heap_init((void*)&Image$$RW_IRAM1$$ZI$$Limit, (void*)STM32_SRAM_END);
|
|
|
- #elif __ICCARM__
|
|
|
- rt_system_heap_init(__segment_end("HEAP"), (void*)STM32_SRAM_END);
|
|
|
- #else
|
|
|
- /* init memory system */
|
|
|
- rt_system_heap_init((void*)&__bss_end, (void*)STM32_SRAM_END);
|
|
|
- #endif
|
|
|
+ rt_system_heap_init((void*)STM32_SRAM_BEGIN, (void*)STM32_SRAM_END);
|
|
|
#endif
|
|
|
|
|
|
- /* init scheduler system */
|
|
|
- rt_system_scheduler_init();
|
|
|
+ /* init scheduler system */
|
|
|
+ rt_system_scheduler_init();
|
|
|
|
|
|
- /* init all device */
|
|
|
- rt_device_init_all();
|
|
|
+ /* init all device */
|
|
|
+ rt_device_init_all();
|
|
|
|
|
|
- /* init application */
|
|
|
- rt_application_init();
|
|
|
-
|
|
|
-#ifdef RT_USING_FINSH
|
|
|
- /* init finsh */
|
|
|
- finsh_system_init();
|
|
|
- finsh_set_device("uart1");
|
|
|
-#endif
|
|
|
+ /* init application */
|
|
|
+ rt_application_init();
|
|
|
|
|
|
/* init timer thread */
|
|
|
rt_system_timer_thread_init();
|
|
|
|
|
|
- /* init idle thread */
|
|
|
- rt_thread_idle_init();
|
|
|
+ /* init idle thread */
|
|
|
+ rt_thread_idle_init();
|
|
|
|
|
|
- /* start scheduler */
|
|
|
- rt_system_scheduler_start();
|
|
|
+ /* start scheduler */
|
|
|
+ rt_system_scheduler_start();
|
|
|
|
|
|
- /* never reach here */
|
|
|
- return ;
|
|
|
+ /* never reach here */
|
|
|
+ return ;
|
|
|
}
|
|
|
|
|
|
int main(void)
|
|
|
{
|
|
|
- /* disable interrupt first */
|
|
|
- rt_hw_interrupt_disable();
|
|
|
+ /* disable interrupt first */
|
|
|
+ rt_hw_interrupt_disable();
|
|
|
|
|
|
- /* startup RT-Thread RTOS */
|
|
|
- rtthread_startup();
|
|
|
+ /* startup RT-Thread RTOS */
|
|
|
+ rtthread_startup();
|
|
|
|
|
|
- return 0;
|
|
|
+ return 0;
|
|
|
}
|
|
|
|
|
|
/*@}*/
|