1、点击new project,新建工程。
选择工程保存的目录,其他保持默认即可。
data:image/s3,"s3://crabby-images/7d49f/7d49f83ffb0cdd59b1ee0c7a711df309004b3a70" alt=""
2、配置编译器
根据工程选择相应的编译器配置文件,此处该示例选择的QAC通用平台的C语言配置文件
data:image/s3,"s3://crabby-images/db00e/db00e571216cb1d523ee847be77188bac8bc06c1" alt=""
3、生成工程文件
点击finish完成编译器配置后,自动生成工程文件
data:image/s3,"s3://crabby-images/f9e95/f9e95fbd822e8992e6e19d0224fb23592d13e172" alt=""
4、配置工程特性
点击project,选择打开工程特性
data:image/s3,"s3://crabby-images/e46e0/e46e05993a36e0fdaad3e404d458c38959668049" alt=""
将MISRA C 2012规范添加进来,也就是把m3cm添加进analysis toolchain。
available components里面保存的是各个编码规范的合规模块
data:image/s3,"s3://crabby-images/48d18/48d18fccd6a49342b9efcf0d242f1c9e3efec1d0" alt=""
点击rule configuration,可以打开或关闭MISRA的某些规则,也可以自定义制定规则。一般使用它默认的规则,不去做变更。
里面有MISRA的3类规则,分别是mandatory(强制遵循),required(违反规则需要制定流程去规避),advisory(违反规则做出记录即可)。
data:image/s3,"s3://crabby-images/3b26d/3b26db680c118aaa7aeac9937ced82f2f233d9d8" alt=""
5、通过同步的方式添加被测源码
点击主页面project,选择synchronize
data:image/s3,"s3://crabby-images/91cfb/91cfbf0f3044819bb2c4d1dca32ad95dde175643" alt=""
同步的原理:监测编译的过程,把编译过程中所调用的源码,头文件,宏定义都是同步添加到这个QAC工程里面。
data:image/s3,"s3://crabby-images/1c3a8/1c3a8bd52a15b68f25189d847527e8e67b4fc852" alt=""
点击同步按钮 ,此处我没有添加成功
data:image/s3,"s3://crabby-images/8d4fc/8d4fc5c725f4d822eb8c3b041802eb11a841affe" alt=""
选择点击QAC工程中的source files,直接添加被测源码所在目录,才添加成功。
data:image/s3,"s3://crabby-images/0c939/0c939580bda5ad3405c6b28f7e55a5cf23b5883e" alt=""
6、分析工程
点击左上角的分析按钮
data:image/s3,"s3://crabby-images/9dcb2/9dcb2a65279a3d67c9151d1787883ade08963235" alt=""
分析过程中,此时如果没有软件授权会导致分析失败。
下面Analysis results/diagnostics窗口会显示诊断的结果。
data:image/s3,"s3://crabby-images/20654/206542dc908bd44fab5ea35e83034a46d7bf09a8" alt=""
7、GUI中快速定位高风险代码
QAC把所有的诊断消息划为了0-8,共九个安全等级。数字越大,该诊断消息的安全等级越高,违反该高安全等级的规则对系统的影响越大。
可以通过滑块的移动来过滤掉低于选中数值以下的诊断消息。
对于下面的诊断消息,双击任一诊断消息,就可以定位到源码界面。
data:image/s3,"s3://crabby-images/fb93e/fb93e4a7e2af394bd09419e832a91f75a4927a40" alt=""
8、GUI中快速定位违反MISRA规则的代码
点击rule group分栏窗口
data:image/s3,"s3://crabby-images/ab62f/ab62f0cb7fc64c86c4cc385734c63d9dc927aa5a" alt=""
此处可以查看那些代码违反MISRA不同等级的规则。
选择某个规则,点击右键,选择show only,诊断信息框就会显示出违反该规则的所有文件,在诊断信息框中,选择一条信息双击,就会自动跳转到源码的对应行。
data:image/s3,"s3://crabby-images/0e9cd/0e9cd1ec144bbc65b5d8a6cc697c129cdc002cb3" alt=""
9、补充
如上图所示,某些规则显示灰色,原因是因为在选择MISRA规范时,默认只开启C99
data:image/s3,"s3://crabby-images/c1e5b/c1e5bc1a95a3aab315ed43071e738aca4a9cf0cc" alt=""
开启C90和c11可以在某个规则上点击右键,选择enable,或者disable来打开和关闭该规则。
data:image/s3,"s3://crabby-images/51daf/51daf339b43c2542b0d3b81d55ea2e2f6616bd78" alt=""