使用ADS移植uCOS的實(shí)例分析_第1頁
使用ADS移植uCOS的實(shí)例分析_第2頁
使用ADS移植uCOS的實(shí)例分析_第3頁
使用ADS移植uCOS的實(shí)例分析_第4頁
使用ADS移植uCOS的實(shí)例分析_第5頁
免費(fèi)預(yù)覽已結(jié)束,剩余1頁可下載查看

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、使用 ads 移植 uc/os-ii 的實(shí)例分析來源:中電網(wǎng)摘 要: 本文介紹了使用 arm 公司提供的 ads 開發(fā)工具,進(jìn)行移植 uc/os-ii 的工作。結(jié)合基于 strongarm 評估板的硬件結(jié)構(gòu),對移植工作中的若干要點(diǎn)做了詳細(xì)分析。最后,給出了移植體會和程序技巧分析。關(guān)鍵詞: ads uc/os-ii strongarm 移植 一、 選擇開發(fā)工具在嵌入式系統(tǒng)設(shè)計(jì)中,開發(fā)工具的選取是一個重要的考慮因素,通常這是與開發(fā)項(xiàng)目的需求和應(yīng)用背景相關(guān)。一般嵌入式開發(fā)工具包含用于目標(biāo)系統(tǒng)的交叉編譯器、連接器、調(diào)試器以及輔助處理用的二進(jìn)制文件分析工具等。目前可以用來編譯鏈接產(chǎn)生 arm 處理器執(zhí)行

2、代碼的開發(fā)工具主要有如下幾類:1. arm 公司提供的 arm developer suite 集成開發(fā)環(huán)境主要工具有 armasm、armcc、armlink、fromelf 等。2. gnu 組織提供的 tool chain for arm 主要工具有 arm-elf-gcc、arm-elf-gdb、arm-elf-objcopy 等3. microsoft公司提供的 embedded visual tools 主要工具有 clarm、clthumb、c2_arm、link、lib等 這里我們選用 arm 公司提供的 ads 下的工具集來編譯我們的程序和鏈接目標(biāo)代碼并最終生成可執(zhí)行的二進(jìn)制

3、映像。這里介紹一下主要會用到的一些工具:armasm.exe : 匯編文件編譯器armcc.exe : c 文件編譯器armlink.exe : 目標(biāo)文件連接器fromelf.exe : 用于將 axf 或者 elf 格式轉(zhuǎn)換成其他格式的文件,例如二進(jìn)制映像。armprof.exe : 對調(diào)試過程中生成的 profiling 記錄文件做分析用的工具軟件二、 存儲空間分配1. 存儲器組織strongarm 存儲器組織主要分4個部分:1) 0h0000 0000 0h3fff ffff用于靜態(tài)存儲器 rom、sram、flash2) 0h4000 0000 0h8fff ffff用于靜態(tài)存儲器和各

4、種 i/o 器件3) 0h8000 0000 0hbfff ffff包括所有片內(nèi)寄存器,主要用于外圍控制、系統(tǒng)控制、存儲擴(kuò)展、lcd和dma。4) 0hb000 0000 0hffff ffff用于動態(tài)存儲器,dram、sdram等2. 堆棧空間分配| 0xc2000000 - 系統(tǒng)堆棧從 0xc2000000 開始向下增長 | 其中 0xc2000000 為 svc 態(tài)的堆棧棧底| 0xc1000000 為 irq 態(tài)的堆棧棧底| sdram (32m) | | 0xc0000000 - rw-base 這里是程序的 rw 段,包括 uc/os-ii 的任務(wù)堆??臻g| : | | 0x020

5、00000 - | | flash rom (32m) | 從 0x00000000 開始依次放置跳轉(zhuǎn)指令,即異常向量表| 0x00000000 - ro-base 這里是程序的 text 段和 ro 段三、 啟動代碼由于板子的 0x0 地址處是 32m 的flash rom,因此在板子加電后,會從 flash 中順序執(zhí)行啟動代碼。為了能使得 uc/os-ii 運(yùn)行,啟動代碼需要完成如下工作:1. 設(shè)置 異常向量表,即在 0x0 0x1c 位置放置7條跳轉(zhuǎn)指令(其中 0x14 為空)2. 分別實(shí)現(xiàn)每種異常的處理程序,其中包括 reset_handler、undefined_handler、sw

6、i_handler、prefetch_handler、abort_handler、irq_handler、fiq_handler。3. 程序從 reset_handler 進(jìn)入后,需要首先進(jìn)行相關(guān)硬件的初始化操作,例如 初始化sdram、cpu speed、interrupt controller、uart、timer 等。4. 建立每種異常狀態(tài)下的系統(tǒng)堆棧,為了簡單起見可以只在 svc 態(tài) 和 irq 態(tài)下的建立堆棧:setup_svc_stack ,setup_irq_stack。5. 強(qiáng)制 arm 處理器狀態(tài)轉(zhuǎn)換為 svc 管理態(tài)。6. 跳轉(zhuǎn)到uc/os-ii 代碼的 main 入口,實(shí)

7、際上是編譯鏈接后產(chǎn)生的 _main 入口。四、 時鐘與中斷處理1. 時鐘控制邏輯os timer interrupt enable registeroperating system match register 03operating system counter registeroperating system status register在上圖中,有4種和系統(tǒng)時鐘相關(guān)寄存器,它們的含義如下:l oscr: 一個自動遞增計(jì)數(shù)的 32 位計(jì)數(shù)器。l osmr3-0: 4 個 32 位的匹配寄存器,當(dāng) oscr 的值匹配時產(chǎn)生中斷。l ossr: 狀態(tài)寄存器,當(dāng) oscr 和 osmr 匹配時

8、,會對 ossr 做標(biāo)志。l oier: 使能寄存器,表示當(dāng)匹配發(fā)生時,允許在 ossr 設(shè)置一個標(biāo)識位。oscr 在自動累加的過程中,與osmr里面設(shè)定的那些匹配寄存器進(jìn)行匹配,發(fā)現(xiàn)有匹配的事件時,就會對 ossr 中的相應(yīng)位置設(shè)一個標(biāo)志位“1”,表示oscr與對應(yīng)的osmr 發(fā)生了匹配。當(dāng)然這個匹配發(fā)生的前提是發(fā)生匹配的那個osmr在oier中的相應(yīng)位被使能,否則osmr中的設(shè)置將不起作用。2. 系統(tǒng)時鐘初始化流程uc/os-ii 中創(chuàng)建的第一個任務(wù)將負(fù)責(zé)啟動時鐘節(jié)拍,時鐘的初始化設(shè)置流程如下:1) 設(shè)置 osmr0 = x ,表示 初始化 osmr0,即當(dāng)計(jì)數(shù)器為x時發(fā)生匹配2) 設(shè)置

9、ossr = 0xf ,表示 清除所有已經(jīng)發(fā)生的匹配,寫“1”清除3) 設(shè)置 oier = oier_eo ,表示 使能 osmr0 來產(chǎn)生匹配4) 設(shè)置 oscr = 0 ,表示 初始化計(jì)數(shù)器的開始值 為 03. 系統(tǒng)時鐘中斷復(fù)位1) 清除 ossr 中的相應(yīng)位,即向發(fā)生匹配的osmr的那個對應(yīng)位寫“1”2) 設(shè)置 oscr = 0 ,表示 繼續(xù)初始化計(jì)數(shù)器的值為 0 4. 中斷控制器相關(guān)的寄存器l icpr: 中斷標(biāo)示寄存器,表示了當(dāng)前系統(tǒng)正處于激活狀態(tài)的中斷源。l icmr: 中斷屏蔽寄存器,用來屏蔽相應(yīng)位的中斷。l iclr: 中斷級別設(shè)置寄存器,設(shè)定報(bào)告中斷的級別是 irq 或者是

10、fiq 。l icip: irq 級別的中斷源寄存器,用來標(biāo)識 irq 中斷發(fā)生的源設(shè)備。l icfp: fiq 級別的中斷源寄存器,用來標(biāo)識 fiq 中斷發(fā)生的源設(shè)備。5. 中斷控制器初始化流程1) 設(shè)置 icmr 屏蔽位為不屏蔽時鐘中斷 osmr0 (相應(yīng)位寫“1”)2) 設(shè)置 iclr 為都報(bào)告為 irq 級別(所有位寫“0”)五、 移植工作總結(jié).1. 難點(diǎn)分析移植 uc/os-ii 到 strongarm 的芯片上,基本上和移植到 arm7 的芯片例如s3c4510,at91x等工作類似,因?yàn)樗械腶rm處理器都共享arm通用的基礎(chǔ)體系結(jié)構(gòu),這使得移植工作變得相對簡單,其中絕大部分工作

11、都集中在 os_cpu_a.s 文件的移植,這個文件的實(shí)現(xiàn)集中體現(xiàn)了所要移植到處理器的體系結(jié)構(gòu)和uc/os-ii 的移植原理;在這個文件里,最困難的工作主要是在 osintctxsw 和 ostickisr 這兩個函數(shù)的實(shí)現(xiàn)上。因?yàn)樗鼈兊膶?shí)現(xiàn)是和移植者的移植思路以及相關(guān)硬件定時器、中斷寄存器的設(shè)置有關(guān)。在實(shí)際的移植工作中,這兩個地方也是比較容易出錯的地方。osintctxsw 最重要的作用就是它完成了在中斷isr中直接進(jìn)行任務(wù)切換,從而提高了實(shí)時響應(yīng)的速度。它發(fā)生的時機(jī)是在 isr 執(zhí)行到 osintexit 時,如果發(fā)現(xiàn)有高優(yōu)先級的任務(wù)因?yàn)榈却?time tick 到來獲得了執(zhí)行的條件,這

12、樣就可以馬上被調(diào)度執(zhí)行,而不用返回被中斷的那個任務(wù)之后再進(jìn)行任務(wù)切換,因?yàn)槟菢拥脑捑筒粔驅(qū)崟r了。實(shí)現(xiàn) osintctxsw 的方法大致也有兩種情況:一種是通過調(diào)整 sp 堆棧指針的方法,根據(jù)所用的編譯器對于函數(shù)嵌套的處理,通過精確計(jì)算出所需要調(diào)整的 sp 位置來使得進(jìn)入中斷時所作的保存現(xiàn)場的工作可以被重用。這種方法的好處是直接在函數(shù)嵌套內(nèi)部發(fā)生任務(wù)切換,使得高優(yōu)先級的任務(wù)能夠最快的被調(diào)度執(zhí)行。但是這個辦法需要和具體的編譯器以及編譯參數(shù)的設(shè)置相關(guān),需要較多技巧。另一種是設(shè)置需要切換標(biāo)志位的方法,在 osintctxsw 里面不發(fā)生切換,而是設(shè)置一個需要切換的標(biāo)志,等函數(shù)嵌套從進(jìn)入 osintex

13、it = os_enter_critical() = osintctxsw() = os_exit_critical() = osintexit退出后,再根據(jù)標(biāo)志位來判斷是否需要進(jìn)行中斷級的任務(wù)切換。這種方法的好處是不需要考慮編譯器的因素,也不用做計(jì)算,但是從實(shí)時響應(yīng)上不是最快,不過這種方法實(shí)現(xiàn)起來比較簡單。在中斷態(tài)下進(jìn)行任務(wù)切換,需要特別說明的一個問題是如何獲得被中斷任務(wù)的 lr_svc 。因?yàn)檫M(jìn)入中斷態(tài)后,lr 變成了lr_irq ,原來任務(wù)的 lr_svc 無法在中斷態(tài)下獲得,這樣要得到 lr_svc ,就必須在中斷 isr 里面進(jìn)行一次 cpu mode 強(qiáng)制轉(zhuǎn)換,即對 cpsr 賦值

14、為0x000000d3 ,只有返回到 svc 態(tài)之后才能得到 原來任務(wù)的 lr ,這個對于任務(wù)切換很重要。還有一個需要留意的問題是在強(qiáng)制 cpsr 變成 svc 態(tài)之后,spsr 也會相應(yīng)地變成 spsr_irq ,這樣就需要在強(qiáng)制轉(zhuǎn)變之前保存 spsr ,也就是被中斷任務(wù)中斷前的 cpsr 。2. 移植中使用的編程技巧ads 編譯器在編譯 c 語言的程序時,如果程序中使用了 main 函數(shù),則編譯器將自動添加如下代碼,完成初始化堆棧和c庫等工作,工作流程如下:1 將執(zhí)行文件中的 ro 段和 rw 段從 load address 復(fù)制到 execution address2 初始化 zi 區(qū)域

15、,用 0 來初始化變量3 跳轉(zhuǎn)到 _rt_entry 執(zhí)行如下 4 個調(diào)用3.1 調(diào)用 _rt_statckheap_init ,建立程序的堆和棧3.2 調(diào)用 _rt_lib_init ,初始化程序用到的 c 庫,并為 main 傳遞參數(shù)3.3 調(diào)用 main ,即用戶程序的入口3.4 調(diào)用 exit因?yàn)橄到y(tǒng)復(fù)位后,在啟動代碼中已經(jīng)設(shè)置了系統(tǒng)堆棧,同時也不需要使用c庫,因此可以從 _rt_entry 處直接跳轉(zhuǎn)到 uc/os-ii 的代碼中,即直接執(zhí)行 main 函數(shù),可以用新的 _rt_entry 來作為鏈接的目標(biāo)入口。 import main export _rt_entry_rt_entry b main這樣在啟動代碼的最后,加入一條跳轉(zhuǎn)語句: bl _main_main 入口是用戶程序執(zhí)行的真正入口,我們利用 armcc 編譯 c 里面的 main 入口以求得到 1 和 2 的代碼,使得可以支持全局變量。否則的話,必須自己來實(shí)現(xiàn)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論