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

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

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

嵌入式代碼覆蓋率統(tǒng)計方法和經(jīng)驗

Q4MP_gh_c472c21 ? 來源:嵌入式ARM ? 作者:嵌入式ARM ? 2021-01-06 15:06 ? 次閱讀

代碼覆蓋率是衡量軟件測試完成情況的指標(biāo),通?;跍y試過程中已檢查的程序源代碼比例計算得出。代碼覆蓋率可以有效避免包含未測試代碼的程序被發(fā)布。

1. 問題背景

代碼覆蓋(Code coverage)是軟件測試中的一種度量,描述程式中源代碼被測試的比例和程度,所得比例稱為代碼覆蓋率。 在進行代碼測試時,常常使用代碼覆蓋率作為考核測試任務(wù)完整性的指標(biāo),并且代碼覆蓋率也被拿來作為衡量代碼質(zhì)量的度量,甚至客戶常常要求交付的軟件達到一定的代碼覆蓋率才能進行發(fā)布,因此代碼覆蓋率統(tǒng)計尤為重要。 C語言嵌入式軟件的開發(fā)與普通的軟件的開發(fā)很大的不同點就是需要采用交叉開發(fā)的方式,即開發(fā)工具運行在軟硬件配置豐富的編譯機上,而嵌入式應(yīng)用程序則運行在軟硬件資源相對缺乏的目標(biāo)機上。面對C語言的覆蓋率工具相對java等語言較少,而對嵌入式軟件交叉編譯后的工具更是鳳毛麟角,所以嵌入式軟件的代碼覆蓋率就成為了一個難題。

2. 解決方法

2.1 覆蓋率工具

嵌入式開發(fā)一般使用GNU/GCC作為主要的編譯器,GCOV是一個GNU/GCC的配套測試覆蓋率的工具,是一款的免費的代碼覆蓋率測試工具,而且可以結(jié)合LCOV生成美觀的html的測試報表。當(dāng)對目標(biāo)代碼進行測試后,GCOV編譯插樁后的程序會監(jiān)視目標(biāo)代碼的執(zhí)行情況,記錄執(zhí)行的代碼行和未執(zhí)行的代碼行,并可以記錄某代碼行的執(zhí)行次數(shù),為分析代碼的執(zhí)行效率提供依據(jù)。 LCOV是GCOV的一個擴展工具,該擴展工具由一套Perl腳本組成,使基于GCOV的文本式輸出實現(xiàn)了一下的增強的功能: 1.基于html的輸出,使用條形圖和不同的顏色來表。 2.支持大型項目,信息匯總頁面提供三個層次的代碼覆蓋細節(jié)信息,目錄試圖、文件試圖和源代碼試圖,允許快速瀏覽代碼覆蓋率數(shù)據(jù)。

2.2 原理簡介 2.2.1 概念解釋 下面對覆蓋率技術(shù)的常見概念進行簡單介紹。主要是基本塊(Basic Block),基本塊圖(Basic Block Graph),行覆蓋率(line coverage), 分支覆蓋率(branch coverage)等。 基本塊(Basic Block),"A basic block is asequence of instructions with only entry and only one exit. If any one of theinstructions are executed, they will all be executed, and in sequence fromfirst to last." 這里可以把基本塊看成一行整體的代碼,基本塊內(nèi)的代碼是線性的,要不全部運行,要不都不運行。 基本塊圖(Basic Block Graph),基本塊的最后一條語句一般都要跳轉(zhuǎn),否則后面一條語句也會被計算為基本塊的一部分。如果跳轉(zhuǎn)語句是有條件的,就產(chǎn)生了一個分支(arc),該基本塊就有兩個基本塊作為目的地。如果把每個基本塊當(dāng)作一個節(jié)點,那么一個函數(shù)中的所有基本塊就構(gòu)成了一個有向圖,稱之為基本塊圖(Basic Block Graph)。且只要知道圖中部分BB或arc的執(zhí)行次數(shù)就可以推算出所有的BB和所有的arc的執(zhí)行次數(shù)。

16603934-4f58-11eb-8b86-12bb97331649.png

圖1 基本塊圖

打樁,意思是在有效的基本塊之間增加計數(shù)器,計算該基本塊被運行的次數(shù);打樁的位置都是在基本塊圖的有效邊上。 行覆蓋率(line coverage),源代碼有效行數(shù)與被執(zhí)行的代碼行的比率。 分支覆蓋率(branch coverage),有判定語句的地方都會出現(xiàn)2個分支,整個程序經(jīng)過的分支與所有分支的比率是分支覆蓋率。注意,與條件覆蓋率(condition coverage)有細微差別,條件覆蓋率在判定語句的組合上有更細的劃分。 2.2.2 編譯選項 gcc需要靜態(tài)注入目標(biāo)程序編譯選項,在編譯鏈接的時候加入2個選項(-ftest-coverage -fprofile-arcs ),編譯結(jié)束之后會生成 gcno文件,而經(jīng)過靜態(tài)注入的目標(biāo)程序在“正常結(jié)束”后,會在運行目錄下產(chǎn)生gcda數(shù)據(jù)文件,通過gcov工具就可產(chǎn)生覆蓋率數(shù)據(jù)結(jié)果。 -ftest-coverage 讓編譯器生成與源代碼同名的gcno文件(note file),這種文件含有重建基本塊依賴圖和將源代碼關(guān)聯(lián)至基本塊及源代碼行號的必要信息。 -fprofile-arcs 讓編譯器靜態(tài)注入對每個源代碼行關(guān)聯(lián)的計數(shù)器進行操作的代碼,并在鏈接階段鏈入經(jīng)態(tài)度libgcov.a,其中包含在程序正常結(jié)束時生成gcda文件的邏輯和記錄弧跳變的次數(shù)及其他的概要信息。 在最終可執(zhí)行程序進入用戶代碼入口函數(shù)之前調(diào)用 gcov_init()內(nèi)部函數(shù)初始化統(tǒng)計數(shù)據(jù)區(qū),并將gcov_exit()內(nèi)部函數(shù)注冊為代碼出口。 當(dāng)程序調(diào)用代碼出口正常結(jié)束時,gcov_exit()內(nèi)部函數(shù)得到調(diào)用,其繼續(xù)調(diào)用__gcov_flush()內(nèi)部函數(shù)輸出統(tǒng)計數(shù)據(jù)并生成gcda文件,若程序是一個狀態(tài)機程序不會自動調(diào)用代碼出口時,需要增加定時器等方式調(diào)用__gcov_flush()內(nèi)部函數(shù)強制輸出gcda文件。

2.3 實踐應(yīng)用

利用GCOV和LCOV工具可以進行嵌入式代碼覆蓋率的統(tǒng)計,需要在Makefile或者Scons文件中做下面的編譯鏈接設(shè)置,增加 -fprofile-arcs -ftest-coverage 或者 –coverage,鏈接的時候,增加 -fprofile-arcs 或者 –lgcov。 為了上述幾個編譯選項的使用不影響到正常的編譯過程和效率。可以使用makefile中通過參數(shù)傳遞來支持覆蓋率產(chǎn)生,可以在makefile使用下面的方式: #代碼覆蓋率編譯選項

ifeq (_CODE_COV,$(CODE))APP_FLAGS += -fprofile-arcs -ftest-coverageendif #代碼覆蓋率鏈接選項

ifeq (_CODE_COV,$(CODE))LD_LINK_LIBFILTER += -fprofile-arcs -ftest-coverageendif 這樣,可以使用 make CODE=_CODE_COV 來引入這些編譯選項而不會影響到正常的編譯。 將目標(biāo)機生成的gcda文件放回至編譯目錄下,利用LCOV命令“l(fā)cov –directory. –capture –output file app.info”可以將gcno文件和gcda文件結(jié)合生成代碼覆蓋率結(jié)果info文件,再用LCOV命令“genhtml –o html app.info –title “LCOV–app.Info” –show-details -legend”將info文件和源代碼文件結(jié)合轉(zhuǎn)化為可視化網(wǎng)頁形式。

圖2 LCOV生成HTML結(jié)果

3.高手總結(jié)方法

代碼覆蓋率等級

代碼覆蓋率可以通過多種方法測量。最常用的是測量以下一個或多個指標(biāo):語句覆蓋率,分支 覆蓋率,修訂的條件/判定覆蓋率(MC/DC)。以下章節(jié)中將逐一詳解這些代碼覆蓋率。

語句覆蓋率

語句覆蓋率用來度量被測代碼中的可執(zhí)行語句是否被執(zhí)行到,它并不考慮循環(huán)或者條件語句, 只針對語句度量可執(zhí)行代碼。應(yīng)當(dāng)特別注意的是:“語句”并不等同于代碼行。

一般情況下,對于 C,C++,Java或Ada,分號代表語句結(jié)束。在某些情況下,一條語句會跨越多行代碼。語句覆蓋率可以有效度量可執(zhí)行代碼是否被執(zhí)行,但同時也有一定的局限性。

語句覆蓋率的局限

考慮如下圖1的代碼段:

int* p = NULL;

if (condition)

p = &variable;

*p = 123;

圖 1 – 語句覆蓋局限代碼示例

如果“condition”為true,那么就有可能達到100%的語句覆蓋,然而這個測試用例忽略了另一種情況:如果“condition”為假,程序?qū)⒁每罩羔?,因此,雖然語句覆蓋率是一個很好的度量指標(biāo),它仍舊是入門級的代碼覆蓋率。理想情況下,即使“condition”為false,測試用例也應(yīng)當(dāng)被計算。

分支覆蓋率

分支覆蓋率用來度量程序中所有的判定和分支以及相應(yīng)的輸出是否都被測試執(zhí)行到,例如 “if”語句必須將“true”和“false”都考慮到以覆蓋所有的輸出。如果只有一個路徑被執(zhí)行,那么覆蓋率將被標(biāo)記為部分執(zhí)行。

和語句覆蓋率類似,分支覆蓋浪費也有一些需要注意的細節(jié),尤其在針對“惰性求值”的編程語言時,惰性求值是將代碼的求值操作延遲到需要結(jié)果值時再進行的一項技術(shù)。

分支覆蓋率的局限

典型的情況是當(dāng)有復(fù)雜的布爾表達式的“惰性求值”出現(xiàn)時,如下圖2的代碼片段:

int* p = NULL;if (condition1 && (condition2 || function1(*p)))statement1;else

考慮“condition1”為假的情況,惰性求值將不會度量“condition2”或,此種情況同樣會導(dǎo)致代碼“if (condition1 && (condition2 || function1(*p)))”的分支覆蓋率計算錯誤。

繼續(xù)考慮“condition1”和“condition2”都為真的情況。惰性求值將再次導(dǎo)致“function1(*p)” 不會被度量,也同樣會導(dǎo)致代碼“if (condition1 && (condition2 || function1(*p)))”的分支覆蓋率計算錯誤。在此種情況下,有可能出現(xiàn)分支覆蓋率為100%但軟件中仍有潛在缺陷的情況。

修訂條件/判定覆蓋率(MC/DC)

MC/DC是一種特殊的分支覆蓋率,它不但會使用分支覆蓋率報告復(fù)雜條件下的true和false輸出,同時也會報告復(fù)雜條件下的全部分支條件輸出。

MC/DC最初由波音公司創(chuàng)建,用于航空軟件中DO-178B的A級認(rèn)證。通過對所有的子條件輸出分支的獨立證明,有效解決了惰性求值帶來的問題。

繼續(xù)討論代碼示例2,我們需要在“condition2”和“function1(*p)”固定的條件下驗證“condition1” 的“true”和“false”判定分支,之后繼續(xù)固定“condition1”和“function1(*p)”驗證“condition2” 的判定分支。

同樣的,讓我們在固定“condition1”和“condition2”的條件下討論 “function1(*p)”。在其他分支條件固定的情況下驗證某個分支條件的“true”和“false”值稱作“MC/DC對”。MC/DC對一般 使用MC/DC真值表描述。表1就是一個MC/DC真值表示例。

171e8236-4f58-11eb-8b86-12bb97331649.jpg

在軟件開發(fā)的不同階段獲取覆蓋率

軟件測試有很多種類,本文將其簡要的分為三類:

> 系統(tǒng)/函數(shù)測試:測試集成后的整個應(yīng)用

> 集成測試:測試集成的子系統(tǒng)

> 單元測試:測試一個或多個文件或類

每個軟件項目在系統(tǒng)測試的過程中都會模擬最終用戶的操作對源代碼做一些系統(tǒng)測試。導(dǎo)致軟件發(fā)布后仍舊存在缺陷最重要的一個原因通常是程序在運行過程中遇到了非預(yù)期的,即沒有測試的輸入組合。

很多軟件項目并不是沒有做集成測試或者單元測試。只是在完成集成測試或單元測試后,開發(fā)團隊可能苦于為隔離程序中的單個或多個文必須所需的大量測試代碼量。

對于最嚴(yán)格的單元測試和集成測試來說,最終生成的測試代碼量比待測代碼量還要龐大是很經(jīng)常出現(xiàn)的情況。因此,這兩種級別的測試普遍適用于關(guān)鍵和高安全領(lǐng)域,例如:航空航天、醫(yī)療、交通運輸、工業(yè)過程控制、高速汽車等。此類軟件中包含大量的嵌入式應(yīng)用軟件。

關(guān)鍵領(lǐng)域的結(jié)構(gòu)化測試流程一般會將需求的級別高低作為重點,代碼覆蓋率因而會在這種“基于需求”的測試中進行分析。在許多項目中,高等級的需求最先被測試。此時代碼覆蓋率可以被用來檢測和報告所達到的覆蓋比例。

然而不幸的是,在系統(tǒng)測試和功能測試階段想要達到100%的代碼覆蓋率幾乎是不可能的。通常情況下系統(tǒng)測試和功能測試只能達到60%-70%的代碼覆蓋率,剩余30%-40%的代碼覆蓋率需要在單元測試和集成測試階段才能夠完成。

單元測試使用包含驅(qū)動和樁的測試代碼隔離系統(tǒng)中的特定函數(shù),同時使用測試用例模擬這些函數(shù)的執(zhí)行。這些所謂的“低等級測試需求” 對被測試代碼提供了更高的控制,可以提高先前執(zhí)行的系統(tǒng)測試覆蓋率(甚至能達到100%)。因此,在不同的測試之間共享覆蓋率數(shù)據(jù)是非常有必要的。

嵌入式環(huán)境中獲取覆蓋率帶來的挑戰(zhàn)

常言道“有得必有失”,在嵌入式環(huán)境獲取代碼覆蓋率的問題上,要付出的代價是對待測代碼額外的插樁工作。插樁是將額外的代碼添加到程序中,從而實現(xiàn)測試過程中的覆蓋率收集和分析操作。

由于插樁的相關(guān)操作將導(dǎo)致程序源代碼增多,進而延長程序的執(zhí)行時間,因而需要預(yù)測插樁后的源代碼的覆蓋范圍預(yù)測,尤其當(dāng)測試實時嵌入式系統(tǒng)環(huán)境時,此項工作就更為重要。

事實上,要精準(zhǔn)的預(yù)測程序文件插樁的影響幾乎是不可能的。沒有算法支持(也不可能有)。每個系統(tǒng)都包含很多的變量,具有獨立唯一的復(fù)雜性。當(dāng)然,對于典型的示例系統(tǒng)來說,獲取一組準(zhǔn)確的估計還是可能實現(xiàn)的。

在共享環(huán)境中獲取覆蓋率數(shù)據(jù)

在嵌入式環(huán)境下管理代碼覆蓋率的主要問題在于如何配置內(nèi)存以容納額外的插樁代碼。VectorCAST針對大量示例代碼評估后發(fā)現(xiàn)添加了上文中提出的各種覆蓋率額外配置之后,源代碼量增長量普遍達到了10%。對于絕大多數(shù)的32位目標(biāo)板,這并不是一個很大的問題,但對于存儲容量有限的8位或者16位目標(biāo)板來說,幾乎可以肯定這會是一個問題。

為了降低可執(zhí)行文件的大小,各種各樣的代碼插樁技術(shù)被發(fā)明出來,針對不同大小的存儲區(qū)域有不同的數(shù)據(jù)采集技術(shù)。植入存儲器內(nèi)部的收集系統(tǒng)可以用于監(jiān)測被檢測到的代碼。這是插樁技術(shù)中保證使用最少RAM的關(guān)鍵技術(shù)。

4. 結(jié)語

通過以上的方法,可以統(tǒng)計C語言嵌入式代碼覆蓋率,統(tǒng)計結(jié)果為提高代碼質(zhì)量提供了有效的依據(jù),也為衡量測試質(zhì)量提供了重要的指標(biāo),并可以通過結(jié)果中的代碼行執(zhí)行次數(shù)進行效率分析。 然而,代碼覆蓋率并不能保證執(zhí)行過的代碼質(zhì)量,也無法作為衡量生產(chǎn)力的指標(biāo),代碼覆蓋率的數(shù)據(jù)只能表明測試用例的覆蓋代碼的強度,只有保證測試用例的正確通過和較高的代碼覆蓋率相結(jié)合才能真正意義上提升代碼的質(zhì)量。

代碼覆蓋率能不能提高軟件的可靠性?答案是肯定的,代碼的覆蓋率分析是保證軟件質(zhì)量最簡便易行的方法。

原文標(biāo)題:硬核:嵌入式代碼覆蓋率統(tǒng)計方法和經(jīng)驗

文章出處:【微信公眾號:嵌入式ARM】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

責(zé)任編輯:haq

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

    關(guān)注

    5082

    文章

    19126

    瀏覽量

    305184
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4788

    瀏覽量

    68611

原文標(biāo)題:硬核:嵌入式代碼覆蓋率統(tǒng)計方法和經(jīng)驗

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    嵌入式學(xué)習(xí)建議

    對廣大渴望學(xué)習(xí)嵌入式系統(tǒng)的學(xué)子提出幾點基礎(chǔ)階段的學(xué)習(xí)建議: ①嵌入式系統(tǒng)軟件硬件密切相關(guān),一定要打好軟硬件基礎(chǔ)。其實,只要找到正確的方法,加上努力,任何理工科學(xué)生,甚至非理工科學(xué)生,都能學(xué)好
    發(fā)表于 10-22 11:41

    synopsys 的design ware:DW_fpv_div,浮點數(shù)除法器,默認(rèn)32位下,想提升覆蓋率(TMAX),如果用功能case去提升覆蓋率呢?

    覆蓋率只有微微的提升,請問是否要遍歷很多數(shù)才能提升覆蓋率嗎?一般這種浮點數(shù)有什么方法去跑嗎? 每個數(shù)都跑豈不是天文數(shù)字,本人剛接觸不久,請大佬指教下,謝謝
    發(fā)表于 10-15 18:38

    嵌入式主板是什么意思?嵌入式主板全面解析

    嵌入式主板,通常被稱為嵌入式系統(tǒng)的核心組件,是一種用于控制和數(shù)據(jù)處理的計算機硬件,其設(shè)計旨在嵌入特定設(shè)備中執(zhí)行專門任務(wù)。嵌入式主板如同是設(shè)備的“大腦”,主要功能是根據(jù)需要管理和控制設(shè)備
    的頭像 發(fā)表于 09-30 10:05 ?469次閱讀

    利用靜態(tài)檢查工具完善功能安全中測試覆蓋率

    在功能安全中測試覆蓋率是比較重要的概念,也是在驗證過程中通常需要花費時間較多的步驟,如果能借助于靜態(tài)檢查工具的死邏輯查找和聲明、測試用例自動補全等功能往往能取得事半功倍的效果。
    的頭像 發(fā)表于 09-05 09:15 ?346次閱讀
    利用靜態(tài)檢查工具完善功能安全中測試<b class='flag-5'>覆蓋率</b>

    飛凌嵌入式旗下教育品牌ElfBoard亮相全國大學(xué)生嵌入式競賽總決賽現(xiàn)場

    ElfBoard作為嵌入式教育市場的新生力量,憑借母公司飛凌嵌入式多年深耕企業(yè)級嵌入式板卡的經(jīng)驗亮相全國嵌賽總決賽現(xiàn)場,希望將企業(yè)的實踐經(jīng)驗
    的頭像 發(fā)表于 08-15 09:39 ?701次閱讀
    飛凌<b class='flag-5'>嵌入式</b>旗下教育品牌ElfBoard亮相全國大學(xué)生<b class='flag-5'>嵌入式</b>競賽總決賽現(xiàn)場

    嵌入式工控一體機的安裝方法和使用注意事項?

    嵌入式工控一體機的安裝方法和使用注意事項?工控一體機系列產(chǎn)品中,因為使用環(huán)境的特殊性,很多企業(yè)需要以嵌入式的方式,把工控一體機安裝到固定的位置,途控在多年的嵌入式工控一體機的客戶溝通中
    的頭像 發(fā)表于 08-04 11:12 ?1213次閱讀

    面試嵌入式工作,會被問什么問題?

    面試嵌入式工作時,面試官可能會從多個方面考察應(yīng)聘者的知識、技能和經(jīng)驗。以下是一些常見的嵌入式工作面試問題,這些問題涵蓋了基礎(chǔ)知識、專業(yè)技能、項目經(jīng)驗和個人能力等方面
    的頭像 發(fā)表于 07-17 09:26 ?2022次閱讀
    面試<b class='flag-5'>嵌入式</b>工作,會被問什么問題?

    單元測試工具TESSY 新版本亮點速覽:提供測試駕駛艙視圖、超級覆蓋率、代碼訪問分析、增強覆蓋率審查

    各種測試對象和方法的所有覆蓋率測量結(jié)果,并記錄在新的測試總結(jié)報告中。 了解更多TESSY新版本功能詳情或申請免費試用,歡迎咨詢TESSY中國授權(quán)分銷商——龍智。 新版本功能亮點速覽: 1、超級覆蓋率 逐行評估源
    的頭像 發(fā)表于 07-08 16:20 ?447次閱讀
    單元測試工具TESSY 新版本亮點速覽:提供測試駕駛艙視圖、超級<b class='flag-5'>覆蓋率</b>、<b class='flag-5'>代碼</b>訪問分析、增強<b class='flag-5'>覆蓋率</b>審查

    如何提升嵌入式編程能力?

    :掌握嵌入式系統(tǒng)的基本原理,包括中斷、并發(fā)、實時操作、低功耗設(shè)計等。 3. 實踐編程:通過實際編寫和測試代碼來提高技能。從簡單的LED閃爍程序開始,逐步過渡到更復(fù)雜的項目,如定時器PWM應(yīng)用、串口、IIC
    發(fā)表于 06-21 10:01

    如何成為一名嵌入式C語言高手?

    、分享代碼和解決問題,可以拓寬我們的視野,了解最新的嵌入式開發(fā)技術(shù)和趨勢。通過參與開源項目,你可以學(xué)習(xí)到其他開發(fā)者的優(yōu)秀代碼和開發(fā)經(jīng)驗,也可以通過貢獻自己的
    發(fā)表于 04-07 16:03

    如何成為一名嵌入式C語言高手?

    、分享代碼和解決問題,可以拓寬我們的視野,了解最新的嵌入式開發(fā)技術(shù)和趨勢。通過參與開源項目,你可以學(xué)習(xí)到其他開發(fā)者的優(yōu)秀代碼和開發(fā)經(jīng)驗,也可以通過貢獻自己的
    發(fā)表于 03-25 14:12

    嵌入式fpga是什么意思

    嵌入式FPGA是指將FPGA技術(shù)集成到嵌入式系統(tǒng)中的一種解決方案。嵌入式系統(tǒng)是一種為特定應(yīng)用而設(shè)計的計算機系統(tǒng),它通常包括處理器、內(nèi)存、外設(shè)接口等組件,并且被嵌入到更大的設(shè)備或系統(tǒng)中,
    的頭像 發(fā)表于 03-15 14:29 ?1260次閱讀

    fpga是嵌入式

    FPGA(現(xiàn)場可編程門陣列)不是嵌入式系統(tǒng),但FPGA在嵌入式系統(tǒng)中有著重要的應(yīng)用。
    的頭像 發(fā)表于 03-14 17:19 ?2321次閱讀

    嵌入式工控機性能特點 嵌入式工控機應(yīng)用場景

    嵌入式工控機性能特點 嵌入式工控機應(yīng)用場景 嵌入式工控機是一種專門設(shè)計用于工業(yè)控制系統(tǒng)的計算機設(shè)備。它具有與傳統(tǒng)計算機不同的性能特點,并且在各種工業(yè)領(lǐng)域中有廣泛的應(yīng)用場景。 一、
    的頭像 發(fā)表于 02-04 11:35 ?692次閱讀

    怎么用Vivado做覆蓋率分析

    在做仿真的時候往往會去做代碼覆蓋率和功能覆蓋率的分析,來保證仿真是做的比較充分完備的。
    的頭像 發(fā)表于 01-03 12:34 ?1719次閱讀
    怎么用Vivado做<b class='flag-5'>覆蓋率</b>分析