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

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

3天內(nèi)不再提示

使用專業(yè)的嵌入式開發(fā)工具來降低成本并加快上市速度

電子設計 ? 2017-11-10 09:42 ? 次閱讀

從只有幾千字節(jié)存儲空間的簡單 8 位控制器,到現(xiàn)在先進的 32 位控制器,雖然微控制器經(jīng)歷了諸多演變,但是許多開發(fā)人員仍在使用老舊的工具,拖慢了開發(fā)周期。

設計人員若要適應當今快速發(fā)展且復雜多變的開發(fā)環(huán)境,則需要確保擁有合適的工具才能應對。他們需要嵌入式工具,以便監(jiān)視芯片并查看其軟件是否按照預期方式運行;他們還需要可指出錯誤或優(yōu)化代碼規(guī)模的工具,以降低其 BOM 成本。

現(xiàn)在有許多工具可以幫助他們降低整體開發(fā)成本,加快調(diào)試過程,從而縮短上市時間。本文將介紹一些這樣的工具,然后說明如何通過它們獲得最大收益。

利用專業(yè)調(diào)試器節(jié)省時間和金錢

開發(fā)人員編寫的軟件程序第一次試運行就正常工作非常少見。因此軟件開發(fā)需要調(diào)試,所以對于軟件開發(fā)人員來說,最重要的工具就是調(diào)試器。利用調(diào)試器,開發(fā)人員可以將應用程序加載到目標微控制器上,逐步檢查代碼,查看存儲器和其他寄存器,并操縱硬件。

問題是,許多專業(yè)開發(fā)人員通常使用的調(diào)試器是其低成本開發(fā)板所附帶的。這些調(diào)試器方便、便宜,而且在演示時表現(xiàn)完美。但是,在開發(fā)專業(yè)軟件時,可能會出現(xiàn)以下限制:

斷點有限

時鐘速率降低

缺乏跟蹤功能

功能極少

換言之,有時真是一分錢一分貨:附送的簡化工具集可能不是快速有效地開發(fā)和調(diào)試軟件的最佳方式。

專業(yè)級調(diào)試器具有許多功能,可提高工程師的生產(chǎn)力,例如無限制的斷點。許多調(diào)試器只能使用微控制器的內(nèi)部比較器來設置斷點,而在大多數(shù)情況下只有兩個可用。在有數(shù)萬行代碼的復雜程序中,只有兩個可用的斷點可能會導致開發(fā)人員把時間浪費斷點切換上,也可能會導致開發(fā)人員錯過軟件中的關(guān)鍵點,從而錯過潛伏的漏洞。這樣一來,可能會導致編碼時間更長,反而增加了開發(fā)成本并影響了上市時間。

專業(yè)級調(diào)試器提供的算法不僅可以使用硬件斷點,還可以使用軟件和閃存斷點,為開發(fā)人員提供了更多的靈活性,而且用來評估代碼的斷點數(shù)量幾無限制。

當然專業(yè)級調(diào)試器不便宜。它們的價格可以輕松標到幾百到幾千美元。但它們?yōu)殚_發(fā)人員帶來了不可計算的投資回報,并能使用多年,無需升級或更換。選擇調(diào)試器時,開發(fā)人員應該問自己幾個問題:

調(diào)試器的斷點數(shù)是否無限制?

這是一款可以與幾乎所有工具鏈和微控制器配合使用的第三方調(diào)試器嗎?

五年后這個調(diào)試器還能使用嗎?

這個調(diào)試器有很好的生態(tài)系統(tǒng)嗎?

調(diào)試器的能力可以擴展嗎?

因為符合上述標準而變得非常受歡迎的一款第三方調(diào)試器是 Segger J-Link。根據(jù)開發(fā)人員的需求,Segger J-Link 可提供不同的版本。其中包括 J-Link Base Unit、J-Link Plus、J-Link Ultra Plus 和 J-Link Trace(圖 1)。

圖 1:Segger J-Link 調(diào)試器型號比較。(來源:Segger)

使用調(diào)試器跟蹤和分支檢測來揪出潛藏的錯誤

高級調(diào)試器(通常也是最昂貴的)配備 ETM 跟蹤連接器,可以獲得大量跟蹤數(shù)據(jù),這是使用 JTAG 或 SWD 的標準跟蹤無法實現(xiàn)的。

使用高級跟蹤功能,開發(fā)人員可以將調(diào)試器與商業(yè)工具鏈(如適用于 ARMKeil MDK-PRO)連用,來監(jiān)視系統(tǒng)中的每一行代碼在測試期間是否得到執(zhí)行。如下例所示,針對 ARM 的 Keil MDK-PRO 與跟蹤調(diào)試器一并運行,檢測到了那些代碼行在測試期間得到執(zhí)行(圖 2)。這種跟蹤對于需要 100% 測試覆蓋的安全關(guān)鍵型系統(tǒng)非常有用。在未測試代碼之處,可能會潛藏錯誤并在以后導致問題。

圖 2:在調(diào)試模式下運行并對軟件執(zhí)行分支分析的用于 ARM 的 Keil MDK-PRO。左側(cè)的綠色塊表示在測試期間得到執(zhí)行的代碼行。(圖片來源:Keil)

如果開發(fā)人員不想購買成熟的跟蹤工具,則可以使用 SWD 進行跟蹤。在這種情況下,開發(fā)人員可以選擇使用如 Segger 的 SystemView 或 Percepio 的 Tracelyzer 之類軟件工具將跟蹤信息流傳輸?shù)皆?PC 上執(zhí)行的應用程序。這些跟蹤系統(tǒng)通常在 RTOS 中工作,并且需要幾行代碼來設置跟蹤任務、捕獲數(shù)據(jù)并將其發(fā)送到調(diào)試器,然后再發(fā)送到 PC 上。

顯示軟件跟蹤的輸出示例(圖 3)。開發(fā)人員可以使用這些工具來檢測諸如優(yōu)先級轉(zhuǎn)換、死鎖、線程饑餓以及許多在復雜系統(tǒng)中可能遇到的其他問題。每個任務都有一條生命線,顯示其何時就緒、何時執(zhí)行、何時完成,以及在此期間可能發(fā)生的任何事件,例如發(fā)出和接收信號。

專業(yè)開發(fā)人員需要這樣的細節(jié),同樣地,也要求他們使用的調(diào)試工具能夠檢索這類信息。

圖 3:使用如 Percepio 的 Tracealyzer 之類工具檢查軟件操作,并查看執(zhí)行時間和時間長短。(圖片來源:Digi-Key

最大限度利用調(diào)試器的技巧與竅門

調(diào)試工具有很多功能,但有時可能受限于為應用選擇的微控制器。開發(fā)人員需要了解其調(diào)試器的功能,并要將其與微控制器正確配對?,F(xiàn)今的許多調(diào)試器都可與 ARM? Cortex?-M 微控制器配合使用,開發(fā)人員在調(diào)試這些系統(tǒng)時應考慮以下幾個因素:

避免通過 UART 進行 printf。而應使用 ITM 端口來獲得更好的性能

不要逐條查看代碼,使用高級斷點來提高調(diào)試效率

選擇一個通過服務器控制的調(diào)試器,以便為多個應用提供調(diào)試數(shù)據(jù),即自定義分析儀、跟蹤、調(diào)試環(huán)境等等。

調(diào)整調(diào)試器使用的默認時鐘速率,因該速率通常比最大值慢得多

在開發(fā)周期的早期階段設置跟蹤,以建立比較基準

使 SWO 能夠從系統(tǒng)獲取更多信息

在硬件、軟件和閃存斷點之間進行選擇性選擇,以最小化實時性能影響

使用這些技巧可以幫助開發(fā)人員從調(diào)試器及其調(diào)試會話中獲取更多信息。

使用商業(yè)編譯器降低成本

GCC 是一款極受歡迎且大獲成功的編譯器。它與商業(yè)工具相比有一個優(yōu)點就是免費!免費并不意味著編譯器的質(zhì)量和輸出將產(chǎn)生與商業(yè)工具同等的可執(zhí)行代碼。事實上,在許多情況下,將 GCC 與商業(yè)編譯器(如用于 ARM 的 Keil MDK-PRO 或 IAR Embedded Workbench)進行比較,得出的結(jié)果是,GCC 使用的代碼規(guī)模更大,占用的 RAM 空間更多。Renesas 甚至在他們的 Synergy 平臺規(guī)格書中顯示了這一點(圖 4)。

在圖中,Renesas 使用 EEMBC CoreMark? 對其編譯器進行了基準測試,顯示了 IAR 編譯的代碼比 GCC 編譯的代碼更快。

CPU工具鏈時鐘迭代時間(秒)CoremarkDK-S7G2GCC240 MHz1000021.93456GCC200 MHz1000026.32380GCC160 MHz1000029.39340GCC80 MHz600034.59173IAR240 MHz1000014.79676IAR200 MHz1000017.75563IAR160 MHz1000019.18521IAR80 MHz600022.61265DK-S3A7GCC48 MHz1000096.34104GCC24 MHz10000187.3153IAR48 MHz1000063.66157IAR24 MHz10000124.1881DK-S124GCC32 MHz10000199.1750IAR32 MHz10000125.9979

圖 4:Renesas Synergy 平臺 CoreMark? 結(jié)果。Coremark 值越大,性能越好。(來源:Renesas SSP 1.0.0 規(guī)格書)

基準測試還顯示,使用商業(yè)級編譯器可以顯著減少代碼規(guī)模。乍一看,開發(fā)人員可能會認為購買諸如用于 ARM 的 Keil MDK-PRO 之類工具不值得投資,而應該使用 GCC。但是,當開發(fā)人員使用包含 128 KB 代碼空間的微控制器(如 NXP MK20DX128)并發(fā)現(xiàn)使用 GCC 應用程序需要 132 KB 時,會發(fā)生什么?

若發(fā)生這種情況,開發(fā)團隊就被迫要尋找一個具有足夠內(nèi)存但卻更為昂貴的引腳兼容器件,如 NXP MKD20DX256。如果該公司只能生產(chǎn)適量的產(chǎn)品,那么每年花在 MCU 上的成本可能會超過最初投資于商業(yè)編譯器上的成本。

使用商業(yè)編譯器也有其他優(yōu)勢,有助于降低成本,例如:

代碼分析功能,如分支檢測

軟件復雜性測量

高效生成代碼

卓越的調(diào)試工具和功能

技術(shù)支持

集成到驅(qū)動程序庫和框架

結(jié)論

開發(fā)人員當然可以使用免費或便宜的開發(fā)工具。然而問題在于,這些低成本工具在大多數(shù)情況下并非是適合這種工作的最佳工具。它們往往缺乏每個開發(fā)人員所需的高級功能,不能節(jié)省時間和金錢,而且常常會導致項目延遲并增加成本。

購買好的專業(yè)調(diào)試器和工具鏈是一項投資,可以在未來幾年節(jié)省大量時間和金錢,并大幅提高開發(fā)團隊的工作效率和績效。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 嵌入式開發(fā)
    +關(guān)注

    關(guān)注

    18

    文章

    1006

    瀏覽量

    47353
收藏 人收藏

    評論

    相關(guān)推薦

    CC2340系統(tǒng)降低成本的方案剖析

    電子發(fā)燒友網(wǎng)站提供《CC2340系統(tǒng)降低成本的方案剖析.pdf》資料免費下載
    發(fā)表于 08-27 09:43 ?0次下載
    CC2340系統(tǒng)<b class='flag-5'>降低成本</b>的方案剖析

    聚焦嵌入式開發(fā)中的合規(guī)性工具、項目管理工具、版本迭代工具應用

    ,就嵌入式開發(fā)與管理領(lǐng)域的最新趨勢、工具選擇以及DevSecOps實踐應用等方面展開了深入探討。 本期對話龍智資深DevSecOps顧問徐晨暉, 分享嵌入式開發(fā)中的合規(guī)性工具、項目管理
    的頭像 發(fā)表于 07-29 15:15 ?237次閱讀

    嵌入式開發(fā)前景怎么樣?

    嵌入式開發(fā)前景非常廣闊,這主要得益于物聯(lián)網(wǎng)、人工智能、大數(shù)據(jù)等技術(shù)的快速發(fā)展,以及嵌入式系統(tǒng)在各個領(lǐng)域的廣泛應用。以下是對嵌入式開發(fā)前景的詳細分析
    的頭像 發(fā)表于 07-10 09:00 ?1548次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b>前景怎么樣?

    fpga是嵌入式開發(fā)

    FPGA(現(xiàn)場可編程門陣列)與嵌入式開發(fā)之間確實存在一定的關(guān)聯(lián),但它們在本質(zhì)上是兩個不同的領(lǐng)域。
    的頭像 發(fā)表于 03-15 14:18 ?749次閱讀

    嵌入式開發(fā)的轉(zhuǎn)變將如何影響未來計算

    正逐漸演變?yōu)榭筛鶕?jù)所收集的數(shù)據(jù)自行做出決策的系統(tǒng)。相較于在物聯(lián)網(wǎng)網(wǎng)關(guān)或云端進行數(shù)據(jù)處理而言,在更接近采集源之處完成數(shù)據(jù)處理的方式,將有望加快決策速度、減少延遲、解決數(shù)據(jù)隱私問題、降低成本并提高能效。 ? 很多應用領(lǐng)域都在
    發(fā)表于 01-03 14:24 ?320次閱讀

    嵌入式開發(fā)學習的十三法則分享

    嵌入式開發(fā)學習是一個不斷積累和總結(jié)的過程,來自一個嵌入式開發(fā)高級工程師為我們總結(jié)的關(guān)于嵌入式開發(fā)學習的十三法則,大家不妨參考一下: 一、冗余度法則 在嵌入式系統(tǒng)具有足夠的冗余度
    發(fā)表于 12-21 06:32

    電路板pcb打樣降低成本的方法

    電路板pcb打樣降低成本的方法
    的頭像 發(fā)表于 12-13 17:25 ?594次閱讀

    c語言嵌入式開發(fā)

    電子發(fā)燒友網(wǎng)站提供《c語言嵌入式開發(fā).zip》資料免費下載
    發(fā)表于 11-17 14:11 ?2次下載
    c語言<b class='flag-5'>嵌入式開發(fā)</b>

    嵌入式開發(fā)系統(tǒng)基礎知識

    電子發(fā)燒友網(wǎng)站提供《嵌入式開發(fā)系統(tǒng)基礎知識.pdf》資料免費下載
    發(fā)表于 11-17 10:59 ?11次下載
    <b class='flag-5'>嵌入式開發(fā)</b>系統(tǒng)基礎知識

    嵌入式開發(fā)學習路線

    電子發(fā)燒友網(wǎng)站提供《嵌入式開發(fā)學習路線.doc》資料免費下載
    發(fā)表于 11-17 10:13 ?13次下載
    <b class='flag-5'>嵌入式開發(fā)</b>學習路線

    嵌入式開發(fā)學習路線分享

    的實際應用范疇,可以說目前市場上對嵌入式開發(fā)人才的需求越來越大,很多小伙伴都想通過培訓學習的方式走向嵌入式開發(fā)相關(guān)的崗位。下面,小編就給各位小伙伴介紹一個簡單易懂的學
    的頭像 發(fā)表于 11-15 11:51 ?1123次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b>學習路線分享

    windows ce嵌入式開發(fā)入門-基本Xscale架構(gòu)

    電子發(fā)燒友網(wǎng)站提供《windows ce嵌入式開發(fā)入門-基本Xscale架構(gòu).pdf》資料免費下載
    發(fā)表于 11-10 11:18 ?0次下載
    windows ce<b class='flag-5'>嵌入式開發(fā)</b>入門-基本Xscale架構(gòu)

    嵌入式軟件開發(fā)常用工具有哪些?

    的Visual Studio是一個非常流行的開發(fā)工具,提供了強大的IDE,支持C/C++等語言的開發(fā),并且可以配合各種插件進行嵌入式開發(fā)。 5、Eclipse:Eclipse是一個開源的、基于插件的
    發(fā)表于 11-10 11:03

    嵌入式開發(fā)入門學習

    電子發(fā)燒友網(wǎng)站提供《嵌入式開發(fā)入門學習.doc》資料免費下載
    發(fā)表于 10-26 09:37 ?1次下載
    <b class='flag-5'>嵌入式開發(fā)</b>入門學習

    Linux系統(tǒng)的嵌入式開發(fā)是什么

    嵌入式開發(fā)聽起來很高大上,但其實它就在我們身邊。   嵌入式開發(fā)是指將操作系統(tǒng)、應用程序或數(shù)據(jù)存儲在嵌入式設備中,如手機、平板電腦、智能家居等。   隨著物聯(lián)網(wǎng)時代的到來,嵌入式開
    的頭像 發(fā)表于 10-12 15:40 ?1522次閱讀