作者:郭嘉

邮箱:allenwells@163.com

博客:http://blog.csdn.net/allenwells

github:https://github.com/AllenWell

【基于Android的ARM汇编语言系列】章节列表

【基于Android的ARM汇编语言系列】之中的一个:ARM汇编语言开篇

【基于Android的ARM汇编语言系列】之二:C/C++程序生成ARM汇编程序的过程分析

【基于Android的ARM汇编语言系列】之三:ARM汇编语言程序结构

【基于Android的ARM汇编语言系列】之四:ARM处理器的寻址方式

【基于Android的ARM汇编语言系列】之五:ARM指令集与Thumb指令集

【基于Android的ARM汇编语言系列】之六:NEON指令集与VFP指令集

Android平台的ARM汇编是GNU ARM汇编格式。使用的汇编器是GAS(GNU Assembler),GAS有自己的一套语法结构。

具体的内容能够查阅GAS语法结构官方手冊

我们先来看一个完整的ARM汇编程序:

C代码:

  1. #include <stdio.h>
  2. int main(int argc, char* argv[]){
  3. printf("Hello ARM!\n");
  4. return 0;
  5. }

相应的汇编代码:

  1. .arch armv5te
  2. .fpu softvfp
  3. .eabi_attribute 20, 1
  4. .eabi_attribute 21, 1
  5. .eabi_attribute 23, 3
  6. .eabi_attribute 24, 1
  7. .eabi_attribute 25, 1
  8. .eabi_attribute 26, 2
  9. .eabi_attribute 30, 6
  10. .eabi_attribute 18, 4
  11. .file "hello.c"
  12. .section .rodata
  13. .align 2
  14. .LC0:
  15. .ascii "Hello ARM!\000"
  16. .text
  17. .align 2
  18. .global main
  19. .type main, %function
  20. main:
  21. @ args = 0, pretend = 0, frame = 8
  22. @ frame_needed = 1, uses_anonymous_args = 0
  23. stmfd sp!, {fp, lr}
  24. add fp, sp, #4
  25. sub sp, sp, #8
  26. str r0, [fp, #-8]
  27. str r1, [fp, #-12]
  28. ldr r3, .L3
  29. .LPIC0:
  30. add r3, pc, r3
  31. mov r0, r3
  32. bl puts(PLT)
  33. mov r3, #0
  34. mov r0, r3
  35. sub sp, fp, #4
  36. ldmfd sp!, {fp, pc}
  37. .L4:
  38. .align 2
  39. .L3:
  40. .word .LC0-(.LPIC0+8)
  41. .size main, .-main
  42. .ident "GCC: (GNU) 4.4.3"
  43. .section .note.GNU-stack,"",%progbits

以下分部分介绍这段代码的结构。

一 处理器架构定义

  1. .arch armv5te @处理器架构
  2. .fpu softvfp @协处理器类型
  3. .eabi_attribute 20, 1 @接口属性
  4. .eabi_attribute 21, 1
  5. .eabi_attribute 23, 3
  6. .eabi_attribute 24, 1
  7. .eabi_attribute 25, 1
  8. .eabi_attribute 26, 2
  9. .eabi_attribute 30, 6
  10. .eabi_attribute 18, 4

1.1 处理器架构

.arch指定了ARM处理器架构。armv5te表示本程序的代码能够执行在armv5te架构的处理器上执行。

1.2 协处理器类型

.fpu指定协处理器的类型。

softvfp表示使用浮点数运算库来模拟协处理器运算。还能够用vfpv2、vfpv3来指定自带的协处理器。

1.3 接口属性

.eabi_attrbute指定了一些接口。

EABI(Embedded Application Binary Interface)嵌入式应用二级制接口是ARM指定的一套接口规范。Android系统实现了它。

二 段定义

  1. .file "hello.c"
  2. .section .rodata
  3. .align 2
  4. .LC0:
  5. .ascii "Hello ARM!\000"
  6. .text
  7. .align 2
  8. .global main
  9. .type main, %function
  10. main:
  11. @ args = 0, pretend = 0, frame = 8
  12. @ frame_needed = 1, uses_anonymous_args = 0
  13. stmfd sp!, {fp, lr}
  14. add fp, sp, #4
  15. sub sp, sp, #8
  16. str r0, [fp, #-8]
  17. str r1, [fp, #-12]
  18. ldr r3, .L3
  19. .LPIC0:
  20. add r3, pc, r3
  21. mov r0, r3
  22. bl puts(PLT)
  23. mov r3, #0
  24. mov r0, r3
  25. sub sp, fp, #4
  26. ldmfd sp!, {fp, pc}
  27. .L4:
  28. .align 2
  29. .L3:
  30. .word .LC0-(.LPIC0+8)
  31. .size main, .-main
  32. .ident "GCC: (GNU) 4.4.3"
  33. .section .note.GNU-stack,"",%progbits

ARM中段的定义格式例如以下所看到的:

  1. .section name , "flags", %type, flag_specific_arguments
  • name:段名
  • flags:段的属性。如读、写和可执行等。
  • type:段的类型,如progbits表示段中含有数据。note表示段中包括的数据并不是程序本身使用。
  • flag_specific_arguments:指定了一些平台相关的參数。

三 凝视与标号

GNU ARM支持两种凝视加入方式。

/* */型凝视

  1. /* args = 0, pretend = 0, frame = 8 */
  2. /* frame_needed = 1, uses_anonymous_args = 0 */

@型凝视

  1. @ args = 0, pretend = 0, frame = 8
  2. @ frame_needed = 1, uses_anonymous_args = 0

四 汇编器指令

  1. .file "hello.c"
  2. .section .rodata
  3. .align 2
  4. .LC0:
  5. .ascii "Hello ARM!\000"
  6. .text
  7. .align 2
  8. .global main
  9. .type main, %function

程序中全部以.开头的指令都是汇编器指令,汇编器指令是与汇编器相关的,它们并不属于ARM指令集。

  • .file:指定源文件名称。
  • .align:指定代码的对齐方式。后面跟的数值是2的次数方。
  • .ascii:声明字符串。
  • .global:声明全局符号,全局符号是指在本程序外能够訪问的符号,
  • .type:指定符号的类型。
  • .word:用来存放地址值。
  • .size:设置指定符号的大小。

  • .ident:编译器标识。无实际用途。

五 子程序与參数传递

子程序在代码表示一个独立的功能。非常多时候。子程序和代码是同样的概念。在汇编中声明函数的方式例如以下所看到的:

  1. .global 函数名
  2. .type 函数名 %Function
  3. 函数名:
  4. ...
  5. 函数体
  6. ...

那么函数调用过程中。參数传递的方式例如以下所看到的:

ARM汇编中规定:R0~R3这4个寄存器分别用来传递函数调用的第1到第4个參数。超出的參数通过堆栈来传递。R0寄存器用来存放函数调用的返回值。被调用的函数在返回前无需恢复这些寄存器的内容。

【基于Android的ARM汇编语言系列】之三:ARM汇编语言程序结构的更多相关文章

  1. 【基于Android的ARM汇编语言系列】之五:ARM指令集与Thumb指令集

    作者:郭嘉 邮箱:allenwells@163.com 博客:http://blog.csdn.net/allenwells github:https://github.com/AllenWell [ ...

  2. ARM的体系结构与编程系列博客——ARM处理器系列介绍

    ARM处理器系列介绍 现在到了3月,过年过得过于舒服了.系列博客也停更了近半月,我果然是个慢(lan)性(gui)子,那么趁着到校的第一天晚上,就写一篇博客来继续我的系列博客了!众所周知,ARM处理器 ...

  3. ARM v8-A 系列CPU的MMU隐射分析

    ARM v8-A 系列CPU的MMU隐射分析 摘要:V8-A系列CPU有ELX,X为0~3等4个异常级别,又有AArch64和AArch32两种执行状态,异常级别可以决定执行状态,而对应着执行状态,M ...

  4. ARM版本系列及家族成员梳理

    ARM公司简介 ARM是Advanced RISC Machines的缩写,它是一家微处理器行业的知名企业,该企业设计了大量高性能.廉价.耗能低的RISC (精简指令集)处理器. 1985年第一个AR ...

  5. 一点理解之 CmBacktrace: ARM Cortex-M 系列 MCU 错误追踪库

    @2019-02-14 [小记] CmBacktrace: ARM Cortex-M 系列 MCU 错误追踪库,用来将单片机故障状态寄存器值翻译出来输出至终端上以便排错 CmBacktrace: AR ...

  6. ARM v7-A 系列CPU的MMU隐射分析

    ARM v7-A 系列CPU的MMU隐射分析 摘要:ARM v7-A系列的CPU加入了很多扩展,如多核处理器扩展.大物理地址扩展.TrustZone扩展.虚拟化扩展.若支持大的物理地址,则必须支持多核 ...

  7. linux驱动系列之arm汇编

    在arm平台学习linux时,会遇到arm汇编指令,arm汇编指令与8086汇编指令很多地方都不同,在此记下来以免后面忘了,同时在学习了汇编指令之后分析一些汇编指令编写的代码. 一.相对跳转指令b.b ...

  8. 基于Android的小巫新闻客户端开发系列教程

    <ignore_js_op> 141224c6n6x7wmu1aacap7.jpg (27.51 KB, 下载次数: 0) 下载附件  保存到相册 23 秒前 上传   <ignor ...

  9. Sql Server来龙去脉系列之三 查询过程跟踪

    我们在读写数据库文件时,当文件被读.写或者出现错误时,这些过程活动都会触发一些运行时事件.从一个用户角度来看,有些时候会关注这些事件,特别是我们调试.审核.服务维护.例如,当数据库错误出现.列数据被更 ...

随机推荐

  1. HDU 2686 Matrix(最大费用流)

    Matrix Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Sub ...

  2. 求好用的在线手册编写工具,能编写像bootstrap在线Doc那种的,想为OpenCenter写个在线手册

    原文地址:http://www.oschina.net/question/1014458_225711 各位OSCer的开源项目的在线说明文档都是用什么写的呢? 类似 http://v3.bootcs ...

  3. Extjs gridPanel 动态指定表头

    var colMArray = new Array(); colMArray = [{header : "产品代码", dataIndex : "cpdm", ...

  4. 在mac上命令行里面如何打开文本编辑器?

    在mac上命令行里面如何打开文本编辑器?   在linux命令行terminal上使用gedit直接就可以打开文本文件 那么在mac上面如何操作呢? 使用:open -a TextEdit setti ...

  5. 新买的mac笔记本,发现vi编辑器没有颜色的解决方案

    新买的mac笔记本,发现vi编辑器没有颜色的解决方案 我在网络上找了一些资料,发现都有些问题,尤其是一些让修改根目录上的文件,发现根本无法修改. 但是在网络上找到了这篇文章: http://super ...

  6. 跨平台app开发(引擎)工具的选择【转】

    跨平台app开发(引擎)工具的选择 1.html5执行速度慢,用户体验不好 2.原生应用开发,即ios和安卓分别开发,需要两种技术人员,后期代码维护困难,很难达到统一. 3.xamarin是一款c#的 ...

  7. Bridge 桥接模式 MD

    桥接模式 简介 将抽象部分与实现部分分离,使它们都可以独立的变化. 业务抽象角色引用业务实现角色,或者说业务抽象角色的部分实现是由业务实现角色完成的 Bridge模式基于类的最小设计原则,通过使用封装 ...

  8. 如果不用jQuery,Ajax你还能写出多少?

    许久之前发过一篇关于Ajax的博客,通篇讲的都是通过jQuery编写Ajax,可能因为jQuery在这方面做的实在太好,以至于突然发现不用jQuery的话自己都模糊了Ajax的写法,这里重温一下. F ...

  9. HttpClient4.3.3 使用样例—获取静态资源

    HttpClient4.3.3 使用样例—获取静态资源 学习了:http://shihlei.iteye.com/blog/2067688

  10. 一直出现 Enter passphrase for key '/root/.ssh/gitkey12.pub'

    案例: 我一下没有设置密码的pub key, 一使用就要求: Enter passphrase for key '/root/.ssh/gitkey12.pub',   原因:本该设置私钥的地方,设置 ...