在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 關(guān)于contiki系統(tǒng)到STM32的移植

            關(guān)于contiki系統(tǒng)到STM32的移植

            作者: 時(shí)間:2016-11-13 來(lái)源:網(wǎng)絡(luò) 收藏
            1.contiki簡(jiǎn)介

            “Contiki是一個(gè)小型的,開(kāi)源的,極易移植的多任務(wù)操作系統(tǒng)。它專門設(shè)計(jì)以適用于一系列的內(nèi)存優(yōu)先的網(wǎng)絡(luò)系統(tǒng),包括從8位電腦到微型控制器的嵌入系統(tǒng)。它的名字來(lái)自于托爾·海爾達(dá)爾的康提基號(hào)。Contiki只需幾kilobyte的代碼和幾百字節(jié)的內(nèi)存就能提供多任務(wù)環(huán)境和內(nèi)建TCP/IP支持。

            本文引用地址:http://www.biyoush.com/article/201611/316108.htm

            2.移植前的準(zhǔn)備

            首先建立一個(gè)最簡(jiǎn)單工程。一個(gè)最簡(jiǎn)單的任務(wù)莫過(guò)于LED閃爍了,從學(xué)習(xí)51單片機(jī)開(kāi)始,到AVR,到ARM,從移植uCOS到移植contiki。LED閃爍無(wú)疑是最棒的任務(wù)。假設(shè)這個(gè)任務(wù)就是LED點(diǎn)亮1秒,然后LED熄滅1秒。Contiki的采用事件驅(qū)動(dòng)機(jī)制,那么如何才能夠產(chǎn)生“事件“呢。答案只有兩個(gè):第一,通過(guò)時(shí)鐘定時(shí),定時(shí)事件到就產(chǎn)生一個(gè)事件;第二,通過(guò)某種中斷,某個(gè)中斷發(fā)生,就產(chǎn)生某個(gè)事件例如外部中斷。那么移植contiki到底要做哪些工作呢。先來(lái)回顧一下uCOS在STM32移植,uCOS的移植也就是做了兩件事情,第一,在PendSV這個(gè)異常中斷中,保存上下文;第二,使用systick提供系統(tǒng)時(shí)鐘。由于contiki是非搶占的操作系統(tǒng),所以移植時(shí)并不需要PendSV中保存上下文。那么時(shí)鐘一定是必要的,移植contiki的移植重點(diǎn)就應(yīng)該在systick上。

            先上全部的代碼,給大家一個(gè)整體的印象。

            1. #include"stm32f10x.h"
            2. #include
            3. #include
            4. #includeuart.h>
            5. #include
            6. #include
            7. #include
            8. #include
            9. #include
            10. unsignedintidle_count=0;
            11. voidled_init();
            12. PROCESS(blink_process,"Blink");
            13. AUTOSTART_PROCESSES(&blink_process);
            14. PROCESS_THREAD(blink_process,ev,data)
            15. {
            16. PROCESS_BEGIN();
            17. while(1)
            18. {
            19. staticstructetimeret;
            20. etimer_set(&et,CLOCK_SECOND);
            21. PROCESS_WAIT_EVENT_UNTIL(etimer_expired(&et));
            22. //打開(kāi)LED
            23. GPIO_ResetBits(GPIOC,GPIO_Pin_6);
            24. printf("LEDONrn");
            25. etimer_set(&et,CLOCK_SECOND);
            26. PROCESS_WAIT_EVENT_UNTIL(etimer_expired(&et));
            27. //關(guān)閉LED
            28. GPIO_SetBits(GPIOC,GPIO_Pin_6);
            29. printf("LEDOFFrn");
            30. }
            31. PROCESS_END();
            32. }
            33. intmain()
            34. {
            35. dbg_setup_uart();
            36. led_init();
            37. printf("Initialisingrn");
            38. clock_init();
            39. process_init();
            40. process_start(&etimer_process,NULL);
            41. autostart_start(autostart_processes);
            42. //process_start(&blink_process,NULL);
            43. printf("Processesrunningrn");
            44. while(1){
            45. do
            46. {
            47. }
            48. while(process_run()>0);
            49. idle_count++;
            50. /*Idle!*/
            51. /*Stopprocessorclock*/
            52. /*asm("wfi"::);*/
            53. }
            54. return0;
            55. }
            56. voidled_init()
            57. {
            58. GPIO_InitTypeDefGPIO_InitStructure;
            59. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC,ENABLE);
            60. //PC6推挽輸出
            61. GPIO_InitStructure.GPIO_Pin=GPIO_Pin_6;
            62. GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
            63. GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;
            64. GPIO_Init(GPIOC,&GPIO_InitStructure);
            65. }

            3.尋找一些線索

            閱讀contiki-2.5 源碼中,stm32移植的相關(guān)內(nèi)容分散在兩個(gè)文件夾中,第一, cpuarmstm32f103,這個(gè)文件夾存放的stm32移植的相關(guān)文件;第二,platformstm32test,這個(gè)文件夾中有一個(gè)不是那么完整的例子。具體的源碼如下:

            1. #include
            2. #include
            3. #include
            4. #include
            5. #include
            6. #include
            7. #include
            8. #include
            9. #include
            10. #include
            11. #include
            12. #include
            13. unsignedintidle_count=0;
            14. int
            15. main()
            16. {
            17. dbg_setup_uart();
            18. printf("Initialisingn");
            19. clock_init();
            20. process_init();
            21. process_start(&etimer_process,NULL);
            22. autostart_start(autostart_processes);
            23. printf("Processesrunningn");
            24. while(1){
            25. do{
            26. }while(process_run()>0);
            27. idle_count++;
            28. /*Idle!*/
            29. /*Stopprocessorclock*/
            30. /*asm("wfi"::);*/
            31. }
            32. return0;
            33. }

            簡(jiǎn)單分析一下,首先文件中包含了一些頭文件??粗悬c(diǎn)熟悉,應(yīng)該是V2.0庫(kù)的頭文件,后面的移植工作會(huì)全部替換掉,使用V3.4的庫(kù)文件。在main函數(shù)中,第一步初始化串口并通過(guò)串口發(fā)送某些信息。接著,初始化時(shí)鐘,通過(guò)跟蹤源代碼,發(fā)現(xiàn)clock_init函數(shù)位于cpuarmstm32f103文件夾中的clock文件夾中。具體的函數(shù)如下:

            1. void
            2. clock_init()
            3. {
            4. NVIC_SET_SYSTICK_PRI(8);
            5. SysTick->LOAD=MCK/8/CLOCK_SECOND;
            6. SysTick->CTRL=SysTick_CTRL_ENABLE|SysTick_CTRL_TICKINT;
            7. }

            這段代碼的原理也非常的簡(jiǎn)單,初始化systick定時(shí)器。其功能是每秒發(fā)生CLOCK_SECOND次溢出。配置了systick也少不了systick中斷了,systick的中斷的源碼如下: 在systick中斷中不斷更新了etimer,有了時(shí)鐘contiki就可以運(yùn)行了。

            4.開(kāi)始移植 先在clock源文件中添加頭文件

            #include "stm32f10x.h"

            #include "stm32f10x_it.h"

            刪除原來(lái)的

            #include

            #include

            把systick初始化改成

            1. void
            2. clock_init()
            3. {
            4. if(SysTick_Config(SystemCoreClock/CLOCK_SECOND))
            5. {
            6. while(1);
            7. }
            8. }

            把systick中斷改為

            1. voidSysTick_Handler(void)
            2. {
            3. current_clock++;
            4. if(etimer_pending()&&etimer_next_expiration_time()<=current_clock){
            5. etimer_request_poll();
            6. //printf("%d,%dn",clock_time(),etimer_next_expiration_time());
            7. }
            8. if(--second_countdown==0){
            9. current_seconds++;
            10. second_countdown=CLOCK_SECOND;
            11. }
            12. }

            最后,把stm32f10x_it.c的void SysTick_Handler(void){}刪除。。 再來(lái)配置一下debug接口。配置串口位于debug_uart文件中,我把原代碼中的DMA相關(guān)代碼刪除,只剩串口初始化和fputc函數(shù)。具體的代碼如下:

            1. void
            2. dbg_setup_uart_default()
            3. {
            4. USART_InitTypeDefUSART_InitStructure;
            5. GPIO_InitTypeDefGPIO_InitStructure;
            6. //使能GPIOA時(shí)鐘
            7. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA
            8. |RCC_APB2Periph_USART1,ENABLE);
            9. //PA9TX1復(fù)用推挽輸出
            10. GPIO_InitStructure.GPIO_Pin=GPIO_Pin_9;
            11. GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
            12. GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP;
            13. GPIO_Init(GPIOA,&GPIO_InitStructure);
            14. //PA10RX1浮動(dòng)輸入
            15. GPIO_InitStructure.GPIO_Pin=GPIO_Pin_10;
            16. GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
            17. GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING;
            18. GPIO_Init(GPIOA,&GPIO_InitStructure);
            19. USART_InitStructure.USART_BaudRate=9600;
            20. USART_InitStructure.USART_WordLength=USART_WordLength_8b;
            21. USART_InitStructure.USART_StopBits=USART_StopBits_1;
            22. USART_InitStructure.USART_Parity=USART_Parity_No;
            23. USART_InitStructure.USART_HardwareFlowControl=USART_HardwareFlowControl_None;
            24. USART_InitStructure.USART_Mode=USART_Mode_Rx|USART_Mode_Tx;
            25. USART_Init(USART1,&USART_InitStructure);
            26. //使能USART1
            27. USART_Cmd(USART1,ENABLE);
            28. }
            29. intfputc(intch,FILE*f)
            30. {
            31. USART_SendData(USART1,(uint8_t)ch);
            32. while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);
            33. returnch;
            34. }

            5.新建一個(gè)任務(wù)

            通過(guò)上網(wǎng)搜索和閱讀書(shū)籍,我寫(xiě)了以下任務(wù)。

            1. PROCESS(blink_process,"Blink");
            2. AUTOSTART_PROCESSES(&blink_process);
            3. PROCESS_THREAD(blink_process,ev,data)
            4. {
            5. PROCESS_BEGIN();
            6. while(1)
            7. {
            8. staticstructetimeret;
            9. etimer_set(&et,CLOCK_SECOND);
            10. PROCESS_WAIT_EVENT_UNTIL(etimer_expired(&et));
            11. //打開(kāi)LED
            12. GPIO_ResetBits(GPIOC,GPIO_Pin_6);
            13. printf("LEDONrn");
            14. etimer_set(&et,CLOCK_SECOND);
            15. PROCESS_WAIT_EVENT_UNTIL(etimer_expired(&et));
            16. //關(guān)閉LED
            17. GPIO_SetBits(GPIOC,GPIO_Pin_6);
            18. printf("LEDOFFrn");
            19. }
            20. PROCESS_END();
            21. }

            該任務(wù)是從contiki-2.5中例子修改而來(lái)的。任務(wù)非常的簡(jiǎn)單,打開(kāi)LED,通過(guò)串口發(fā)送提示信息,然后關(guān)閉LED,通過(guò)串口發(fā)送提示信息。

            【1】PROCESS(blink_process,"Blink");相關(guān)于函數(shù)的聲明

            【2】AUTOSTART_PROCESSES(&blink_process);是指該任務(wù)自動(dòng)啟動(dòng),也可以調(diào)用process_start函數(shù)啟動(dòng)任務(wù)。AUTOSTART_PROCESSES其實(shí)也是一個(gè)宏?yáng)|定義:

            1. #if!CC_NO_VA_ARGS
            2. #ifAUTOSTART_ENABLE
            3. #defineAUTOSTART_PROCESSES(...)
            4. structprocess*constautostart_processes[]={__VA_ARGS__,NULL}
            5. #else//AUTOSTART_ENABLE
            6. #defineAUTOSTART_PROCESSES(...)
            7. externint_dummy
            8. #endif//AUTOSTART_ENABLE
            9. #else
            10. #error"Ccompilermustsupport__VA_ARGS__macro"
            11. #endif

            要想使用它的話,還需要添加AUTOSTART_ENABLE定義。

            #define AUTOSTART_ENABLE 1

            最后請(qǐng)大家不要忘記LED相關(guān)IO口的初始化操作。請(qǐng)查看前文代碼。

            6.實(shí)驗(yàn)結(jié)果

            先給出contiki的IAR 工程目錄和文件目錄

            再來(lái)一個(gè)頭文件包含路徑:

            $PROJ_DIR$CMSIS

            $PROJ_DIR$StdPeriph_Driverinc

            $PROJ_DIR$User

            $PROJ_DIR$contiki-2.5core

            $PROJ_DIR$contiki-2.5coresys

            $PROJ_DIR$contiki-2.5corelib

            $PROJ_DIR$contiki-2.5cpu

            【小技巧】在編譯文件的時(shí)候會(huì)發(fā)生一些莫名奇妙的警告,這個(gè)警告產(chǎn)生的原因是 linux的文件換行和window文件換行不同! 采用以下方法可以屏蔽這個(gè)警告,如下圖所示:

            如果移植順利的話,就可以看到以下實(shí)驗(yàn)結(jié)果。

            寫(xiě)到這里你會(huì)發(fā)現(xiàn),contiki的移植還是非常簡(jiǎn)單的。



            關(guān)鍵詞: contiki系統(tǒng)STM32移

            評(píng)論


            技術(shù)專區(qū)

            關(guān)閉