打印
[STM32F3]

使用fromelf反汇编keil生成的AXF文件

[复制链接]
3712|6
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
从fromelf这个名字上我们就能看到它是用来处理elf文件的,elf 全称 Executable and Linking Format ,这种文件是gcc编译出来的,而我们使用的axf全称 Arm executable File ,是由keil或者ads编译出来的,两者在格式上有些区别,但里面包含的符号表,调试信息,汇编基本是相同的。keil生成的hex就是调用的fromelf将axf转换而来的,所以你编译后可以在输出文件中同时看到axf和hex文件。

fromelf有2种模式:常用的生成的bin文件是使用的format conversion mode,还有一种text mode模式就是用来生成反汇编的text文件的。

text模式介绍如下:值得注意的是如果我们不指定输出格式的话,那么默认就是--text格式,也就是说如果我们给--text 指定几个options的话我们可以省掉--text 而只使用相应的[options就可以,我下面的处理中将会省掉--text。

--text的几个options介绍:下面要使用的反汇编是-c


用fromelf把axf反汇编有2中方法,一种直接在windows环境中使用,一种和生成bin文件那样在keil编译后调用。
1)windows 窗口下进行:
❶:将我们生成的axf文件复制到keil安装目录的下ARM\ARMCC\bin目录下,

❷:在这个窗口中不要选中任何文件的前提下按下键盘的Shift键然后单击鼠标的右键选中“在此处打开命令窗口”,
fromelf.jpg (56.96 KB, 下载次数: 1)
下载附件
2015-7-5 17:30 上传



❸:在打开的CMD窗口中输入下面的命令并回车,
fromelf -c F303RE.axf -o F303RE.txt


沙发
IversonCar|  楼主 | 2016-3-22 22:12 | 只看该作者
❹:然后就可以生成反汇编文件F303RE.txt文件,



2)在keil里面直接调用和生成bin文件差不多,我们可以使用下面的命令:
fromelf -c -o "$L@L.txt" "#L"

如果你感觉上面的命令比较难懂,也可以使用下面的稍微好理解的命令,不过一定要注意你生成的axf的文件的路径和工程文件所在路径的对应关系,否则可能会调用失败,
fromelf -c  .\output\F303RE.axf  -o  .\output\F303RE.txt


使用特权

评论回复
板凳
IversonCar|  楼主 | 2016-3-22 22:13 | 只看该作者


好了,现在我们已经得到反汇编文件F303RE.txt,使用notepad++打开这个文件,你就可以看到我们的c语言汇编成的代码,我们还是使用上面提到的昨天的那个帖子的LR的值0x080002bd,因为M3/M4内核使用的Thumb指令会要求最低bit0为1,所以我们此处的LR 应该为 0x080002bc  在notepad++里面ctrl+f打开查询窗口输入0x080002bc  然后回车,我们发现定位的代码和昨天定位的一样,就是那句对0地址赋值0的代码,至此,我们也就通过反汇编axf找到导致程序跑飞程序的代码了。
fromelf.jpg (97.59 KB, 下载次数: 4)
下载附件
2015-7-5 17:51 上传




formelf 命令的功能相当强大,平常我使用到只是生成bin反汇编axf这些基本的,由于人比较懒用不到的就不想看这些英文文档,下面附件中的fromelf的说明文档详细介绍了它的其他的功能,希望那位兄弟有兴趣研究了分享下。

F303RE_Fromelf.rar

476.66 KB

使用特权

评论回复
地板
643757107| | 2016-3-22 22:37 | 只看该作者
我只会用这个命令生成BIN文件,方便之后在其他单片机里面下载使用。

使用特权

评论回复
5
yjmwxwx| | 2016-3-23 18:28 | 只看该作者


arm-none-eabi-objdump  -S 1.o

就出来啦,这个有什么用,那么多汇编怎么看啊

使用特权

评论回复
6
Michael_000| | 2017-9-7 12:54 | 只看该作者
不错,顶一下           

使用特权

评论回复
7
feelhyq| | 2017-9-7 13:04 | 只看该作者

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

50

主题

344

帖子

0

粉丝