使用Helix QAC对OpenHarmony代码做静态分析

Helix QAC是一款权威的C/C++代码合规性静态分析工具,适用于对代码的规范性和可靠性有较高要求的软件系统。针对任何C/C++代码都可以使用Helix QAC来做静态分析,找出代码中不符合编码规范的语法问题,提高软件整体编码质量,优化编码开发习惯。本文对面向全场景、全连接、全智能时代的Harmony OS的开源项目OpenHarmony代码进行静态分析

 
测试环境介绍

整个测试环境搭建在VMware Workstation虚拟机上,虚拟机分配4核心,4GB内存,安装Ubuntu Server 20.10操作系统,使用最新的Helix QAC 2021.2 for Linux,使用MobaXterm终端软件,SSH连接到虚拟机,图形界面通过SSH转发到MobaXterm自带的X Server,显示出图形化界面。OpenHarmony代码使用的是gitee上最新的master分支代码(截至2021年9月),使用内置示例工程wifi-iot项目,对wifi-iot项目做静态分析。


开发环境的配置
 
安装好Ubuntu server系统和Helix QAC2021.2静态测试工具之后,就可以开始开发环境的配置。按照官方文档教程,通过apt安装必要的库和工具,使用官方文档推荐的“通过repo+https”方式下载源代码到虚拟机中。下载完成后,在shell里面输入hb set命令,设置当前的代码的根目录,以及要编译的项目,在这里选择代码中内置的wifiiot_hispark_pegasus项目。

选择完成后,开发相关的环境配置完成,接下来尝试编译源代码,输入hb build命令,就可以开始构建编译源代码了。

这一步的目的是确保源代码能够正确编译,没有任何编译错误,也就代表代码的开发环境配置完成。

 
测试环境的配置
 
使用Helix QAC对代码进行静态分析时,必要的前置条件就是确保代码可以完全编译成功,没有任何编译错误,只有这样才能保证静态分析的结果是可信的。在上一步已经验证代码是可以完全正确编译的,接下来就可以打开Helix QAC,创建一个静态分析项目,对代码进行静态分析。输入./qagui,就可以打开Helix QAC的图形化界面。

整个静态分析的过程均可以在图形化界面中完成,同时也提供了命令行的操作方式,便于和CI系统集成,在整个项目开发周期内,持续不断确保高标准代码质量。

 
创建一个静态分析的项目
 
到菜单Project->Create New Project,打开测试环境创建向导。

打开之后,根据实际需要设置项目的目录和项目名称。

根据实际使用的编译器,选择编译器对应的CCT,在这里,OpenHarmony中的wifi-iot项目是由riscv32-unknow-elf-gcc编译器编译的,在这里选择riscv32-unknow-elf-gcc编译器对应的CCT。

导入项目代码
 
项目创建完成,就可以导入代码,对代码做静态分析。在这里可以通过同步的方式,导入代码。
 
菜单Project->Synchronize,打开同步配置窗口,输入项目代码根目录,再输入编译命令,就可以导入源代码。同步需要对项目做rebuild,所以要事先清除,编译命令输入hb clean && hb build,点击Synchronize,会自动调用编译命令对代码完整编译,同时监控编译过程,把所有编译到的文件都导入到Helix QAC静态分析项目中。

同步完成后,可以看到被添加进Helix QAC静态分析项目的源文件。

静态分析代码以及分析结果
 
点击分析按钮,就可以对项目中所有的代码进行静态分析,在这里使用MISRA C 2012 规则,对代码的编码规范做检查。分析完成可以看到结果以及分析之后的数量。

针对当前代码版本的OpenHarmony代码,经过Helix QAC的静态分析,使用MISRA C 2012编码规范,总共发现了违反MISRA C 2012 规则的数量是63222,其中违反MISRA C 2012 Mandatory的数量是356,违反MISRA C 2012 Requird数量是39481。违反MISRA C 2012 Advisory的数量是27538。违反Mandatory分类和required分类的代码需要做出更正,违反Advisory分类的代码,可以根据需要做出修正。Helix QAC还可以自动生成报告,这里对于当前的分析结果生成一份代码审查报告(Code Review Report,CRR)。

 以下是报告截图(部分)

 “原创内容,转载请标明出处”

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1、 QAC介绍和使用说明 其他的功能概括 1、提供一种可量化措施的代码度量值属性:33基于功能 32基于文件和4个项目级别 2、功能结构关系图,以提供控制流动洞察 3、展示全局调用函数的关系图引用和文件树结构 4、提供统计分析代码质量的全面评估 5、跨模块分析能力(CMA)、分析递归功能和全局标识符的各种问题 6、简化的旧代码修改的设置基准模块 Source..c文件通过分析工具生成3种文件source.c.i、source.c.met、source.c.err。source.c.i文件可以直接生成报告文件,.met、.err这两个文件可以分析出功能结构、关系、特征标准、报告或者进行跨模块分析,对于跨模块分析和剖析器分析需要进行配置,source.c.met、source.c.err、配置文件可以在信息浏览器显示 2、 规划 2.1、自动生成文件及参数说明 生成自动文档步骤: 1、从文件菜单选者Auto-Create Project 2、进入Root Folder Name,这是工程的根目录,后面的自动生成的文件都会对应此根目录产生 3、进入Starting Directory,这个源代码目录与工程的根目录相连 4、进入Output File Path,这里可以选择QAC分析后的输出文件,好的情况就是用一个专门的目录和工程根目录相连 5、Replicate source tree structure in output paths通常是为输出部分建立一个子目录结构,这里可以有2种选择,可以选择Parallel to Source Structure为源代码建立一个平行的目录结构,或者选择Sub-path to each source location把规定的输出的子目录嵌入到源工程目录下面 6、选择File Extensions可以加入项目,通常只要选择一个.C文件,包括对.H文件也就被加入 7、为文件夹选择一个个性,可能会使用默认设置为起始点,可以在QAC选择Configuration菜单 8、点击OK就是建立了工程,包含源文件工程和子文件夹 9、保存文件,外部扩展名为.prj 注意:也可以在已有的项目上自动生成一个文件夹,点击菜单Edit > Auto-create Sub-Folders,其余步骤和以上相同 文件夹参数:包括文件夹名称、默认源路径、输出路径和三种个性 可以进入Edit > Folder Parameters只可以改变文件夹参数,进入Edit > Propagate Changes to Sub-Folders可以改变所有子文件夹参数 2.2、手动生成文档及参数说明 生成手动文档步骤: 1、从菜单File选择New Project,显示一个对话框New Project Parameters 2、进入Root Folder Name,输入一个项目名称 3、进入Default Source Path为项目初始化文件夹,这个路径可以改变所有子文件夹 4、在Output File Path选择需要输出的分析文档 5、为工程选个个性 6、点击 OK创建项目,这工程的配置是唯一的文件夹 7、按要求增加更多的子文件夹和文件按要求 8、保存文件,外部扩展名为.prj 文件夹参数;在File > Reopen这项可以有10多个选项,当没用的文件可以选择Clean-up。 文件和目录的位置时重新打开项目,将检查的存在。如果不存在一个条目将显示下面的对话框。有的更正可以自动应用的过程。 2.3、选择输出文件 一般文件夹的层次结构在在左边显示,选择的列表在文件的右边显示 所有的选择都在Browse 和d Reports这两个菜单 A、如果选择单个文件或一组文件,则使用 B、否则当前所选文件夹,再加上所有子其文件夹,窗体所选内容。这意味着使用这些文件夹的所有文件。 在浏览器内修改,有可能会改变开始的选择,用Select Files…在File菜单内 2.4、互相比较和环境变化的报告 2.4.1、根路径 2.4.2、基于GUI的环境变量创建 2.4.3、相对路径和环境变量的运用 选择Apply Relative Paths项可以选择相对路径减少的所有文件条目,根目录在右上角,表示保存项目文件的位置,确定路径是否合适相对路径减少。 选择Make file paths in each folder relative to its Default Source Path entry项,如果想要应用一个虚拟的环境变量表达默认每个文件的源路径到其他文件条目下。 在Available Environment Variables列表下,可以添加EVs to Apply至右边框,将这种替换只发生在项目的项的文件或关联的路径不受相对路径减少的个性 选择Apply path reduction to personality file entries associated with the project项,为了继续应用相对路径和环境变量在文件路径下的个性定义 选择Remove all path reduction from the project and associated personalities项若要撤消所有的相对路径和环境变量从相关个性设置项目恢复到完全在所有情况下限定的路径 例如,一个被重建的“Diff”项目如下所示与充分的relative道路实施 3、 配置QAC 为应用程序配置主要通过可访问Configuration > Options选项卡,有以下几点: Annotated Source 附加说明源 Cross-Module Analysis 跨模块分析 Custom Reports 自定义报告 Default Personalities 默认特性 Editor Preferences 编辑选项 Environment 环境 (Product)Extensions (产品)条目 Project File Options 项目文件选择 要查看您的安装与那些一起的个性的一组在您的项目定义,可以在Configuration下选择Message Personalities, Analyser Personalities or Compiler Personalities这几个选项 当创建了一个额外的特性,也可以设置它们成为系统默认,在Configuration>Options>Default Personalities下设置 3.1、配置编译器特性 看附录A 3.1.1、设置系统头文件 在系统包括系统标题选项卡上的标题,设置您系统标头包含路径 可以点击Suppress Output阻止这些头文件,当阻止了那些头文件,一些从特定的头文件或路径产生的分析数据也不能在.err、.met文件出现 您可以手动输入是相对于当前项目的路径位置,虽然建议进行完整路径选择和然后将任何选择的道路减少保存项目的过程的应用操作 3.1.2、设置系统宏 在System Macro Defines下的Project Macros菜单,设置宏同编译器或开发环境一致,宏可以在Compiler Personality或Analyser Personality设置 3.1.3、设置实现定义的类型 在c编译器里有3类型定义,在“implementation defined”选择,如下: size_t 一种无符号必需类型通过sizeof操作表示返回类型 ptrdiff_t 一种有有符号必需类型用减法运算的两个指针来表示 wchar_t 它反映了类型的范围内的整数类型字符文本和宽字符字符串 在Data Types下的Intrinsic Types条目控制这些类型的方法实施,需要以匹配编译器配置环境。所载入的任何相应类型声明头文件(e.g. stddef.h, stdio.h)必须反映内在匹配值类型。如果不符合,qac提示等级9的警告,如有必要,检查您的头文件确定适当的设置这些选项。 如上所述:QAC随提供一套标准库的头文件,如果想改变这些类型定义,必须先明白QAC内部的定义类型,因为那些头文件包含一些声明ptrdiff_t, size_t 和wchar_t,还有3种宏指令定义PRQA_PTRDIFF_T, PRQA_SIZE_T,和PRQA_WCHAR_T, 3.1.4、编译器扩展 许多编译器制造商实施 ISO C 的扩展语言定义来利用特定的硬件环境。特别是在嵌入式软件代码的速度和空间是重要 使用的语言扩展的危险是他们妥协可移植性。源代码越来越依赖于编译器和硬件环境。 QA C 是能够分析各种不同的语言变体和扩展,但它不是通常能够解释扩展在语义上。通常,必须配置该工具等,非标准关键字将被忽略。 有几种方法可以为此配置QAC,看附录B–extensions部分

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值