電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>嵌入式開發(fā)>多核軟件調(diào)試方法與困難

多核軟件調(diào)試方法與困難

2017-10-19 | rar | 0.6 MB | 次下載 | 1積分

資料介紹

對(duì)于嵌入式裝置而言,多核技術(shù)可以提供更高的處理器性能、更有效的電源利用率,并且占用更少的物理空間,因而具有許多優(yōu)勢(shì)。
  要想充分發(fā)揮多核以及多處理解決方案的潛能,僅僅擁有高性能的芯片是不夠的,還需要采用新的編程方法、調(diào)試方法和工具。在傳統(tǒng)上,JTAG調(diào)試技術(shù)主要是用于硬件Bring-Up,如今也常常被用于配合基于代理的調(diào)試(agent-based debugging)。然而,在多核和多處理的環(huán)境中,片上調(diào)試(on-chip debugging)正在扮演著越來越重要的角色。
  多核軟件調(diào)試的難點(diǎn)所在
  多核環(huán)境顯著增加了系統(tǒng)復(fù)雜度,因此在對(duì)操作系統(tǒng)和與多核相關(guān)的硬件進(jìn)行調(diào)試的時(shí)候,就必須采用一整套更有效的工具。在嵌入式軟件開發(fā)工作中,多核主要呈現(xiàn)為多處理的形式,而這些處理器的內(nèi)核不一定要處在同一個(gè)芯片之中。不論這些處理器內(nèi)核是在同一個(gè)芯片之中,或者是分布在同一個(gè)電路板中的多個(gè)芯片之中,甚至是同一個(gè)系統(tǒng)中的多個(gè)電路板之中,開發(fā)人員都必須解決好多處理環(huán)境中的調(diào)試問題。
  多核與多處理技術(shù)為系統(tǒng)調(diào)試帶來了許多新的挑戰(zhàn),因?yàn)橄到y(tǒng)復(fù)雜度不斷增加,要通過優(yōu)化硬件和軟件來充分發(fā)揮其中的性能潛力,難度就更大了。其中最主要的挑戰(zhàn)來自以下幾個(gè)方面:第一,有效地管理內(nèi)存和外設(shè)等共享資源;第二,在多內(nèi)核、多電路板和多操作系統(tǒng)的環(huán)境中對(duì)操作系統(tǒng)和應(yīng)用代碼進(jìn)行調(diào)試;第三,優(yōu)化JTAG接口并充分利用JTAG帶寬;第四,調(diào)試單一芯片中的同構(gòu)和異構(gòu)多核,進(jìn)而實(shí)現(xiàn)整個(gè)系統(tǒng)的協(xié)同調(diào)試;第五,有效地利用JTAG與基于代理的調(diào)試方法,確保不同調(diào)試工具之間的順暢協(xié)同;第六,確保多核環(huán)境中應(yīng)用調(diào)試的同步機(jī)制。
  在多核調(diào)試中,主要是在解決一個(gè)核心問題——由SoC廠商所提供的JTAG接口所造成的局限性。為了節(jié)省成本,許多SoC廠商都只為芯片提供單一的JTAG接口,而不理會(huì)其中包含了多少個(gè)內(nèi)核。對(duì)于開發(fā)者來說,最大的挑戰(zhàn)就是經(jīng)濟(jì)有效地使用這些接口來同步多核以及多處理的調(diào)試工作,而經(jīng)常用到的就是采用IEEE 1149.1標(biāo)準(zhǔn)daisy-chain方法。
  在JTAG接口中有4條線:TDI、TDO、TCK和TMS。為了在多核調(diào)試中能夠與LTAG接口相連,主要涉及到TDI和TDO。在daisy-chain中,前一個(gè)內(nèi)核的輸出被連接到后一個(gè)內(nèi)核的輸入,以這種方式連接,直到抵達(dá)所有的內(nèi)核。daisy-chain方法是基于標(biāo)準(zhǔn)的,得到了廣泛的應(yīng)用,并且在所有的多核環(huán)境中都是有效的。
  在daisy-chain方法中,JTAG調(diào)試器利用JTAG服務(wù)器的軟件接口來解決多核環(huán)境中經(jīng)常遇到的JTAG連接受限問題。不論內(nèi)核位于何處,JTAG服務(wù)器都可通過JTAG接口來實(shí)現(xiàn)每個(gè)內(nèi)核的編址。JTAG服務(wù)器也幫助開發(fā)者實(shí)現(xiàn)同一個(gè)JTAG下的內(nèi)核同步、進(jìn)程的起始與停止以及連接的增加和移除,而且不會(huì)影響到掃描鏈(Scan-Chain)中的處理器或整個(gè)系統(tǒng)。這種方法可以保持精確的時(shí)鐘,同時(shí)為跨越多個(gè)內(nèi)核的不同操作系統(tǒng)或者同一個(gè)操作系統(tǒng)中不同進(jìn)程的調(diào)試提供便利,而daisy-chain方法的核心目標(biāo)是性能和JTAG帶寬的充分利用。
  daisy-chain方法中JTAG的主要問題是在Shift-IR階段發(fā)送的數(shù)據(jù)量取決于在掃描鏈中發(fā)出數(shù)據(jù)的裝置數(shù)量以及每個(gè)設(shè)備的IR長度。例如,在一個(gè)包含3個(gè)裝置的daisy-chain中訪問一個(gè)8位IR寄存器需要24Bit的數(shù)據(jù)量。這類問題對(duì)于DR同樣存在,但由于一個(gè)處于 bypass模式的裝置在Shift-DR階段實(shí)際上只需要1bit的數(shù)據(jù),從而使這類問題的影響變得比較小。如果JTAG服務(wù)器能夠設(shè)計(jì)得恰如其分,幾乎就可以避免對(duì)性能造成任何影響。這也正是Wind River所提供的JTAG解決方案的最大特色。
  OCD是多核調(diào)試?yán)?br />   單一調(diào)試器的主流方法仍然是JTAG多路技術(shù)。這種技術(shù)對(duì)IEEE JTAG標(biāo)準(zhǔn)規(guī)范進(jìn)行了拓展,以便為通過共享JTAG接口連接起來的每個(gè)內(nèi)核提供獨(dú)立的調(diào)試器。在多路技術(shù)的支持下,通過對(duì)希望調(diào)試的內(nèi)核進(jìn)行注冊(cè)登記(Registering),開發(fā)人員可經(jīng)由單一JTAG接口訪問多個(gè)離散狀態(tài)的內(nèi)核。這種解決方案的最大優(yōu)勢(shì)在于它的連接和調(diào)試性能。因?yàn)槎嗦芳夹g(shù)單獨(dú)連接到每個(gè)內(nèi)核,因而避免了daisy-chaining方法中所遇到的比特位移(bit shifting)方面的麻煩,因而在單芯片中的多核系統(tǒng)中具有更高的性能。這種方式的另一個(gè)好處是不需要對(duì)開發(fā)工具進(jìn)行修改,從而可以順暢地應(yīng)用在多個(gè)開發(fā)項(xiàng)目之中。
  多路技術(shù)方法所存在的主要問題是在多內(nèi)核調(diào)試過程中無法同時(shí)啟動(dòng)和停止內(nèi)核來同步應(yīng)用。如果要停止全部內(nèi)核,開發(fā)人員只能順序地逐個(gè)進(jìn)行,這就引發(fā)了調(diào)用延遲問題。在調(diào)試過程中的延遲問題,會(huì)導(dǎo)致很難在內(nèi)核之間的操作系統(tǒng)、中間件和應(yīng)用中找到發(fā)生問題的確切位置,特別是當(dāng)運(yùn)行在不同內(nèi)核之中的應(yīng)用存在相互依賴性的時(shí)候,這個(gè)問題就更為突出。例如,某個(gè)產(chǎn)品包含DSP功能和ARM 9內(nèi)核,其中DSP用來處理視頻流,ARM 9內(nèi)核提供文件系統(tǒng),那么內(nèi)核的啟動(dòng)與停止同步將會(huì)十分關(guān)鍵。如果調(diào)試過程中在ARM內(nèi)核的啟動(dòng)和DSP的停止之間出現(xiàn)過多的延遲,DSP視頻流數(shù)據(jù)很快就會(huì)溢滿ARM文件緩沖區(qū),而視頻流也將會(huì)中止。如果出現(xiàn)這種情況,就很難判斷系統(tǒng)中的問題出在哪里。而且,多路進(jìn)程也給開發(fā)人員在故障排除時(shí)帶來了許多新的問題,將會(huì)大幅度增加調(diào)試時(shí)間。
  另外,如果在有多個(gè)廠商芯片組成的異構(gòu)多核環(huán)境中進(jìn)行調(diào)試工作,例如處理器來自一個(gè)廠商,而DSP器件來自另一個(gè)廠商,還會(huì)有更復(fù)雜的問題需要處理。因?yàn)檫@種情況下的多路(Muxing)機(jī)制更為復(fù)雜,如果各部分之間的兼容性沒有得到保證,也就很難保證系統(tǒng)正常運(yùn)行。此時(shí),僅僅依靠多路技術(shù)是無法解決問題的,開發(fā)人員就需要采用可編址掃描端口addressable scan port),這也可能是最后僅有的方法了。這種架構(gòu)需要用到非常特殊的組件,這些組件可以讓開發(fā)人員把JTAG掃描鏈分割成多個(gè)功能組,并通過唯一的地址來訪問每個(gè)功能組。這是一種多支路(multi-drop)架構(gòu),經(jīng)常被用于底板(Backplane)環(huán)境之中。在這里,有一個(gè)分別可編址的掃描鏈在底板內(nèi)實(shí)現(xiàn)路由(Routed),從而使機(jī)箱中的每個(gè)底板都擁有自己專屬的掃描鏈。這種架構(gòu)的運(yùn)行速度受限于可編址掃描端口的速度,最典型的情況是25MHz。
  總之,在多核開發(fā)中,JTAG調(diào)試可以承擔(dān)非常有價(jià)值的角色,有效地改善“編輯-編譯-調(diào)試” 周期時(shí)間。然而,實(shí)現(xiàn)這一點(diǎn)的前提是把JTAG調(diào)試與基于標(biāo)準(zhǔn)的集成化開發(fā)環(huán)境(例如Eclipse)緊密地集成起來。最理想的技術(shù)方案是,在Daisy Chain中采用遵從IEEE 1149.1 JTAG標(biāo)準(zhǔn)的單一的JTAG調(diào)試器,而JTAG的主要作用是改善系統(tǒng)的吞吐能力和性能。在On-Chip Debugging(片上調(diào)試)方面,Wind River可以提供獨(dú)有的能力,在其產(chǎn)品中有效地集成了基于代理的調(diào)試技術(shù),從而幫助開發(fā)人員,即使在面臨非常復(fù)雜的系統(tǒng)時(shí),也可以極大地改善調(diào)試工作效率。
  利用Wind River提供的JTAG解決方案,也就是Workbench On-Chip Debugging,開發(fā)人員可以同時(shí)停止或者啟動(dòng)任何內(nèi)核,在一個(gè)或者多個(gè)內(nèi)核上設(shè)置斷點(diǎn),其中還可以包括條件斷點(diǎn)。此外,Workbench Eclipse框架和基于代理的調(diào)試方式使開發(fā)人員在單一控制臺(tái)上即可管理多內(nèi)核/多處理應(yīng)用的開發(fā)。開發(fā)人員可以在JTAG調(diào)試和基于代理調(diào)試二者之間靈活地選擇,例如在硬件Bring-Up、內(nèi)核、中間件和其他應(yīng)用功能調(diào)試的時(shí)候采用JTAG連接,然后在自己認(rèn)為適當(dāng)?shù)臅r(shí)機(jī)平滑地轉(zhuǎn)移到基于代理的調(diào)試,而這些調(diào)試工作都是圍繞著同一個(gè)應(yīng)用的。這些能力都會(huì)增加不同開發(fā)人員之間的協(xié)同能力,同時(shí)改善異常問題的判定效率,從而加快整個(gè)開發(fā)與調(diào)試進(jìn)程。
?
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

  1. 1TC358743XBG評(píng)估板參考手冊(cè)
  2. 1.36 MB  |  330次下載  |  免費(fèi)
  3. 2開關(guān)電源基礎(chǔ)知識(shí)
  4. 5.73 MB  |  6次下載  |  免費(fèi)
  5. 3100W短波放大電路圖
  6. 0.05 MB  |  4次下載  |  3 積分
  7. 4嵌入式linux-聊天程序設(shè)計(jì)
  8. 0.60 MB  |  3次下載  |  免費(fèi)
  9. 5基于FPGA的光纖通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
  10. 0.61 MB  |  2次下載  |  免費(fèi)
  11. 6基于FPGA的C8051F單片機(jī)開發(fā)板設(shè)計(jì)
  12. 0.70 MB  |  2次下載  |  免費(fèi)
  13. 751單片機(jī)窗簾控制器仿真程序
  14. 1.93 MB  |  2次下載  |  免費(fèi)
  15. 8基于51單片機(jī)的RGB調(diào)色燈程序仿真
  16. 0.86 MB  |  2次下載  |  免費(fèi)

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費(fèi)
  3. 2555集成電路應(yīng)用800例(新編版)
  4. 0.00 MB  |  33564次下載  |  免費(fèi)
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費(fèi)
  7. 4開關(guān)電源設(shè)計(jì)實(shí)例指南
  8. 未知  |  21548次下載  |  免費(fèi)
  9. 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費(fèi)
  11. 6數(shù)字電路基礎(chǔ)pdf(下載)
  12. 未知  |  13750次下載  |  免費(fèi)
  13. 7電子制作實(shí)例集錦 下載
  14. 未知  |  8113次下載  |  免費(fèi)
  15. 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德爾著
  16. 0.00 MB  |  6653次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費(fèi)
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537796次下載  |  免費(fèi)
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420026次下載  |  免費(fèi)
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費(fèi)
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費(fèi)
  11. 6電路仿真軟件multisim 10.0免費(fèi)下載
  12. 340992  |  191185次下載  |  免費(fèi)
  13. 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
  14. 158M  |  183278次下載  |  免費(fèi)
  15. 8proe5.0野火版下載(中文版免費(fèi)下載)
  16. 未知  |  138040次下載  |  免費(fèi)