91在线观看视频-91在线观看视频-91在线观看免费视频-91在线观看免费-欧美第二页-欧美第1页

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

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

3天內不再提示

Harmony系統代碼的靜態測試

北匯信息POLELINK ? 2022-08-01 14:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

華為的Harmony手機操作系統已經發布了幾個月了,作為國產操作系統,其寄托了我們的深切希望。在Harmony系統發布會上,手機、平板、智能手表等消費電子類產品固然是主角,而作為華為冉冉升起的新興業務領域——智能汽車,亦被包含在系統生態之中,也引起了行業的廣泛關注。

Harmony作為一個新生的系統,其不可避免的會存在很多問題,而汽車領域對代碼的編碼規范要求又極為嚴格。因此本文將通過使用汽車行業主流的靜態分析工具,來分析測試Harmony系統代碼對汽車行業內常用編碼規范(CERT、MISRA C 2012、CWE C)的遵循情況。

考慮到標準Harmony系統的代碼量非常龐大,本文僅以OpenHarmony_1.0.1_release分支中的Hi3861 WLAN模組代碼為例進行部分代碼的靜態測試。

編譯Harmony系統

Ubuntu編譯環境準備

系統要求:Ubuntu16.04及以上64位系統版本。

本文使用的是搭建在虛擬機中的Ubuntu 18.0系統,編譯環境搭建分為如下步驟:

▲獲取源碼

▲安裝和配置Python

▲安裝gn

▲安裝ninja

▲安裝LLVM

▲安裝hb

了解詳細的配置步驟請移步Harmony開源項目教程指南,本文就不做詳細的介紹了,按照文檔一步一步進行操作,就可以獲取Harmony輕量系統源碼,并完成編譯環境的搭建。

請注意,此時我們還無法編譯Harmony系統,需要完成后續開發板環境搭建后才能正常編譯Harmony系統。

Hi3861開發板環境搭建

為了能正常編譯源碼中的wifiiot_hispark_pegasus工程,我們需要在剛才設置的Ubuntu編譯環境中搭建Hi3861開發板環境搭建,如果需要編譯別的工程,搭建對應的開發板環境即可。

了解詳細的搭建步驟請移步安裝Hi3861開發板環境

編譯Harmony系統

完成Hi3861開發版環境搭建后,我們就可以正常編譯源碼中的wifiiot_hispark_pegasus工程了,具體步驟如下:

▲到下載的源碼根目錄下,執行hb set,然后會提示讓你輸入源碼根目錄,輸入當前路徑后回車,選擇wifiiot_hispark_pegasus項目就完成了編譯準備工作。

pYYBAGLmUPaAe4SkAABQ-O7ArnI670.png

▲執行hb build即可進行wifiiot_hispark_pegasus工程的編譯,如果編譯結果如下圖所示,即表示你成功地編譯了該工程。

pYYBAGLmUQCAKpznAAKGobVp8jA714.png

成功實現wifiiot_hispark_pegasus工程的編譯后,我們就可以進行后續的靜態分析工作了。

Harmony系統靜態分析

Harmony系統編譯環境配置

通過編譯器環境配置文件生成工具,我們可以很方便地生成Harmony編譯環境的配置文件,由于wifiiot_hispark_pegasus工程是C工程,因此只配置C編譯器的環境即可,考慮到Harmony使用的是C99標準,因此需要在生成配置文件時需要添加-std=C99,具體如下圖:

poYBAGLmUTaASOyhAADCfhveTPQ839.png

然后在靜態測試工具中導入該配置文件即可。

靜態分析執行

為了方便后續將Harmony的靜態分析過程部署到持續集成平臺上,本文以命令行的方式進行靜態分析操作的演示。具體步驟如下:

  • 創建QAC工程,命令如下:

qacli admin --qaf-project-config --qaf-project . --cct "/home/zhou/.config/Perforce/Helix-QAC-2021.1/config/cct/GNU_GCC-riscv32-unknown-elf-gcc_7.3.0-riscv32-unknown-elf-C-c99.cct" --acf "/home/zhou/.config/Perforce/Helix-QAC-2021.1/config/acf/HMOS.acf" --rcf "/home/zhou/.config/Perforce/Helix-QAC-2021.1/config/rcf/HMOS.rcf"

為了更全面地了解Harmony系統的代碼質量,本文在QAC工程的分析配置文件HMOS.acf中添加了MISRA C 2012合規模塊、CERT C合規模塊及CWE C合規模塊。

  • MISRA C 2012:為開發安全關鍵系統提供編碼標準,廣泛應用于汽車軟件開發。
  • CERT:信息安全編碼標準,能確保您的軟件免受潛在的軟件安全漏洞的侵害。
  • CWE C:常見弱點枚舉(CWE)列表標識了軟件和硬件中的軟件安全弱點。

  • 過濾Harmony中包含的第三方源碼,命令如下:

qacli pprops -P . --sync-setting FILE_FILTER --set "/home/zhou/Downloads/openHarmony/third_party"

通過該命令,我們可以將Harmony工程中包含的第三方源碼從QAC工程中過濾出去,這樣我們可以更好地通過QAC的分析結果衡量Harmony蒙源碼的代碼質量。

  • 將wifiiot_hispark_pegasus工程源碼加載到QAC工程中,具體命令如下:

qacli sync -P . -t MONITOR "cd /home/zhou/Downloads/openHarmony&&hb clean&&hb build"

該命令是通過監測wifiiot_hispark_pegasus工程的編譯過程,自動將編譯過程中調用的源文件和頭文件添加到QAC工程中。

  • 執行QAC分析,具體命令如下:

qacli analyze -P . –cf

pYYBAGLmUXqAa57jAALZbPTOTSw762.png

  • 生成合規報告

qacli report -P . -t RCR

pYYBAGLmUYeANkEjAADsATX29pc031.png

  • 將分析結果上傳到QAC的網頁端,方便查看,命令如下:

qacli upload -P . --qav-upload --upload-project HMOS --snapshot-name v1.0 --upload-source ALL -U https://192.168.9.126:8081/ --username admin --password admin

poYBAGLmUZ6AeDtCAACzd2L9VCc876.png

靜態分析結果分析

模塊wifiiot_hispark_pegasus的總體合規情況如下:

pYYBAGLmUbCARIOUAABvDWWvFAc088.png

QAC共計報出107618條診斷消息,共計違反規則290264次,違反的規則數目為302條(包含MISRA C、CERT C和CWE C),符合的規則有216條,由于模塊的文件合規率高達94.19%,但是工程合規率卻只有41.70%,所以可以看出違反規則的情況集中在少部分源文件中。

CERT合規情況

wifiiot_hispark_pegasus源碼的CERT總體違規情況如下圖:

poYBAGLmUdCAFENbAACYpBAO6v8814.png

圖中的圖例為CERT C的規則組簡寫,詳細信息如下:

02_DCL Declarations and Initialization (DCL)

10_ENV Environment (ENV)

11_SIG Signals (SIG)

04_INT Integers (INT)

09_FIO Input Output (FIO)

14_CON Concurrency (CON)08_MEM Memory Management (MEM)

07_STR Characters and Strings (STR)

03_EXP Expressions (EXP)

違反最多的10條CERT C規則如下圖:

pYYBAGLmUe6AW8kOAACZVXx4egw261.png

CERT C規則的違規分布情況如下圖:

pYYBAGLmUfuAbq3HAAJe27dqtzU467.png

圖中方塊面積表示代碼量,顏色深淺表示違反CERT的嚴重程度,由上圖可以看出,CERT C的違規情況主要集中在如下源文件中:

  • cmsis_task_func_test.c:有3182行代碼,違反了1951條CERT C的診斷消息;
  • cmsis_task_pri_func_test.c有1635行代碼,違反了1144條CERT C的診斷消息;
  • tcp_session_manager.c:有1230行代碼,違反了912條CERT C的診斷消息;
  • huks_adapter.c:有1705行代碼,違反了862條CERT C的診斷消息;
  • coap_adapter.c:有638行代碼,違反了579條CERT C的診斷消息。

圈復雜度最高的10個函數如下圖:

poYBAGLmUhaAChnzAABHg9v6sVk317.png

下文我們將摘錄部分違反規則的代碼進行分析說明:

1. DCL37 Do not declare or define a reserved identifier. (rule)

規則解釋:

根據 C標準,7.1.3 [ISO/IEC 9899:2011],

所有以下劃線和大寫字母或其他下劃線開頭的所有標識符都始終保留使用。

所有以下劃線開頭的標識符始終保留,用作普通名稱空間和標簽名稱空間中文件范圍的標識符。

違規舉例:

/HMOS/base/hiviewdfx/hievent_lite/frameworks/hiview_event.c,L28:

#define EVENT_VALUE_MAX_NUM16

此處代碼不合規,因為'EVENT_VALUE_MAX_NUM'宏可能在未來與''中的宏有沖突。

參考ISO:C90 Language [7.13], ISO:C99 Language [7.26]

2. INT02 Understand integer conversion rules. (recommend)

規則解釋:

轉換可以作為強制轉換的結果顯式發生,也可以根據操作的要求隱式發生。盡管正確執行程序通常需要進行轉換,但它們也可能導致數據丟失或被誤解。將操作數值轉換為兼容類型不會導致值或表示發生變化。

C整數轉換規則定義了 C編譯器如何處理轉換。這些規則包括整數提升整數轉換等級通常的算術轉換。規則的意圖是確保轉化導致相同的數值,并且這些值最小化了其余計算中的意外。Prestandard C通常更傾向于保留類型的簽名。

違規舉例

/HMOS/base/hiviewdfx/hievent_lite/frameworks/hiview_event.c,L57:e.common.mark=EVENT_INFO_HEAD;

此處代碼不合規,因為一個'essentially signed'類型的整型常量在賦值時被轉換為'unsigned'類型。

3. DCL23 Guarantee that mutually visible identifiers are unique. (recommend)

規則解釋:

根據 C標準 [ISO/IEC 9899:2011]的第 6.2.7條,

所有引用同一對象或函數的聲明都應具有兼容的類型;否則,行為未定義。

此外,根據第 6.4.2.1款,

任何在重要字符上不同的標識符都是不同的標識符。如果兩個標識符僅在非重要字符上不同,則行為未定義。

違規舉例:

/HMOS/base/hiviewdfx/hievent_lite/interfaces/native/innerkits/hiview_event.h,L85:

voidHiEventPutInteger(HiEvent*event, int8 key, uint32 value);

此處代碼不合規,因為外部標識符匹配其他外部標識符(例如:'HiEventPrintf')的前6個字符-程序不符合嚴格的ISO:C90。

參考:ISO:C90 Language [6.1.2], Security Problems

4. DCL00 Const-qualify immutable objects. (recommend)

規則解釋:

不可變對象應該使用const限定。使用const限定來強制對象不變性有助于確保應用程序的正確性和安全性。例如,ISO/IEC TR 24772建議將參數標記為常量,以避免無意中修改函數參數 [ISO/IEC TR 24772]。STR05-C.Use pointers to const when referring to string literals描述了此建議的特殊情況。

違規舉例

/HMOS/base/hiviewdfx/hievent_lite/frameworks/hiview_event.c,L50:

voidHiEventPrintf(uint8 type, uint16 eventId, int8 key, uint32 value)

此處代碼不合規,因為形參'type'永遠不會被修改,因此可以用'const'限定符聲明它。

參考:, ISO:C90 Language [6.5.3], Security Problems

5. MEM34-C. Only free memory allocated dynamically.(rule)

規則解釋:

C標準附錄J [ISO/IEC 9899:2011]指出,如下行為是未定義的:

free或realloc函數的指針參數與先前由內存管理函數返回的指針不匹配,或者空間已被調用free或realloc釋放

釋放非動態分配的內存可能導致堆棧損壞和其他嚴重錯誤。不要對非標準內存分配函數返回的指針調用free(),如malloc()、calloc()、realloc()或aligned_alloc()。

違規舉例

/HMOS/base/security/deviceauth/frameworks/deviceauth_lite/source/struct/parsedata.c,第76行代碼:

FREE((char*)payload);

此處代碼不合規,因為這是對非動態內存palyload變量的釋放,payload定義在/HMOS/base/security/deviceauth/frameworks/deviceauth_lite/source/struct/parsedata.c,L53:

payload=json_to_string(obj_value);

限于篇幅,MISRA C和CWE C的合規情況不在這里一一展示。

結束語

通過對Harmony系統部分代碼的靜態測試,我們嘗試了解了Harmony系統針對汽車行業常用的代碼編程規范的合規情況,期望未來Harmony通過不斷迭代開發,提升代碼的合規程度,進一步改善代碼的質量,成為一個優秀的車載操作系統。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    IGBT靜態參數測試系統

    HUSTEC華科智源 HUSTEC-1600A-MT IGBT功率器件測試儀 一:IGBT功率器件測試儀主要特點 華科智源HUSTEC-1600A-MT靜態測試儀可用于多種封裝形式的
    的頭像 發表于 07-08 17:31 ?534次閱讀

    harmony-utils之CacheUtil,緩存工具類

    harmony-utils之CacheUtil,緩存工具類
    的頭像 發表于 07-04 16:36 ?114次閱讀

    harmony-utils之CharUtil,字符工具類

    harmony-utils之CharUtil,字符工具類
    的頭像 發表于 07-04 16:34 ?118次閱讀

    harmony-utils之CrashUtil,異常相關工具類

    harmony-utils之CrashUtil,異常相關工具類
    的頭像 發表于 07-04 16:33 ?118次閱讀

    harmony-utils之DeviceUtil,設備相關工具類

    harmony-utils之DeviceUtil,設備相關工具類
    的頭像 發表于 07-03 18:27 ?153次閱讀

    harmony-utils之DisplayUtil,屏幕相關工具類

    harmony-utils之DisplayUtil,屏幕相關工具類
    的頭像 發表于 07-03 18:26 ?126次閱讀

    harmony-utils之EmitterUtil,Emitter工具類

    harmony-utils之EmitterUtil,Emitter工具類
    的頭像 發表于 07-03 18:24 ?130次閱讀

    harmony-utils之FileUtil,文件相關工具類

    harmony-utils之FileUtil,文件相關工具類
    的頭像 發表于 07-03 18:23 ?129次閱讀

    harmony-utils之FormatUtil,格式化工具類

    harmony-utils之FormatUtil,格式化工具類
    的頭像 發表于 07-03 18:22 ?130次閱讀

    harmony-utils之ImageUtil,圖片相關工具類

    harmony-utils之ImageUtil,圖片相關工具類
    的頭像 發表于 07-03 18:22 ?164次閱讀

    如何測試TPA3118和TPA3116的靜態電流和靜態功耗?

    1.如何測試TPA3118和TPA3116的靜態電流和靜態功耗? 2.測試時候需要帶負載嘛?(是否需要接喇叭) 3.如果用萬用表測試應該
    發表于 10-12 06:54

    汽車異構硬件平臺開發如何進行靜態代碼分析

    先進的靜態代碼分析工具,其新版本中引入的多CCT功能為開發人員提供了強大的支持,該功能不僅簡化了多編譯器環境下的代碼分析過程,還可以極大增強代碼的質量和安全性。
    的頭像 發表于 10-09 16:15 ?872次閱讀
    汽車異構硬件平臺開發如何進行<b class='flag-5'>靜態</b><b class='flag-5'>代碼</b>分析

    變頻器靜態測試和動態測試方法

    在變頻器的維護和故障診斷中,靜態測試和動態測試是兩項不可或缺的步驟。這兩類測試為技術人員提供了判斷變頻器內部組件健康狀況的依據。 一、靜態
    的頭像 發表于 08-19 17:47 ?2605次閱讀

    恒訊科技分析:如何測試海外靜態IP服務的穩定性和速度?

    測試海外靜態IP服務的穩定性和速度可以通過以下步驟進行: 1、選擇測試工具:使用網絡測試工具,如ping命令、traceroute(或 racert)、網絡速度
    的頭像 發表于 08-14 14:58 ?676次閱讀

    功率半導體器件靜態特性測試挑戰及應對測試方案

    PMST系列功率器件靜態參數測試系統是武漢普賽斯正向設計,精益打造的高精密電壓/電流測試分析系統,是一致能夠提供IV,CV、跨導等豐富功能的
    的頭像 發表于 07-23 15:43 ?1010次閱讀
    功率半導體器件<b class='flag-5'>靜態</b>特性<b class='flag-5'>測試</b>挑戰及應對<b class='flag-5'>測試</b>方案
    主站蜘蛛池模板: 国产美女精品一区二区三区 | 天天做日日干 | 国色天香精品亚洲精品 | 久久国内 | 精品视频在线观看视频免费视频 | 一二三区在线视频 | 黄色网址在线免费观看 | 国内久久久久高清影视 | 高清视频免费观看 | 亚洲 欧美 自拍 另类 欧美 | 特黄a大片免费视频 | 亚洲第二页 | 天天爽天天爱 | 特黄特级高清免费视频毛片 | 天天精品视频在线观看资源 | 成人福利在线视频 | 日本黄色片在线播放 | 成人狠狠色综合 | 欧美三级手机在线 | 亚洲国产欧美日韩一区二区三区 | 免费一级e一片在线播放 | 天天干天天综合 | 中国胖女人一级毛片aaaaa | 好爽毛片一区二区三区四区 | 狠狠色噜噜 | 高清一区二区三区视频 | 人人爽人人爱 | 久久香蕉国产精品一区二区三 | 1024在线观看你懂的 | 丁香五月欧美成人 | 天天操夜夜摸 | 韩国免费人成在线观看网站 | 日韩欧美亚洲综合一区二区 | 亚洲午夜一区 | 超级香蕉97视频在线观看一区 | 国产高清一级视频在线观看 | 国产自在自线午夜精品视频在 | 午夜视频在线观看一区二区 | 久久精品视频99精品视频150 | 六月婷婷视频 | 伊人久久亚洲综合天堂 |