ARM体系结构与编程-5
GET通经常使用于包括定义常量的源文件。
比如:GET 2440addr.inc
用AREA定义一个段。ENTRY用于指定程序的入口点,END用于告诉汇编器源文件已经结束。
比如:
AREA init, CODE, READONLY
ENTRY
......
END
EQU用于定义常量,提醒:在每条ARM指令前必须有空格。可是用EQU定义常量时,必须顶格写,否则编译器报错。
LTORG用于声明一个文字池,所谓文字池就是一个数据缓存区。
ALIGN伪操作通过调整地址指针,使得当前地址满足一定的对齐方式。在ARM代码中要求地址标号是字对齐的。
MACRO和MEND伪操作用于宏定义。语法例如以下:
MACRO
{$label} MacroName {$parameter1} {$parameter2} ...
;这里加入自己的代码
MEND
当中:$label代表一个标号,在宏展开时。替换成对应的值。
MacroName用于指定宏名称。
$parameter代表要传递的參数。
{}中的项表示是可选的。
比如:
MACRO
$label HANDLER $HandleAddr
$label
sub sp, sp, #4
stmfd sp!, {r0}
ldr r0, =$HandleAddr
ldr r0, [r0]
str r0, [sp, #4]
ldmfd sp!, {r0, pc}
MEND
在程序中能够通过例如以下方式调用该宏:HandlerIRQ HANDLER HandleIRQ
宏展开结果例如以下:
HandlerIRQ
sub sp, sp, #4
stmfd sp!, {r0}
ldr r0, =HandleIRQ
ldr r0, [r0]
str r0, [sp, #4]
ldmfd sp!, {r0, pc}
MAP用于定义内存表的首地址,当中MAP能够用^表示。
FIELD用于定义一个内存表中的数据域,当中FIELD能够用#表示。用法例如以下所看到的:
_ISR_STARTADDRESS EQU0X33FFFF00
MAP _ISR_STARTADDRESS
HandleReset FIELD 4
;HandleReset的地址范围为0X33FFFF00~0X33FFFF03
HandleUndef FIELD4
;HandleUndef的地址范围为0X33FFFF04~0X33FFFF07
HandleSWI FIELD4
;HandleSWI的地址范围为0X33FFFF08~0X33FFFF0B
HandlePabrt FIELD4
;HandlePabrt的地址范围为0X33FFFF0C~0X33FFFF0F
HandleDabrt FIELD4
;HandleDabrt的地址范围为0X33FFFF10~0X33FFFF13
以上定义内存表的方式等价于例如以下方式:
_ISR_STARTADDRESS EQU 0X33FFFF00
^ _ISR_STARTADDRESS
HandleReset #4
;HandleReset的地址范围为0X33FFFF00~0X33FFFF03
HandleUndef #4
;HandleUndef的地址范围为0X33FFFF04~0X33FFFF07
HandleSWI #4
;HandleSWI的地址范围为0X33FFFF08~0X33FFFF0B
HandlePabrt #4
;HandlePabrt的地址范围为0X33FFFF0C~0X33FFFF0F
HandleDabrt #4
;HandleDabrt的地址范围为0X33FFFF10~0X33FFFF13
建立好上述内存表之后,能够从C源文件里通过例如以下方式訪问:
#define pISR_SWI (*(unsigned int*)(_ISR_STARTADDRESS+0x8))
ARM伪指令:中等范围的地址读取指令ADRL、大范围的地址读取指令LDR 比如:
ADRL R1, var1 ;表示把var1的地址读取到R1中去。
var1 DCD 5
LDR R1, =var1 ;表示把var1的地址读取到R1中去。
var1 DCD 5
DCD用于分配一块连续的内存单元,并用expr初始化:{label} DCD expr{,expr}...
label代表所分配的内存单元的地址。
SPACE用于分配一块内存单元,并将其初始化为0:{label} SPACE expr
label代表内存块的起始地址,expr表示所要分配的内存字节数目
比如: zero SPACE 12 即分配12个字节长度的连续内存单元
ARM汇编程序的结构:
ARM源程序有下面几种类型:
*.s:汇编语言源文件
*.inc:被汇编源文件包括的文件
*.c:C语言源文件
*.h:头文件
编写汇编语言源文件的格式规范:
全部标号必须在一行的顶格书写
全部的指令均不能顶格书写。指令前应该有空格或Tab缩进
凝视内容由";"開始到此行结束
指令、寄存器能够所有为大写或者小写字母,但不能大写和小写字母混用
定义变量、常量时。其标志符必须在一行的顶格书写
经常使用汇编语言程序子模块实例:
<1>关闭看门狗定时器
WTCON EQU 0X53000000
LDR R0, =WTCON
MOV R1, #0
STR R1, [R0]
<2>内存数据复制:如果R1指向源数据块的起始地址,R2指向源数据块的结束地址。R3指向目的数据块的起始地址。
loop
LDR R0, [R1], #4
STR R0,[R3]. #4
CMP R1,R2
BCC loop
<3>批量载入与存储:初始化SDRAM。SMRDATA是在内存中定义的一个数据表。占领13个字(52字节)的空间;BWSCON是2440处理器的存储控制器寄存器的起始地址。
ADRL R0, SAMRDATA
LDMIA R0, {R1-R13}
LDR R0, = BWSCON
STMIA R0, {R1-R13}
<4>堆栈操作:堆栈初始化
FIQMODE EQU
0X11
IRQMODE EQU 0X12
SVCMODE EQU 0X13
MODEMASK EQU 0X1F
NOINT EQU 0XC0
_STACK_BASE_ADDRESS EQU 0X33FF8000
FIQStack EQU (_STACK_BASE_ADDRESS-0X0) ;0X33FF8000~
IRQStack EQU (_STACK_BASE_ADDRESS-0X1000) ;0X33FF7000~
SVCStack EQU (_STACK_BASE_ADDRESS-0X2800) ;0X33FF5800~
InitStacks
MRS R0, CPSR
BIC R0, R0, #MODEMASK
ORR R1, R0, #IRQMODE | NOINT
MSR CPSR_CXSF, R1;IRQMode
LDR SP, =IRQStack;IRQStack=0x33FF7000
ORR R1, R0, #FIQMODE | NOINT
MSR CPSR_C, R1;FIQMode
LDR SP, =FIQStack;FIQStack=0x33FF8000
BIC R0, R0, #MODEMASK | NOINT
ORR R1, R0, #SVCMODE
MSR CPSR_CXSF, R1;SVCMode
LDR SP, =SVCStack;SVCStack=0x33FF5800
MOV PC, LR
<5>实现查表功能:
MOV R9, #4
LDR R8, =DATATABLE
LDR R8, [R8,R9,LSL,#2]
DATATABLE DCD 0X10, 0X20, 0X30, 0X40, 0X50
DCD 0X60, 0X70, 0X80, 0X90, 0XA0
/**************************************************************/
在基于ARM处理器的裸机程序开发中,启动代码主要用于为执行用户程序准备主要的执行环境。
它主要实现下面功能:
<1>建立异常中断向量表
<2>初始化各种模式下的堆栈
<3>初始化硬件:包含
关闭看门狗
屏蔽全部中断
初始化时钟
初始化存储系统:NandFlash、NorFlash、SDRAM等
<4>初始化应用程序运行环境:代码的搬移和未初始化数据段ZI的清零。
一个ARM映像文件主要由RO、RW、ZI段构成。
<5>跳转到主程序(用户程序)运行。
ARM体系结构与编程-5的更多相关文章
- ARM体系结构与编程-3
ARM存储系统:ARM中用于存储管理的系统控制协处理器CP15:包括16个32位寄存器,其编号为0到15.实际上对于某些编号的寄存器可能相应有多个物理寄存器. 訪问CP15寄存器的指令:MRC.MCR ...
- ARM体系结构与编程
ARM处理器的7中执行模式:usr.fiq.irq.svc.abt.und.sys. ARM处理器共37个寄存器:31个通用寄存器(未备份寄存器R0-R7,在全部模式下指的都是同一个物理寄存器:备份寄 ...
- ARM体系结构与编程读书笔记——处理器的寄存器
ARM处理器共有37个寄存器,其中包括: 31个通用寄存器,包括程序计数器(PC)在内,寄存器都是32位: 6个状态寄存器,这些寄存器都是32位的,目前只使用了其中12位: 通用寄存器 可以分为下面3 ...
- ARM体系结构与编程读书笔记——处理器的运行模式
ARM处理器共有7种运行模式,如下表: 处理器模式 描述 用户模式(User, usr) 正常程序执行的模式 快速中断模式(FIQ, fiq) 用于高速数据传输和通道处理 外部中断模式(IRQ, ir ...
- ARM的体系结构与编程系列博客——ARM体系版本
ARM体系版本前言 很多人都知道,ARM有许多版本,口中最长说的就是ARM7\ARM9\ARM11,诚然,这个的确是ARM处理器的版本,但绝对不是ARM的版本,其实ARM到迄今为止经历了6代版本,随着 ...
- ARM的体系结构与编程系列博客——ARM处理器系列介绍
ARM处理器系列介绍 现在到了3月,过年过得过于舒服了.系列博客也停更了近半月,我果然是个慢(lan)性(gui)子,那么趁着到校的第一天晚上,就写一篇博客来继续我的系列博客了!众所周知,ARM处理器 ...
- ARM体系结构和汇编指令
第一节 可编程器件的编程原理 1. 可编程器件的特点 1 . CPU在固定频率的时钟控制下节奏运行 2 . CPU可以通过总线读取外部存储设备中的二进制指令集,然后解码执行 3 . 这些可以被CPU解 ...
- ARM体系结构简介
ARM体系结构简介 新一代的ARM9处理器,能达到两倍ARM7的处理能力,它们的区别如下: ARM微处理器的工作状态(可切换): 第一种为ARM状态,此时处理器执行32位的字对齐的ARM指令 第二种为 ...
- ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(2)- 寄存器
1. 前言 2. 指令运行与异常处理寄存器 ARM体系结构的寄存器分为两类: (1)系统控制和状态报告寄存器 (2)指令处理寄存器,如累加.异常处理 本部分将主要介绍如上第(2)部分的寄存器,分为AA ...
随机推荐
- sqlserver的left join优化
MS sqlserver 对4张表进行left join join字段是varchar类型长度20,也都建了索引,但是光查一个count(Id) 耗时就超过了8秒,数据量只有100多万条,该怎么优化呢 ...
- DS博客作业06—图
1.本周学习总结 1.1思维导图 1.2学习体会 2.PTA实验作业 2.1 图着色问题 图着色问题是一个著名的NP完全问题.给定无向图G=(V,E),问可否用K种颜色为V中的每一个顶点分配一种颜色, ...
- 九度oj 题目1457:非常可乐
题目描述: 大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为.因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶可乐,而且一定要喝的和seeyou一样 ...
- 【bzoj2333】[SCOI2011]棘手的操作 可并堆+STL-set
UPD:复杂度是fake的...大家还是去写启发式合并吧. 题目描述 有N个节点,标号从1到N,这N个节点一开始相互不连通.第i个节点的初始权值为a[i],接下来有如下一些操作: U x y: 加一条 ...
- 扩展kmp--模板解析
扩展kmp: 用于求串的各个后缀与原串的最长公共前缀的长度: 上图的是字符串自匹配的过程: 图一: 假设现在匹配到i-1了,开始求next [ i ] 的值,此时,k记录的是到目前为止匹配到的最远的位 ...
- CSSborder制作小三角形
#cssborder制作小三角形 1.原理是CSS盒模型 一个盒子包括: margin+border+padding+content – 上下左右边框交界处出呈现平滑的斜线. 利用这个特点, 通过设置 ...
- [luoguP3231] [HNOI2013]消毒(最小点覆盖 + 状压)
传送门 考虑贪心,控制某一维为1,另两位最大是最优的,也就是一次选一个厚度为1的面 那么对于每个点,可以有3种面是可以选到它的 然后gg 考虑二维的状态,一个平面,有些点,一次选一行或一列最优 那么每 ...
- 【前端学习笔记】2015-09-01 附 split()方法、readyState
1.split():作用对象是一个字符串或者字符串对象,会要求设置两个参数(分割点(separator),分割出来的数量(number)),ps:1."2:3:4:5".split ...
- <深入理解计算机系统> CSAPP Tiny web 服务器
本文是我学习<深入理解计算机系统>中网络编程部分的学习笔记. 1. Web基础 web客户端和服务器之间的交互使用的是一个基于文本的应用级协议HTTP(超文本传输协议).一个w ...
- node起始——安装并且新建一个node项目
1.安装nodejs和npm http://nodejs.cn/ 2.设置环境变量,安装到那里就在那里配置. 3.express开发框架安装 //命令行输入命令 npm install -g expr ...