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

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

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

利用深入洞察分析來測試軟件

工程師兵營 ? 來源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2018-06-27 09:29 ? 次閱讀

嵌入式系統(tǒng)現(xiàn)在變得更加智能,互連程度更高,當然也比以前要復(fù)雜。要讓嵌入式系統(tǒng)保持穩(wěn)健并盡可能接近無錯誤,開發(fā)團隊需要有效的方法來進行測試,驗證系統(tǒng)能否按預(yù)期的方式工作。測試工作中最關(guān)鍵,通常也是難度最高的方面,就是在微控制器上運行軟件。

由于在資源受限的器件上使用最新測試技術(shù)存在困難,微控制器軟件測試通常落后于在基于應(yīng)用處理器的器件上執(zhí)行的測試。但是,由于我們在與傳統(tǒng)測試工具設(shè)計技術(shù)配合使用的調(diào)試技術(shù)方面取得了新進展,嵌入式系統(tǒng)開發(fā)人員現(xiàn)在能夠更加有效地測試系統(tǒng)軟件。

本文將向開發(fā)人員介紹如何使用這些新技術(shù),以及新技術(shù)實施所需的設(shè)備和工具。

嵌入式測試的要求變化

現(xiàn)代嵌入式系統(tǒng)測試工具要求開發(fā)人員采用以下四種主要組件,才能完全測試他們的系統(tǒng)(圖 1):

測試嵌入式系統(tǒng)所需的各種接口和工具的框圖

圖 1: 測試嵌入式系統(tǒng)所需的各種接口和工具,包括調(diào)試器、通信轉(zhuǎn)換器、邏輯分析儀和模數(shù)轉(zhuǎn)換器。(圖片來源:Beningo Embedded Group)

使用這四個組件,開發(fā)人員能夠在系統(tǒng)級別和微控制器級別上測試嵌入式軟件,還可向下深入到由微處理器執(zhí)行的指令。在當今的開發(fā)環(huán)境中,這一點非常關(guān)鍵,旨在確保構(gòu)建的系統(tǒng)不僅能夠滿足需求,還能夠可靠地運行。

初看起來,圖 1 可能類似于非常傳統(tǒng)的嵌入式系統(tǒng)測試工具,但它的進步和新功能真正源于一種分析微控制器中運行情況的全新方式,稱為“深入洞察分析”(Deep Insight Analysis)。

利用深入洞察分析來測試軟件

深入洞察分析讓開發(fā)人員能夠在運行時分析系統(tǒng)。深入洞察分析有三個關(guān)鍵組成部分:

  • RTOS 感知的調(diào)試

  • 運行時分析

  • 剖析和代碼覆蓋分析

開發(fā)人員通常在設(shè)計應(yīng)用之后,使用基本調(diào)試技術(shù)(例如斷點調(diào)試)嘗試了解系統(tǒng)的工作情況,隨后立即開始測試。在存在斷點的情況下進行測試只流于表面,無法讓開發(fā)人員真正了解微控制器中的運行情況。使用深入洞察分析,開發(fā)人員能夠在基本測試和調(diào)試之外更深入地挖掘 RTOS、運行時行為、執(zhí)行分析和覆蓋(圖 2)。

深入洞察分析不僅限于基本測試和調(diào)試的圖片

圖 2: 深入洞察分析能夠在基本測試和調(diào)試之外更深入地挖掘 RTOS、運行時行為、執(zhí)行分析和覆蓋。(圖片來源: Beningo Embedded Group)

要為測試工具添加深入洞察分析功能,開發(fā)人員必須使用專業(yè)調(diào)試工具,例如 Segger Microcontroller Systems、J-Trace 或 J-Link Ultra+(圖 3)。J-Link Ultra+ 使用標準的 JTAG 或 SWD 接口,從板載調(diào)試模塊提取跟蹤數(shù)據(jù)。這些信息可用于執(zhí)行多種不同分析,例如 RTOS 感知的調(diào)試。

圖 3: Segger 的 J-Link Ultra+ 使用標準的 JTAG 或 SWD 接口,從板載調(diào)試模塊提取跟蹤數(shù)據(jù)。(圖片來源: Segger Microcontroller Systems)

使用 RTOS 感知的調(diào)試,開發(fā)人員能夠在執(zhí)行測試案例時監(jiān)控任務(wù)的執(zhí)行情況。例如開發(fā)人員能夠深入了解以下情況:

  • 最大堆棧使用

  • 任務(wù)運行計數(shù)

  • 任務(wù)狀態(tài)

圖 4 顯示了結(jié)合使用 Segger 的 embOS RTOS 和 Embedded Studio 的測試會話示例。此視圖可以讓開發(fā)人員深入了解 RTOS 的運行情況,但無法提供應(yīng)用運行情況的完整信息。

Segger 的 embOS RTOS 和 Embedded Studio IDE 的圖片

圖 4: 使用 Segger 的 embOS RTOS 和 Embedded Studio IDE 的 RTOS 感知調(diào)試的示例(圖片來源:Beningo Embedded Group)

開發(fā)人員可以使用 Segger 的免費 SystemView 實用工具或 Percepio 的 Tracealyzer 工具,進一步增強測試工具。這些工具為開發(fā)人員提供運行時分析,以便他們在運行測試套件時,直觀地查看和分析應(yīng)用的執(zhí)行情況。為了采集這些跟蹤數(shù)據(jù),開發(fā)人員需要配置他們的應(yīng)用,以便在 IDE 內(nèi)部進行跟蹤,或者使用配置工具進行跟蹤。如果沒有使用工具,他們可以手動集成低級別庫。

運行時分析可為開發(fā)人員提供有關(guān)應(yīng)用運行情況的豐富信息(圖 5)。例如,開發(fā)人員能夠:

  • 跟蹤事件的時間和順序

  • 獲取最大、最小和平均的執(zhí)行時間

  • 直觀地查看任務(wù)執(zhí)行,以及任務(wù)何時切換

  • 監(jiān)控 CPU 負載

  • 分析任務(wù)統(tǒng)計數(shù)據(jù)

  • 識別潛在問題,例如優(yōu)先級反轉(zhuǎn)、任務(wù)抖動和死鎖

使用跟蹤工具 SystemView 進行的運行時分析的圖片

圖 5: 使用跟蹤工具 SystemView 進行的運行時分析。(圖片來源:Beningo Embedded Group)

雖然為測試工具添加了 RTOS 感知的調(diào)試和運行時分析功能,但這可能還不足夠。在很多實例中,錯誤可能隱藏在測試過程中從不執(zhí)行的代碼中。對于開發(fā)人員而言,了解哪些代碼行已經(jīng)執(zhí)行過可能非常困難。在這一方面,J-Trace 等工具為我們帶來了很多便利。

如何跟蹤已執(zhí)行代碼

J-Trace 使用微控制器中的嵌入式跟蹤宏單元 (ETM) 端口來執(zhí)行指令跟蹤。通過指令跟蹤,J-Trace 能夠“看到”在處理器上執(zhí)行的每一個 CPU 指令,以及代碼的準確路徑。

在測試工具中使用這種分析,開發(fā)人員能夠確定測試案例是否達到了 80%、90% 或 100% 的代碼覆蓋率。如果測試覆蓋率只有 95%,但又必須達到 100% 的覆蓋率才能交付產(chǎn)品,他們可以使用類似于 Ozone 的免費實用工具,查看哪些代碼行已經(jīng)執(zhí)行,更重要的是查看哪些代碼行尚未執(zhí)行(圖 6)。然后可以添加新的測試案例,確保這些遺漏的代碼行在測試中得到執(zhí)行。

使用 Ozone 執(zhí)行代碼分析的圖片

圖 6: 使用 Ozone 執(zhí)行代碼分析。(圖片來源:Beningo Embedded Group)

借助深入洞察分析提供的強大工具,開發(fā)人員現(xiàn)在能夠自由專注于構(gòu)建有效測試工具所必需的其他組件。測試工具的另一個至關(guān)重要的組件是在測試過程中用于與微控制器通信并控制其行為的工具。

命令和控制嵌入式系統(tǒng)

對于如何與外界進行交互,每個嵌入式都有不同的需求。有些器件可能通過簡單的 UART 進行通信,而其他器件則可能使用 CAN 或 TCP/IP。為了成功地構(gòu)建能夠與系統(tǒng)進行通信并讓其執(zhí)行命令的測試工具,開發(fā)人員必須在測試工具中增加通信硬件和軟件。

雖然嵌入式系統(tǒng)使用了大量不同的通信接口,但其中一種接口比其他任何接口都更加常用,那就是 UART。嵌入式軟件開發(fā)人員習(xí)慣使用 UART,將這種接口包括在測試工具中很重要,原因有幾個,其中包括:

  • 為了調(diào)試信息,例如打印消息(雖然這些信息應(yīng)該通過調(diào)試器發(fā)送)

  • 設(shè)備發(fā)出命令

  • 監(jiān)控多個器件之間的內(nèi)部通信

  • 易于使用

每個開發(fā)人員都應(yīng)在實驗室常備的一種通用 UART 工具是由 SparkFun Electronics 提供的 BOB-12731 FT232R, USB-to-UART 評估板(圖 7)。

圖 7: 來自 SparkFun Electronics 的 BOB-12731 FT232R, USB-to-UART 評估板在任何實驗室中都非常實用,因為它可以輕松連接到任何嵌入式系統(tǒng)。(圖片來源: SparkFun Electronics)

這些價格低廉的評估板可以輕松連接到任何嵌入式系統(tǒng),并在 PC 上作為簡單的通信端口。它不需要任何特殊驅(qū)動程序或軟件就能與嵌入式系統(tǒng)進行通信。開發(fā)人員只需打開 COM 端口即可開始發(fā)送和接收測試消息。

驗證每個邏輯狀態(tài)

要對嵌入式系統(tǒng)進行完全測試,就需要開發(fā)人員驗證微控制器的內(nèi)部工作情況,以及它產(chǎn)生的外部邏輯。這種邏輯可能是簡單的輸入和輸出狀態(tài),以及低級別通信,例如 I2C 或 SPI。

但是,如果開發(fā)人員使用模數(shù)轉(zhuǎn)換器 (ADC) 和數(shù)模轉(zhuǎn)換器 (DAC) 板,則監(jiān)控輸入/輸出狀態(tài)和低級別通信可能成本高昂。開發(fā)人員可以利用一些技巧來降低成本,以便監(jiān)控這些信號和改進測試功能。

第一個技巧是使用來自系統(tǒng)上的微控制器的開發(fā)板,來監(jiān)控微控制器引腳。例如,如果開發(fā)人員使用 STMicroelectronics STM32F767 或 STM32L4 微控制器,則他們應(yīng)該首先購買 STM32F767 Nucleo 板 或 STM32L476RGT6 Nucleo 板(圖 8)。

圖 8: STM32L476RGT6 Nucleo 板可用于監(jiān)控 STM32L4 微控制器上的引腳。(圖片來源:STMicroelectronics)

然后,他們應(yīng)該使用板上的針座,直接將每個 I/O 引腳跳轉(zhuǎn)到系統(tǒng)上的相應(yīng)引腳。由于他們已經(jīng)為微控制器開發(fā)了低級別驅(qū)動程序,因此可以輕松地調(diào)節(jié)這些驅(qū)動程序,以便監(jiān)控微控制器的輸入和輸出狀態(tài)。

開發(fā)人員還可以添加少量額外代碼,例如 USB 驅(qū)動程序,這樣開發(fā)板就能夠直接插入到測試主機。USB 可用于接收輸入/輸出樣本狀態(tài)數(shù)據(jù),隨后這些數(shù)據(jù)可以關(guān)聯(lián)至從系統(tǒng)發(fā)出和接收命令,以確定工作情況是否完全符合預(yù)期。

除了使用開發(fā)板之外,測試工具也可以使用邏輯探頭,例如同樣來自 SparkFun 的 Logic Pro 8(圖 9)。

圖 9: Logic Pro 8 是來自 SparkFun Electronics 的多功能邏輯探頭,讓開發(fā)人員能夠針對要監(jiān)控的對象,對每個輸入進行編程。(圖片來源: SparkFun Electronics)

這些邏輯分析儀具有多功能性,在要監(jiān)控的對象方面,可通過軟件對每個輸入進行修改。例如,開發(fā)人員可設(shè)置前兩個輸入來監(jiān)控開關(guān)輸入,同時使用接著的兩個輸入來監(jiān)控 I2C 通信,并使用剩余的輸入來監(jiān)控 SPI。數(shù)據(jù)可以輕松采集,然后與測試工具的剩余組件進行同步,從而讓我們?nèi)媪私馇度胧较到y(tǒng)的工作情況。

構(gòu)建測試工具的技巧和訣竅

顯而易見,測試工具對于很多現(xiàn)代嵌入式系統(tǒng)是必不可少的。獲得認證有時可能非常困難,但認證產(chǎn)生的回報和帶來的系統(tǒng)穩(wěn)健性提升的價值會數(shù)倍于投資成本。在首次構(gòu)建測試工具時,甚至在升級測試工具時,開發(fā)人員可以利用多種技巧,確保構(gòu)建最有效的測試工具。其中包括:

  • 使用與主要目標相同的處理器的開發(fā)套件,來監(jiān)控微控制器的數(shù)字輸入和輸出

  • 在支持跟蹤功能的調(diào)試器上進行投資,并利用免費的軟件包,以最深入地了解系統(tǒng)運行情況

  • 運行軟件跟蹤時,請務(wù)必使用最壞情況測試,以確保您能夠獲取最壞情況場景

  • 如果沒有足夠的資金來構(gòu)建完善的測試工具,首先構(gòu)建較小的測試工具,然后隨著時間推移加以完善。哪怕只進行一部分測試,也強于沒有進行測試。

  • 花費必要的時間掌握要在測試工具中使用的不同工具和組件

  • 不要害怕構(gòu)建您自己的接口,要充分利用現(xiàn)有軟件來監(jiān)控系統(tǒng)運行情況

  • 不要做出任何假設(shè)!如果您沒有監(jiān)控輸出或觸發(fā)輸入,則很可能讓錯誤乘虛而入。

總結(jié)

為嵌入式系統(tǒng)開發(fā)測試工具,是一種改進嵌入式系統(tǒng)可靠性的低成本方法。精心選擇測試工具的組件,可以讓開發(fā)人員輕松監(jiān)控軟件的外部行為。測試的最關(guān)鍵而又經(jīng)常易于忽略的環(huán)節(jié)是檢查跟蹤數(shù)據(jù),現(xiàn)在這些數(shù)據(jù)可從微控制器輕松訪問。使用這些跟蹤數(shù)據(jù),開發(fā)人員能夠執(zhí)行深入洞察分析,同時執(zhí)行他們的測試案例,以確保其軟件即使針對個別指令也能按預(yù)期工作。

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

    關(guān)注

    5087

    文章

    19158

    瀏覽量

    306446
  • RTOS
    +關(guān)注

    關(guān)注

    22

    文章

    817

    瀏覽量

    119767
  • 調(diào)試器
    +關(guān)注

    關(guān)注

    1

    文章

    305

    瀏覽量

    23783
收藏 人收藏

    評論

    相關(guān)推薦

    如何利用emulation提升軟件測試效率

    隨著技術(shù)的發(fā)展,軟件變得越來越復(fù)雜,對測試的要求也越來越高。傳統(tǒng)的測試方法往往需要大量的硬件資源和時間,而emulation技術(shù)提供了一種更高效、成本更低的測試解決方案。 1. Emu
    的頭像 發(fā)表于 12-05 15:51 ?191次閱讀

    是德矢量網(wǎng)絡(luò)分析儀的線性度測試

    至關(guān)重要。是德科技矢量網(wǎng)絡(luò)分析儀憑借其高精度、寬頻帶和強大的軟件功能,成為進行線性度測試的首選儀器。本文將重點介紹如何利用是德矢量網(wǎng)絡(luò)分析
    的頭像 發(fā)表于 11-27 16:43 ?310次閱讀
    是德矢量網(wǎng)絡(luò)<b class='flag-5'>分析</b>儀的線性度<b class='flag-5'>測試</b>

    嵌入軟件單元/集成測試工具專業(yè)分析

    軟件開發(fā)設(shè)計的單元測試工具,其獨特的功能和優(yōu)勢使其在市場中占據(jù)了一席之地。本文將對WinAMS進行深入分析,并將其與其他測試工具進行對比,探討其在功能、易用性和兼容性等方面的優(yōu)點。 1
    的頭像 發(fā)表于 11-19 16:41 ?269次閱讀

    Simcenter Testlab測試分析軟件

    SimcenterTestlabSimcenterTestlab是一個將數(shù)據(jù)采集與測試分析工具相結(jié)合的集成式解決方案,能夠有效提高測試效率并提供更可靠的結(jié)果。SimcenterTestlab
    的頭像 發(fā)表于 11-12 16:10 ?362次閱讀
    Simcenter Testlab<b class='flag-5'>測試</b><b class='flag-5'>分析</b><b class='flag-5'>軟件</b>

    矢量網(wǎng)絡(luò)分析軟件精準測試天線

    自動化測試方法是通過系統(tǒng)集成的方式實現(xiàn),通過軟件程控網(wǎng)分等硬件設(shè)備完成S參數(shù)測試。NSAT-1000是專門針對各類射頻器件性能
    的頭像 發(fā)表于 08-29 17:50 ?389次閱讀
    矢量網(wǎng)絡(luò)<b class='flag-5'>分析</b>儀<b class='flag-5'>軟件</b>精準<b class='flag-5'>測試</b>天線

    FLEXBENCH通用測試軟件平臺

    1.簡介 FlexBench是锘華儀器針對航空航天等領(lǐng)域的測試需求研制開發(fā)的通用測試軟件平臺。 FlexBench為用戶提供海量接口,支持用戶自主定制測試任務(wù),一鍵自動化執(zhí)行
    的頭像 發(fā)表于 08-06 14:04 ?287次閱讀
    FLEXBENCH通用<b class='flag-5'>測試</b><b class='flag-5'>軟件</b>平臺

    軟件測試六大問 全面而深入軟件測試行業(yè)解疑

    隨著科技的進步和大數(shù)據(jù)時代的到來,?軟件測試面臨著前所未有的挑戰(zhàn)和機遇。?在這篇文章中我們將深入討論軟件測試行業(yè)的發(fā)展前景、行業(yè)趨勢、薪資水
    的頭像 發(fā)表于 07-30 10:28 ?313次閱讀

    動態(tài)追溯方法:徹底革新軟件測試

    動態(tài)追溯方法為解決軟件開發(fā)中追溯的挑戰(zhàn)提供了創(chuàng)新的解決方案。通過自動和動態(tài)地鏈接需求和測試用例,使測試過程顯著提高效率和精確度。該方法減少了手工操作,改善了故障分析,并確保了持續(xù)的追溯
    的頭像 發(fā)表于 07-05 17:40 ?434次閱讀
    動態(tài)追溯方法:徹底革新<b class='flag-5'>軟件</b><b class='flag-5'>測試</b>

    利用NVIDIA的nvJPEG2000庫分析DICOM醫(yī)學(xué)影像的解碼功能

    本文將深入分析 DICOM 醫(yī)學(xué)影像的解碼功能。AWS HealthImaging 利用 NVIDIA 的 nvJPEG2000 庫實現(xiàn)此功能。
    的頭像 發(fā)表于 05-28 14:27 ?854次閱讀
    <b class='flag-5'>利用</b>NVIDIA的nvJPEG2000庫<b class='flag-5'>分析</b>DICOM醫(yī)學(xué)影像的解碼功能

    電源芯片測試系統(tǒng):確保電源管理芯片的性能與安全

    納米軟件電源管理芯片測試系統(tǒng)旨在為4644電源芯片以及其它各類電源管理芯片提供自動化測試方案。區(qū)別于傳統(tǒng)自動化測試系統(tǒng),該系統(tǒng)集運行測試、數(shù)
    的頭像 發(fā)表于 05-22 18:41 ?510次閱讀
    電源芯片<b class='flag-5'>測試</b>系統(tǒng):確保電源管理芯片的性能與安全

    如何利用矢量網(wǎng)絡(luò)分析儀對新材料進行阻抗匹配測試?

    利用矢量網(wǎng)絡(luò)分析儀(VNA)對新材料進行阻抗匹配測試是高頻電路設(shè)計和新材料研發(fā)中的一個重要環(huán)節(jié)。
    的頭像 發(fā)表于 05-17 15:58 ?1236次閱讀

    仿真測試軟件測試的區(qū)別

    在當今軟件開發(fā)和驗證的領(lǐng)域中,測試是保證軟件質(zhì)量的關(guān)鍵環(huán)節(jié)。而在測試的眾多方法中,仿真測試軟件
    的頭像 發(fā)表于 05-17 14:33 ?949次閱讀

    納米軟件自動化測試合作:4644芯片與VPX模塊測試

    近日,納米軟件與西安廣勤電子技術(shù)有限公司就4644電源芯片自動化測試和VPX電源自動化測試達成戰(zhàn)略合作。在雙方進行深入探討后,納米軟件為廣勤
    的頭像 發(fā)表于 05-09 15:49 ?487次閱讀
    納米<b class='flag-5'>軟件</b>自動化<b class='flag-5'>測試</b>合作:4644芯片與VPX模塊<b class='flag-5'>測試</b>

    深入解析與無線通信RFIC設(shè)計與測試實用指南

    深入解析與無線通信RFIC設(shè)計與測試實用指南
    發(fā)表于 04-16 11:03 ?341次閱讀
    <b class='flag-5'>深入</b>解析與無線通信RFIC設(shè)計與<b class='flag-5'>測試</b>實用指南

    2024年小米汽車產(chǎn)業(yè)鏈分析及新品上市全景洞察報告

    2024年小米汽車產(chǎn)業(yè)鏈分析及新品上市全景洞察報告 *附件:小米汽車全面洞察報告.pdf 本文主要介紹了小米汽車在市場中的布局和優(yōu)勢,以及其面臨的劣勢與挑戰(zhàn)。小米汽車憑借品牌、技術(shù)和成本三大核心優(yōu)勢
    發(fā)表于 03-29 13:46