使用doxygen分析MCAL源码的层次架构-基于YTM32

news2024/11/28 7:38:26

使用doxygen分析MCAL源码的层次架构-基于YTM32

文章目录

  • 使用doxygen分析MCAL源码的层次架构-基于YTM32
    • 引言
    • 准备和安装软件
    • 生成Call Graph
      • 配置`Wizard > Project`页面
      • 配置`Wizard > Mode`页面
      • 配置`Expert > Project`页面
      • 配置`Expert > Build`页面
      • 配置`Expert > Dot`页面
      • 分析并生成源码
      • 查看生成内容
      • 查看生成的调用流图
    • 总结
    • 参考文献

引言

阅读MCAL源码包中的源码,猜测MCAL可能只是MCU底层SDK向AutoSAR的一个适配接口。为了验证这个猜测,比较直接的做法,就是通过源码“逆向”出软件包中函数的调用关系,试图归纳出实际的源码设计层次架构。为此,我想到多年前在CI服务器上生成SDK API手册时,偶然发现的可以使用doxygen工具生成函数调用关系图的方法,打算摩拳擦掌,“搞”它一下子。

通过函数调用关系分析层次架构(抽象流图),是入手研究复杂软件的常用方法,也是软件架构师的基操,666 ^v^

文末有彩蛋。。。

准备和安装软件

doxygen 是跨平台的工具,官网:http://www.doxygen.nl/,支持Linux、Windows、Mac OS X系统(本文将以Windows版本为例)。支持C语言在内的多种语言的分析,生成的帮助文档格式可以是CHM、RTF、PostScript、PDF、HTML和Unixman page等。它是一款优秀的文档自动生成工具,可以将代码中的注释转换成帮助文档(注释格式要符合 doxygen 要求才行,FFmpeg API Documentation 就是用doxygen自动生成的)。本文使用doxygen的主要目的是生成函数调用关系图,也可以通过静态分析代码,生成「头文件引用关系图」、「函数调用关系图」、「继承图」以及「协作图」来可视化文档之间的关系。

doxygen(for Windows)的下载链接:https://www.doxygen.nl/files/doxygen-1.9.8-setup.exe

doxygen 自身没办法直接生成关系图,需要依赖 graphviz 才行,得先安装 graphviz。

官网:http://www.graphviz.org/
下载:https://graphviz.gitlab.io/_pages/Download/windows/graphviz-2.38.msi

生成Call Graph

运行 doxywizard.exe。

配置Wizard > Project页面

配置doxygen工程的目录、即将扫描源码的目录、产生输出文件的目录等。
在这里插入图片描述

配置Wizard > Mode页面

选定目标源码的编程语言,为C语言。
在这里插入图片描述

配置Expert > Project页面

可以选择生成中文文档。
在这里插入图片描述

配置Expert > Build页面

配置引用的对象类型。
在这里插入图片描述

配置Expert > Dot页面

启用DOT,启用生成CALL_GRAPH,配置生成DOT的工具路径。

在这里插入图片描述

分析并生成源码

在这里插入图片描述

查看生成内容

在这里插入图片描述

查看生成的调用流图

以查看Mcu.c文件的包含关系为例:
在这里插入图片描述
以查看Mcu_ClockInit()函数的调用关系为例:
在这里插入图片描述

查看Mcu模块与其他模块的关联关系:
在这里插入图片描述

总结

在doxygen生成的网站中大略过了一遍YTM32 MCAL的调用关系流图,以MCU驱动模块为例,做了简要的架构分析。MCU驱动模块的实现源码主要位于Mcu目录中(另有Mcu_Cfg.h文件位于board目录中),MCU驱动模块还引用了RteDet目录中的组件,以及Platform中关于硬件硬件的访问。根据AutoSAR MCAL的规范,McuDetRte等组件位于同一层次,并存在相互调用的关系。MCU驱动模块为了区分MCAL的同层调用关系和面向硬件的调用关系,专门在Mcu.c文件和Mcu_Lld.c文件中分两层实现了MCU驱动模块的功能:

  • 在Mcu.c文件中,可以调用MCAL同层次组件的服务,向AutoSAR的BSW提供底层服务。向下通过调用Mcu_Lld.c文件中函数,实现对本组件专属硬件的访问。
  • 在Mcu_Lld.c文件中,不能调用MCAL层次上的服务,仅能访问MCU硬件资源,并仅能又Mcu.c文件中的函数调用。

类似地,其他的MCAL层的驱动模块也是如此分层地设计和实现。

如此,可以推断,本文分析的YTM32B1ME05的MCAL软件包为代表,若在YTM32B1MD14芯片(或其他车规MCU)的MCAL软件包中,在基于这个层次架构实现MCAL软件包中,需要适配的,也仅仅是Mcu_Lld.c文件这个层级上的源码。

参考文献

  • doxygen+graphviz轻松绘制函数调用图(call graph),
    https://www.cnblogs.com/realjimmy/p/12892179.html
  • 绘制函数调用图(call graph)(4):doxygen + graphviz,
    https://blog.csdn.net/benkaoya/article/details/79763668

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1160271.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vue3视频大小适配浏览器窗口大小

目标:按浏览器窗口的大小,平铺视频,来适配屏幕的大小。 考虑使用 DPlayer.js、video.js、vue-video-player等视频插件,但报了各种各样的错;试过使用 js 对视频进行同比例放大,再判断其与窗口的大小取最小值…

纯CSS实现跑马灯效果,CSS动画知识是该补一补了

前言 最近看一个网站的时候,发现一个效果类似于广告灯的感觉,挺不错的,于是就想用纯CSS来实现这个效果,顺便提升一下自己的CSS动画技能。 分析 我们先分析怎么做的,这个效果分成两个部分: 上层&#xff…

matplotlib画刻度为对数的图

1. 代码 import matplotlib.pyplot as plta [1000,2000,3000,4000,5000] a_x [1, 2, 3, 4, 5] b [0.00001,0.00025,0.001,0.005,0.000001]plt.figure(figsize(10, 6)) plt.plot(a_x, b, cred, labellabel) plt.scatter(a_x, b, cblue) plt.xlabel(step$(\\times 10^3)$) pl…

【MySQL索引与优化篇】数据库设计实操(含ER模型)

数据库设计实操(含ER模型) 文章目录 数据库设计实操(含ER模型)1. ER模型1.1 概述1.2 建模分析1.3 ER 模型的细化1.4 ER 模型图转换成数据表1. 一个实体转换成一个数据库表2. 一个多对多的关系转换成一个数据表3. 通过外键来表达1对…

栅栏密码fence cypher

f{_wi3_hlyk_lnceaonr_cirgu04fep} flag{you_kn0w_r4il_f3nce_cipher}

世界坐标系投影到像素坐标系【python实验】

对于三维视觉而言,需要清晰了解世界坐标系和像素坐标系的对应关系。本文用python做实验。 相机内外参数的数学推导可以看我之前的博客《【AI数学】相机成像之内参数 》,《【AI数学】相机成像之外参数》。 实验开始 首先明确相机的内外参数: …

AI智能识别如何助力PDF,轻松实现文档处理?

AI智能识别如何助力PDF,轻松实现文档处理? 随着科技的不断发展,人工智能(AI)在各个领域都发挥着重要的作用。其中,文档智能( Document AI )在金融、医疗、教育、保险、能源、物流等…

yolov7改进之使用QFocalLoss

深度学习三大件:数据、模型、Loss。一个好的Loss有利于让模型更容易学到需要的特征,不过深度学习已经白热化了,Loss这块对一个成熟任务的提升是越来越小了。虽然如此,也不妨碍我们在难以从数据和模型层面入手时,从这个…

Object转List<>,转List<Map<>>

这样就不会局限在转换到List<Map<String,Object>>这一种类型上了.可以转换成List<Map<String,V>>上等,进行泛型转换虽然多了一个参数,但是可以重载啊注: 感觉field.get(key) 这里处理的不是很好,如果有更好的办法可以留言 public static <K, V> …

大数据Doris(十四):Doris表中的数据基本概念

文章目录 Doris表中的数据基本概念 一、​​​​​​​Row & Column

前端项目 index.html 中发请求 fetch

想要在前端项目 index.html文件中向后端发起请求&#xff0c;但是引入axios报错&#xff08;我这边会报错&#xff09;&#xff0c;可以使用fetch。 //window.location.origin----获取域名&#xff0c;包括协议、主机号、端口号fetch(window.location.origin "/api/pla…

el-tabs 默认选中第一个

1. 实际开发中el-tabs 都会设置第一个为默认值 ,这样会好看一点, 而渲染的数据经常是通过后端返回的数据 , v-model 无法写死默认值 解决办法 , 通过计算机属性 ,在data 定义一个 selectedTab watch: {defaultTab(newVal) {this.selectedTab newVal; // 设置第一个标签页…

腾讯云双11云服务器活动:3年366元,超多超值云服务器!

腾讯云在双11活动中推出了一款3年366元的云服务器&#xff0c;配置为2核2G 40GB SSD盘&#xff0c;300GB月流量&#xff0c;4M带宽。这一配置相较于其他厂商同等规格的云服务器&#xff0c;具有较高的性价比。在市场上很少有厂商提供3年期的优惠服务器&#xff0c;因此此次双11…

函数式接口详解(Java)

函数式接口详解&#xff08;Java&#xff09;_函数式接口作为参数_凯凯凯凯.的博客-CSDN博客 函数式接口&#xff1a;有且仅有一个抽象方法的接口 Java中函数式编程体现就是Lambda表达式&#xff0c;所以函数式接口就是可以适用于Lambda使用的接口 只有确保接口中仅有一个抽…

第二证券:怎么判断股票浮筹多少?

股票的浮筹是指公司的股份中&#xff0c;揭露生意在市场上的股份&#xff0c;一般是指除了大股东和筹码安稳的组织等&#xff0c;其他组织和个人能够自在生意的股份。在出资股票时&#xff0c;了解公司的浮筹是非常重要的&#xff0c;由于它直接联络到股票的供需联络和股价动摇…

初识JavaScript(一)

文章目录 一、JavaScript介绍二、JavaScript简介1.ECMAScript和JavaScript的关系2.ECMAScript的历史3.什么是Javascript&#xff1f;4.JavaScript的作用?5.JavaScript的特点 三、JavaScript基础1.注释语法2.JavaScript的使用 四、JavaScript变量与常量变量关键字var和let的区别…

苹果AirTag固件更新

苹果公司针对其热销的物品追踪器 AirTag 于今天发布了新的固件更新&#xff0c;最新版本号为 2A61&#xff0c;但是这次更新苹果并未提供发布说明&#xff0c;所以目前还不知道这次更新有什么新内容。 关于这次更新&#xff0c;用户无法自己手动更新 AirTag 固件&#xff0c;因…

5.1 运输层协议概述

思维导图&#xff1a; 前言&#xff1a; 第5章 运输层笔记 1. 概览 主要内容&#xff1a;介绍运输层协议的特点、进程间通信、端口、UDP和TCP协议、可靠传输、TCP报文段的首部格式、TCP的关键概念&#xff08;如滑动窗口、流量控制、拥塞控制和连接管理&#xff09;。重要性…

自定义类型结构体(上)

目录 结构体类型的声明结构体的概念结构体的声明特殊的声明结构的自引用 结构体变量的创建和初始化结构成员访问操作符 感谢各位大佬对我的支持,如果我的文章对你有用,欢迎点击以下链接 &#x1f412;&#x1f412;&#x1f412; 个人主页 &#x1f978;&#x1f978;&#x1…

linux下df -h 命令一直卡住的解决方法

在Linux中&#xff0c;偶尔遇到用 df -h 查看磁盘情况时&#xff0c;一直卡住无法显示结果。 解决方法&#xff1a; 1、首先使用strace追踪到底执行到哪里卡住 $ strace df -h 2、如果没有strace命令则进行安装 $ yum install strace -y 3、显示出卡住的地方&#xff0c;如…