ARM Linux常用汇编语法

汇编语言每行的语法:

lable: instruction ; comment

段操作: .section
 
 格式: .section 段名 [标志]

[标志]可以是如下:
 
  a 允许段
  w 可写段
  x 可执行段

常见段名: data, bss, text, rodata段,我们也可以定义我们自己的段。

.data: 已初始化数据段
 .bss: 未初始化数据段
 .text:代码段
 .rodata:只读段


编程序的入口点:

通常,linux的汇编程序的入口点都是从_start这个全局符号开始的。而C语言的入口点是main, main函数就是被_start后面的代码调用。

.global _start
_start:
  代码,,, 初始化程序运行环境;
  代码,,,
  ,,,
  bl main
  bl exit
 

linux汇编中常数的使用:

十进制: 以非0 的数字开头表示, 124, 564
 二进制: 以0b开头,如0b101001
 八进制: 以0开始的数字,如05645
 十六进制:以0x开头, 如0xab12
 

linux汇编中常用的伪操作:

数据定义伪操作:

.byte, 定义单个字节, 如, .byte 5, 4, 0b1001, 0x22, 055, 'b'
  .short, 定义半字数据, 如,.short 0x1122, 3344
  .long, 定义4字节数据,如, 0x11223344,
  .word
 
  .string, .asciz, .ascii, 定义字符串数据, 比如.string "hello"

对齐伪操作:  .align n  --> 2^n
 文件结束操作:.end
 文件包含操作:.include, 一般是在文件开头的时候包含头文件时使用
 
 代码指令集切换:
  
  .thumb, .code 16 这两个伪指令告诉编译器从这里开始,以后的代码都编译成16为的thumb指令。
  .arm, .code 32  这两个伪指令告诉编译器从这里开始,以后的代码都编译成32为的arm指令。
  
函数定义格式:
 
 函数名:
   函数体
   函数返回语句

比如add函数:
   .global add
  add:
   add r0, r1, r2
   mov pc, lr


常见符号的意义和用法:
 
 @ : 代码注释符号
 ;   语句分离符号。(相当于C语言中的;)
 #   立即数前缀

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/5b11e2e83b1202278859f63baf8f9825.html