ARM汇编指令

ARM指令

[toc]

逻辑指令

and r0,r1,#0xFF // r0 = r1&0xFF
orr r3,r0,#0x0F // r3 = r0|0x0F
bic r0,r0,#0x03 // 清除r0中的0号位和1号位
tst r0,#0x20 //测试第6位是否为0 ,为0则Z标志置1
cmp r1,r0 //将R1与R0相减做比较,并根据结果设置CPSR的标志位

使能中断和快速中断?

mrs   r0,cpsr
bic   r0,r0,#0xc0
msr   cpsr,r0

判断当前工作状态是否是ARM状态,是则切换到user 工作模式?

mrs   r0,cpsr
tst   r0,#0x20
andeq   r0,r0,#0xFFFFFFE0
orreq   r0,r0,#0x10
msreq   cpsr,r0

算数指令

add r0,r1,r2 //r0=r1+r2
sub r0,r1,#3 //r0= r1 - 3
sub r0,r1,r2,LSL#1
mul r1,r2,r3 //r1=r2*r3

跳转指令

b main //跳转到标号为main地代码处
bl func //保存下一条要执行的指令的位置到 LR寄存器,跳转函数func
//当跳转代码结束后,用MOV PC,LR指令跳回来
beq addr //当CPSR寄存器中的Z条件码置位时,跳转到该地址处
bne addr //当不等时,跳转到地址addr

例1:函数调用

用汇编实现下面功能

void main(void)
{
    int ret=0;
    func1(2);
    while(1) {};    
}   
func1(int a)
{
    if(a==2)
        return func2(a);
    else
        return func3(a);  
}
func2(int a) 
{    
    return a+3;
} 
func3(int a)
{    
    return a-1;
} 
    .text
    
    main:
    mov r0, #0
    mov r1, #2
    bl func1
    
    main_end:
    b main_end
    
    func1:
    mov r12, lr
    cmp r1, #2
    bleq func2
    blne func3
    
    func1_end:
    mov pc, r12
    
    func3:
    sub r1, #1
    mov pc, lr
    
    func2:
    add r1, #3
    mov pc, lr
    
    .end

例2:延时1s函数


    .text
main:
    bl delay1s

main_end:
    b main_end
    
delay1s:
    ldr r5, =0x3fffff
    loop:
        cmp r5, #0
        beq delay1s_end
        sub r5, #1
        b loop
delay1s_end:
    mov pc, lr
    .end

例3:求最大公约数

用汇编实现求最大公约数?(如9 15 值是3)

int GCD(int a,int b)
{         
    while(1)
    {
        if(a==b)
        break;  
        if(a>b){
            a=a-b;
        }else{
            b=b-a;      
        }
    }       
    return a;          
} 
    .text
main:
    mov r0, #9
    mov r1, #15
    bl gcd

main_end:
    b main_end
    
gcd:
    loop:
        cmp r0, r1
        beq gcd_end
        subgt r0, r0, r1
        sublt r1, r1, r0
        b loop

gcd_end:
mov pc, lr
    .end

Load/Store 指令

注:load/store架构规定,存储器之间不能直接拷贝,需通过寄存器做中转

ldr r0,[r1] (load) //r0=*r1 r1里存放的是地址,把该地址里存放的内容读入到r0中
//LDRB(byte) LDRH(half word)

ldr r0,[r1,#8] //r0=*(r1+8) 存储器地址为r1+8的字数据读入寄存器0。
ldr pc,_irq // pc = *(_irq) 将标号中的内容放入pc中

str r0,[r1] (store) // *r1 = r0 将寄存器r0中值写入到存储器地址为r1的空间中

str r0,[r1],#4 // r0=*r1, r1=r1+4 将r0 中的字数据写入以r1为地址的内存中,并将新地址r1+4 写入r1

str r0,[r1,#4] //*(r1+4)=r0 将r0 中的字数据写入以r1+4 为地址的内存中

Pre or Post Indexed 寻址

例4:拷贝srcBuf里内容到destBuf中


    .text
main:
    mov r0, #9
    ldr r5, =buf
    ldr r6, =dest_buf
    ldr r0, [r5]
    
    str r0, [r6]

main_end:
    b main_end

mov pc, lr


    .data
    
@ char buf[]={}
        buf:
            .byte 0x01, 0x02, 0x03, 0x04
            
    dest_buf:
        .space 8
    .end

例5:拷贝函数

实现以下函数:

main()
{
    int i=0;
    const  char buf[]={1,2,3};
    char destBuf[8];
        for(i=0,i<3,i++)
        {
        destBuf[i] = buf[i];
        }
}

    .text
main:
    mov r5, #0
    ldr r7, =buf
    ldr r8, =dest_buf
    
    loop:
        cmp r5, #3
        beq main_end
        add r5, #1
        ldrb r0, [r7], #1
        strb r0, [r8], #1
        b loop
        
main_end:
    b main_end

mov pc, lr

buf:
    .byte 1,2,3
    
    .data
dest_buf:
    .space 8
    .end

GNU汇编伪指令

.text 将定义符开始的代码编译到代码段
.data 将定义符开始的代码编译到数据段

.end 文件结束

.equ GPG3CON, 0XE03001C0 定义宏(即用GPG3CON代替 0XE03001C0)
.byte 定义变量 1字节
.byte 0x11,'a',0 定义字节数组
.word 定义word变量 (4字节 32位机)
.word 0x12344578,0x33445566
.string 定义字符串 .string "abcd\0"

ldr r0,=0xE0028008 载入大常数0xE0028008 到r0中
.global _start 声明_start 为全局符号

例6:拷贝ROM中字符串到RAM中

   .text
start:
    ldr  r5,=srcBuf
    ldr  r6,=destBuf
loop:
    ldrb r4,[r5]
    cmp  r4,#0
    beq  main_end
    ldrb  r0,[r5],#1
    strb  r0,[r6],#1    
    b   loop
main_end:
    b    main_end
srcBuf:
    .string  "abcdefg\0"
    .data 
destBuf:
    .space  8
    .end

批量操作指令

批量操作指令 (ia-Increment After ib-Increment Before da-Dec After db-Dec Before)
ldmia r0!, {r3 - r10} //r0里地址指向的内容批量,load 到r3~r10寄存器中, r0里地址会自动加4
stmia r0!, {r3 - r10} //把r3~r10寄存器中内容,store 到r0里地址执行空间中,r0里地址会自动加4

例7:批量拷贝数据

.text
   ldr r12,=srcBuf
   ldr r13,=dstBuf
   ldmia  r12!,{r0 - r11}
   stmia  r13!,{r0 - r11}

  .data
srcBuf:
  .string "abdfasdf13535dfksjdlfkjlksldkjflkl\0"
srcBuf_end:  

dstBuf:
  .space  12*4
  .end

堆栈操作指令

stmfd sp!,{r0-r12,lr} 将寄存器r0~r12 lr中的值存入栈中
常用于中断保护现场,! 表示会自动偏移
ldmfd sp!,{r0-r12,pc}^ 将栈中值逐个弹出到寄存器r0~r12 pc中
常用于中恢复断现场,^表示会恢复spsr到cpsr

软中断指令

swi 0x22 产生软中断,软中断号为2

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容

  • 1.跳转指令 B 无条件跳转 BL 带链接的无条件跳转 BX 带状态切换的无条件跳转 根据目标地址最低位切换...
    vipzher阅读 629评论 0 1
  • ARM汇编指令编程之寄存器中数据调换顺序 题目:将R0中的数据调换顺序;例如:R0=0XAABBCCDD调换顺序后...
    HurryChen阅读 1,114评论 0 0
  • https://8biiit.github.io/2019/09/04/Arm%E6%8C%87%E4%BB%A4...
    萌小菜阅读 2,653评论 0 0
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 8,520评论 28 53
  • 人工智能是什么?什么是人工智能?人工智能是未来发展的必然趋势吗?以后人工智能技术真的能达到电影里机器人的智能水平吗...
    ZLLZ阅读 3,763评论 0 5