0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

从最简单的例子,带你轻松学习ARM指令集

Q4MP_gh_c472c21 来源:未知 作者:龚婷 2018-03-14 10:36 次阅读

首先编辑一个最简单的函数,包含变量分配及初始化:test1.c

1.#include

2.

3.voidmain()

4.{

5.intd=4;

6.}

然后编译:arm-linux-gnueabihf-gcc test.c -o test1

然后看看汇编代码:arm-linux-gnueabihf-objdump -D test1;每一句的含义我已经给出详细注释。

首先对输出的文件格式说明,对于如下的输出,左边是程序地址(各种函数地址等等),第二列是指令码的十六进制表示也俗称机器码,剩下的就是给人类看的指令助记符号,举例举例:

835c: b480 push {r7}

这里,835c是main函数的地址,b480是机器码表示的指令,push {r7}就是给我们人类看的了。下面看test1的输出:

0000835c

:

程序用到了r7寄存器,所以需要保护以免破坏之前的数据

1 835c: b480 push {r7}

堆栈向下增长栈用的不多,只需要12个字节就够用了: int d需要4个,多出来的8个没有使用

2 835e: b083 sub sp, #12

因为r0-r7是通用寄存器,可以使劲用,堆栈寄存器sp只有没办法的时候才使用。只好用r7 = sp + 0这种笨办法

3 8360: af00 add r7, sp, #0

参与int d = 4这条语句的是r3,这是通用寄存器,spec定义大家都可以用,不需要保护

4 8362: f04f 0304 mov.w r3, #4

把4存储到sp+4所指定的栈里,c语言描述:*(sp + 4) = 4;留给大家思考:为何不顶着sp放置--即*(sp+0)=4?

5 8366: 607b str r3, [r7, #4]

还记得第二条:sub sp, #12吗?此句和下一句是为从堆栈里恢复原来的r7--pop {r7},做准备;

6 8368: f107 070c add.w r7, r7, #12

r7已经是原来的sp了

7 836c: 46bd mov sp, r7

弹出sp指向的内存数据给r7,c语言:r7 = *sp;

8 836e: bc80 pop {r7}

没有调用子函数,即没有使用lr寄存器,所以不需要push lr。跳转到lr地址--进入main函数的下一条地址

9 8370: 4770 bx lr 10 8372: bf00 nop

我们再编辑一个稍微增加一个变量:test2.c

[cpp]view plaincopy

1.#include

2.

3.voidmain()

4.{

5.intd=4;

6.charb=2;

7.}

0000835c

:

1 835c: b480 push {r7}2 835e: b083 sub sp, #123 8360: af00 add r7, sp, #0

4 8362: f04f 0304 mov.w r3, #4

把4存储到sp+0所指定的栈里,c语言描述:*(sp + 0) = 4,注意与上一个例子的区别,这里是顶着stack存放,为什么?

5 8366: 603b str r3, [r7, #0]

6 8368: f04f 0302 mov.w r3, #2

为何要这么任性的存放变量b?

7 836c: 71fb strb r3, [r7, #7]8 836e: f107 070c add.w r7, r7, #129 8372: 46bd mov sp, r710 8374: bc80 pop {r7}11 8376: 4770 bx lr

栈里的数据是这样的,b和d中间隔着好几条街呢:)

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • ARM
    ARM
    +关注

    关注

    134

    文章

    9088

    浏览量

    367423
  • 寄存器
    +关注

    关注

    31

    文章

    5336

    浏览量

    120261
  • 指令集
    +关注

    关注

    0

    文章

    223

    浏览量

    23379

原文标题:从最简单的例子,带你轻松学习ARM 指令集

文章出处:【微信号:gh_c472c2199c88,微信公众号:嵌入式微处理器】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    常用ARM指令集及汇编

    常用ARM指令集及汇编ARM处理器是基于精简指令集计算机(RISC)原理设计的,指令集和相关译码机制较为
    发表于 11-23 09:38

    简单介绍ARM指令集

    处理器架构是处理器厂商为同一个系列的处理器规定的一个规范。ARM架构是一种精简指令集(RISC)架构,具有以下RISC架构特点:较大的通用寄存器堆。load/store体系结构,其中数据处理操作仅对
    发表于 08-18 10:58

    ARM指令集文章集合

    三、指令集如果你想要集中学习一下关于ARM指令集方面的知识(比如下面几个知识点),可以看下下面的文章1、机器码2、运算指令3、控制
    发表于 09-07 22:06

    ARM指令集的特点有哪些呢

    1、ARM指令集ARM指令集格式ARM指令集ARM
    发表于 12-14 07:24

    常用ARM指令集与汇编

    常用ARM指令集与汇编 好资料,与你供享。只供学习
    发表于 03-25 16:34 74次下载

    ARM指令集下载 arm指令集参考手册

    ARM指令集下载 arm指令集参考手册, ARM 指令集 寄存器和处理器模式(26-bi
    发表于 12-25 09:20 118次下载

    常用arm指令集及汇编

    常用arm指令集及汇编
    发表于 09-09 14:22 34次下载
    常用<b class='flag-5'>arm</b><b class='flag-5'>指令集</b>及汇编

    arm指令集(1)

    arm指令集(1)  ARM跳转指令可以当前指令向前或向后的32MB地址空间跳转。这类跳转
    发表于 03-02 15:46 79次下载

    ARM指令集详解

    ARM指令集详解 内容提要 ARM指令集 ARM指令集分类与
    发表于 03-09 09:39 263次下载
    <b class='flag-5'>ARM</b><b class='flag-5'>指令集</b>详解

    arm7指令集

    1.ARM处理器寻址方式        ARM处理器是基于精简指令集计算机(RISC)原理设计的,指令集和相关译码
    发表于 10-23 11:07 163次下载
    <b class='flag-5'>arm</b>7<b class='flag-5'>指令集</b>

    ARM指令集介绍

    arm开发板 嵌入式开发 指令集 PDF文档。
    发表于 05-03 16:42 5次下载

    常用的ARM指令集及汇编

    常用的ARM指令集及汇编
    发表于 10-30 10:07 24次下载
    常用的<b class='flag-5'>ARM</b><b class='flag-5'>指令集</b>及汇编

    thumb指令集是什么_thumb指令集arm指令集的区别

    thumb指令集arm指令集的一个子集,是针对代码密度问题而提出的,它具有16位的代码宽度。与等价的32位代码相比较,thumb指令集在保留32位代码优势的同时,大大的节省了系统的存
    发表于 11-03 17:34 1.8w次阅读
    thumb<b class='flag-5'>指令集</b>是什么_thumb<b class='flag-5'>指令集</b>与<b class='flag-5'>arm</b><b class='flag-5'>指令集</b>的区别

    ARM架构及ARM指令集 Thumb指令集你了解多少?

    ARM架构及ARM指令集、Thumb指令集你了解多少?
    的头像 发表于 02-26 16:09 7135次阅读

    ARM处理器的寻址方式和指令集介绍

    ARM处理器是基于精简指令集计算机(RISC原理设计的,指令集和相关峄码机制较为简单ARM7TDM(S)具有32位
    发表于 11-24 17:24 33次下载
    <b class='flag-5'>ARM</b>处理器的寻址方式和<b class='flag-5'>指令集</b>介绍