keil5显示内存和存储占用百分比进度条工具

简介

[Keil5_disp_size_bar]
以进度条百分比来显示keil编译后生成的固件对芯片的内存ram和存储flash的占用情况,
并生成各个源码文件对ram和flash的占比整合排序后的map信息的表格和饼图。

d2b5ca33bd171632

d2b5ca33bd171644

原理是使用C语言遍历当前目录找到keil工程和编译后生成的map文件
然后读取工程文件和map文件来找到对应关键词内的ram和flash的各类信息
最后把信息整合以进度条字符串直观格式输出,同时把map的数据排序后导出csv和xlsx文件,绘制饼图。

注意:再次编译前先关闭已经使用excel打开的表格,或者先把原来的表格移走,不然excel占用表格文件导致没法输出新表格
注意:再次编译前先关闭已经使用excel打开的表格,或者先把原来的表格移走,不然excel占用表格文件导致没法输出新表格
注意:再次编译前先关闭已经使用excel打开的表格,或者先把原来的表格移走,不然excel占用表格文件导致没法输出新表格

该程序容易和keil的after bulid功能集成,以便嵌入式软件工程师方便知道芯片占用情况,进行裁剪和优化。

这个项目也有一个Qt的版本:https://gitee.com/nikolan/keil_development_assistant
表格和进度条等内容直接在图形化的Qt应用查看
不过这个命令行的版本虽然没法交互,但是更容易集成到项目工程内,不太占空间,且纯C库依赖少,执行更快,各有各的好处。

基本能找到编译后生成的map文件,
就能输出生成的代码对ram和flash的占用大小百分比进度条,和表格数据。
只要能找到工程文件和map文件,keil5环境下通用,对于没有使用分散加载的stm32和各种国产32一般都是可以直接适配的。
程序如果没有输出或输出有错误请查看运行日志 _alog.txt,看程序在哪个步骤断开没有往下执行。
项目内附上一个H7B0工程文件和map文件用于测试。

该项目代码可应用于二次开发,任何数据使用C语言整合信息用链表排序后,以表格方式输出。
例如统计自己源码的某些信息,例如RTOS创建的任务信息或者函数关系等。

使用方法:

  1. 把程序Keil5_disp_size_bar.exe放到工程目录下,
    要放在在.map文件更上一层的目录,
    例如可以放在和工程文件.uvoptx同一目录下。

d2b5ca33bd171700

  1. 在工程打开魔术棒配置,在User的After Build/Rebuild下
    添加编译后执行程序#Run1或#Run2,
    在前面打钩,后面则选择要执行的程序Keil5_disp_size_bar.exe对应路径
    注意要选对是当前工程目录下的Keil5_disp_size_bar.exe
    最好还是使用相对路径,避免工程移动后导致找不到。
    (为避免移动工程后,路径找不到的情况。也可手动输入 相对当前工程文件的相对路径,例如:”./Keil5_disp_size_bar.exe”)

如果选错其他工程的,编译出的信息则是其他工程的map文件

最新版本支持传入参数
./Keil5_disp_size_bar.exe 参数1 参数2 参数3 参数4 参数5

参数1:工程文件和map文件的递归查找目录,默认是”./”即exe所在目录
参数2:map文件的递归查找目录,默认是”./”即exe所在目录
参数3:是否输出程序详细运行过程,默认是0不输出,1则输出。
参数4:打印进度条已占用时的字符串,默认是”■”
参数4:打印进度条未占用时的字符串,默认是”_”

d2b5ca33bd171714

  1. 接着每次对工程按下编译,编译完成后就能看到生成的代码对ram和flash的占用大小百分比进度条。d2b5ca33bd171729

同时生成了4个文件

  • xxx_alog.txt 是程序运行日志文件,当输出不对或没有输出时可以查看

  • xxx_sort_by_flash.csv是把文件按flash占用排序的表格

  • xxx_sort_by_ram.csv是把文件按ram占用排序的表格

  • xxx_analysis.xlsx是文件ram和flash的占用和绘制的百分比饼图

d2b5ca33bd171751

  1. 如果执行了Keil5_disp_size_bar.exe,却没有输出占用百分比进度条,或者输出的信息有误
    请检测输出的错误消息或alog日志文件,最大可能是当前工程或者你放置程序的目录下递归查找也找不到map文件,
    请检测工程的Output输出生成配置,然后按下全部重新编译一次再看看能不能输出占用百分比进度条。

d2b5ca33bd171812

 

二次开发环境搭建

  1. 系统:windos10

  2. 编译器mingw-64

  3. 编辑器:例如vscode(使用其他IDE环境也可)

工程结构如下:
├─.vscode
├─inc(头文件)
│ └─xlsxwriter(头文件)
│ └─third_party(头文件)
├─lib(静态库)
└─src(源码)

开发方式和linux下编译开发C语言差不多,通过make或者gcc指令编译。

源码是使用GB2312格式编码的字符,使用其他编码打开的话中文注释和特殊字符会乱码。因为keil如果使用utf-8输出到cmd的会带乱码,这是因为window的cmd中文默认GB2312。

代码通过预编译实现了库的可裁剪
Makefile的USED_XLSXWRITER_LIB=1 默认是1,编译xlsxwriter库

如果USED_XLSXWRITER_LIB=0
则代码生成xlsx文件部分代码则被裁剪掉,只会生成csv文件。

版本更新日志

. 更新到v1.0 版本1.0进行了大更新

  • 代码规范化,大部分变量以结构体形式封装,且函数接口有较详细注释

  • 支持main函数传参 参数1:工程和map的递归查找地址 参数2:map递归查找地址 参数3是否输出运行过程到终端,参数4进度条占用字符串 参数5进度条不占用字符串

  • 支持显示ram和flash段的基地址,且按基地址纠正是ram还是flash

  • 程序运行后直接输出结果,程序的运行过程默认不输出到终端而是保存在 工程名_alog.txt内,要输出则传参数4为 1

  • 解析文件在已使用的ram和flash的占比,导出csv和xlsx表格结果,xlsx表格会画出百分比的饼图,csv则需要自己使用excel画

. 更新到v0.4

  • 把uint64_t改为uint32_t,因为发现sscanf函数的%x给赋值时,64位好像会因为对齐问题错误。

  • 修复递归查找不彻底导致子目录下的map找不到

  • 添加C51支持8051 测试STC89C52和WCH552均测试可以,但是部分工程没有写xram的大小的默认只能以iram大小替代。还有部分工程是没有在工程定义真正大小的,也就是芯片本身没有keil开发包,用其他芯片或通用开发包定义的工程。在keil上是没有定义对应芯片型号或用了其他芯片的定义的8051这就会导致显示占用的最大值错误。要确保工程文件里面的IRAM,XRAM,IROM都是正确的才行。

  • 同时发现部分例如stm32F0系列的工程map文件格式不同,可能早期map不怎么统一规范,给的max都是0xFFFFFFFF,无法输出进度条,只能读工程的里芯片定义的max,来替代map文件的max,所以部分自定义的显示不出来,工程文件有些格式也是会不一样有的以逗号分隔有的以-分隔。

. 更新到v0.3

  • 修改进度条部分字符对齐问题,方块字符选择了正方形等宽

  • 根据网友的反馈由于关键词(Exec关键词有部分map文件不存在,关键词改成Execution Region检索执行段

  • 加大ram和flash的占用信息存储数组的上限为30,有的map的flash分开的段比较多,或者自定义了.bss的内存池

  • 根据网友反馈使用了自定义malloc的内存池的ram被归类为了flash,除了带RAM外添加带ER$$的也视为RAM

  • 百分比修改以KB单位的显示占用分子分母

  • 最后以B为单位显示剩余可用空间

  • %d显示改为%u显示无符号整数

. 更新到V0.2

  • 更改进度条样式

  • 采用关键词(Exec模糊检索ram和flash的size和max

  • 支持多个ram和flash的占用百分比进度条显示

  • 一个极客 ageek nikola 开源

下载

 



版权声明 1 本网站名称:我爱单片机
2 本站永久网址:https://52dpj.com
3 本站部分内容来源于网络,仅供学习参考,如侵权,请联系站长 QQ:737313573删除处理。
4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
5 本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
6 本站资源大多存储在云盘,如发现链接失效,请联系我们我们会第一时间更新。
7加入本站QQ群:775957568,一起学习单片机开发。
© 版权声明
THE END
喜欢就支持一下吧
点赞11赞赏 分享