关于contiki系统到STM32的移植
化改成
- void
- clock_init()
- {
- if(SysTick_Config(SystemCoreClock/CLOCK_SECOND))
- {
- while(1);
- }
- }
把systick中断改为
- voidSysTick_Handler(void)
- {
- current_clock++;
- if(etimer_pending()&&etimer_next_expiration_time()<=current_clock){
- etimer_request_poll();
- //printf("%d,%d\n",clock_time(),etimer_next_expiration_time());
- }
- if(--second_countdown==0){
- current_seconds++;
- second_countdown=CLOCK_SECOND;
- }
- }
最后,把stm32f10x_it.c的void SysTick_Handler(void){}删除。。 再来配置一下debug接口。配置串口位于debug_uart文件中,我把原代码中的DMA相关代码删除,只剩串口初始化和fputc函数。具体的代码如下:
- void
- dbg_setup_uart_default()
- {
- USART_InitTypeDefUSART_InitStructure;
- GPIO_InitTypeDefGPIO_InitStructure;
- //使能GPIOA时钟
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA\
- |RCC_APB2Periph_USART1,ENABLE);
- //PA9TX1复用推挽输出
- GPIO_InitStructure.GPIO_Pin=GPIO_Pin_9;
- GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
- GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP;
- GPIO_Init(GPIOA,&GPIO_InitStructure);
- //PA10RX1浮动输入
- GPIO_InitStructure.GPIO_Pin=GPIO_Pin_10;
- GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
- GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING;
- GPIO_Init(GPIOA,&GPIO_InitStructure);
- USART_InitStructure.USART_BaudRate=9600;
- USART_InitStructure.USART_WordLength=USART_WordLength_8b;
- USART_InitStructure.USART_StopBits=USART_StopBits_1;
- USART_InitStructure.USART_Parity=USART_Parity_No;
- USART_InitStructure.USART_HardwareFlowControl=USART_HardwareFlowControl_None;
- USART_InitStructure.USART_Mode=USART_Mode_Rx|USART_Mode_Tx;
- USART_Init(USART1,&USART_InitStructure);
- //使能USART1
- USART_Cmd(USART1,ENABLE);
- }
- intfputc(intch,FILE*f)
- {
- USART_SendData(USART1,(uint8_t)ch);
- while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);
- returnch;
- }
5.新建一个任务
通过上网搜索和阅读书籍,我写了以下任务。
- PROCESS(blink_process,"Blink");
- AUTOSTART_PROCESSES(&blink_process);
- PROCESS_THREAD(blink_process,ev,data)
- {
- PROCESS_BEGIN();
- while(1)
- {
- staticstructetimeret;
- etimer_set(&et,CLOCK_SECOND);
- PROCESS_WAIT_EVENT_UNTIL(etimer_expired(&et));
- //打开LED
- GPIO_ResetBits(GPIOC,GPIO_Pin_6);
- printf("LEDON\r\n");
- etimer_set(&et,CLOCK_SECOND);
- PROCESS_WAIT_EVENT_UNTIL(etimer_expired(&et));
- //关闭LED
- GPIO_SetBits(GPIOC,GPIO_Pin_6);
- printf("LEDOFF\r\n");
- }
- PROCESS_END();
- }
该任务是从contiki-2.5中例子修改而来的。任务非常的简单,打开LED,通过串口发送提示信息,然后关闭LED,通过串口发送提示信息。
PROCESS(blink_process,"Blink");相关于函数的声明
AUTOSTART_PROCESSES(&blink_process);是指该任务自动启动,也可以调用process_start函数启动任务。AUTOSTART_PROCESSES其实也是一个宏东定义:
- #if!CC_NO_VA_ARGS
- #ifAUTOSTART_ENABLE
- #defineAUTOSTART_PROCESSES(...)\
- structprocess*constautostart_processes[]={__VA_ARGS__,NULL}
- #else//AUTOSTART_ENABLE
- #defineAUTOSTART_PROCESSES(...)\
- externint_dummy
- #endif//AUTOSTART_ENABLE
- #else
- #error"Ccompilermustsupport__VA_ARGS__macro"
- #endif
要想使用它的话,还需要添加AUTOSTART_ENABLE定义。
#define AUTOSTART_ENABLE 1
最后请大家不要忘记LED相关IO口的初始化操作。请查看前文代码。
6.实验结果
先给出contiki的IAR 工程目录和文件目录


再来一个头文件包含路径:

$PROJ_DIR$\CMSIS
$PROJ_DIR$\StdPeriph_Driver\inc
$PROJ_DIR$\User
$PROJ_DIR$\contiki-2.5\core
$PROJ_DIR$\contiki-2.5\core\sys
$PROJ_DIR$\contiki-2.5\core\lib
$PROJ_DIR$\contiki-2.5\cpu
在编译文件的时候会发生一些莫名奇妙的警告,这个警告产生的原因是 linux的文件换行和window文件换行不同! 采用以下方法可以屏蔽这个警告,如下图所示:

如果移植顺利的话,就可以看到以下实验结果。

写到这里你会发现,contiki的移植还是非常简单的。
contiki系统STM32移 相关文章:
- Windows CE 进程、线程和内存管理(11-09)
- RedHatLinux新手入门教程(5)(11-12)
- uClinux介绍(11-09)
- openwebmailV1.60安装教学(11-12)
- Linux嵌入式系统开发平台选型探讨(11-09)
- Windows CE 进程、线程和内存管理(二)(11-09)
