- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《这一段时间学习汇编》2012-9-18
ARM7 100M-200M mp3
ARM9 200M-400M 诺基亚,车载电视,点菜机,楼宇,工控
ARM11 500M-600M 平板
CORTEX:
M系列: M3 60-100M 工控,单片机
A系列: A8 500-1GHZ 娱乐,消费类电子
R 军工,市场比较少。
寄存器组织:共37个寄存器,7种模式。
R0-R12:通用寄存器;
R13(SP)栈指针寄存器,记录栈地址;
R14:链接返回寄存器,保存程序的返回地址,如函数调用返回。
R15(pc):程序计数器,PC指向哪,CPU就到哪去执行,PC每次自动加4,指令集定长。
CPSR:状态寄存器 current process state risk
M[0-4]:工作模式
T:在ARM模式(32位)或者s(16位)模式,默认在ARM模式下。
F和I位:中断开关位。:
高4位:N,Z,C,V:
N:体现输出正负;Z:输出为0则置位;C:进位/借位标志位;V:移位标志位
cxsf 4个域,主要为c,f两个域。C控制域,x扩展域,s状态域,f标志域
两种模式切换数据保存在PCB中。R13和R14
1.2.3大小端存储:
1.2.4:处理器组成原理:又称为3级流水线
1.预取: PC中的值保存预取中的值 pc的值应为加上3,无论是8级还是多少 pc中的值都是加上3即为预取中的值。
2.译码:
3.执行:
每个程序都要经过三级流水线
开发环境ADS1.2:
Codewarraoior 编辑环境(vim)
Debug:调试版本
Release:发布版本
最后可执行文件在 DebugRel中的.axf格式 与linux下的elf格式一样。
Elf:代码段,数据段,只读段。(io段,bss段,data段)
AXD中开始时file中load imame不能点 ,解决:打开Options中的第三项-选择ARMUL最后点OK
_start:初始化内存,加载库,
R:寄存器调试串口
Window下的memory地址栏 查看内存中的地址
看反汇编 右键第5项
04 08 c 10
汇编指令中加S即影响f标志位置位 汇编执行完后影响cpsr中flag中相关标志位。 汇编条件码为执行条件前进行判断。
操作码:(汇编指令集)
AREA aaa,CODE,READONLY
CODE32 ;32BIT ARM
ENTRY
START
MOV R0,#1
MOV R1,#2
ADD R2,R0,R1
MOVS R3,#0
B START ;LOOP TO START
END
MOV R0,R1
MOV R0,#5
MOV R0,R1 LSL #1 : 把R1中的数逻辑左移,之后放入R0中
MOVEQ R0 ,R1:首先判断CPSR zhong Z 是否置位,置位则mov r1移动到r0
MOVEQS R0 ,R1 :
MVN:数据取反传输;
MVN R0 ,#0 使0取反为ffffffff 放入R0中
ADD
ADD R0,R2,R3
ADDS R0,R1,#3
Adc:
ADC R0,R1,R2即为R0= R1+R2+c标志位.一定要加上进位等
SUB:
SUB R0,R1,R2
SBC:带借位的减法 其中c的值若有借位置0. 最后应减去c取反
AND:位与;
ORR:wei huo
NOP:空指令
CMP:比较指令 CMP R0,R1 影响标志位
BLCS A :BL 跳转指令
BLCC B
C语言如下:
If(ab)
Printf(a);
Else
Printf(b);
BIC:位清零指令
BIC R0, R1 ,#0XFF 把R1中低八位清零之后放入R0中。
与内存相关的仅有这两个指令::
LDR: load 内存到寄存器
STR: store 从寄存器到内存
R0 = 123
R1 = 0X80000
STR R0,[R1] 把123这个数存进0x80000这个地址
LDR R0,[R1]
STRH R0,[R1]:操作一个short类型(低字节)
LDRH
STRB R0,[R1] 低一个字节:
STR :偏移量,要求偏移量在4k以内
STR R0,[R1,#-4] R1向左偏移4位放入R0,此时R1中值不变,假如加上一个! 称为回写符,回写R1
STR R0,[
您可能关注的文档
最近下载
- 学校教学楼采暖改造投标方案施工组织设计.doc VIP
- 能源转型关键矿产的“资源民族主义”抬头趋势——基于2023–2025年印尼、智利、墨西哥出口管制.docx VIP
- 养老院入院协议合同协议表格模板实用文档-养老院入院协议百.pdf VIP
- 湘少版三年级英语上册全册教案.pdf VIP
- T-CIAS-3-2020建筑设备安装工程支吊架计算书编制标准.pdf VIP
- 加味左金丸治疗肝胃不和型反流性食管炎临床观察.pptx VIP
- 新苏教版二年级下册道德与法治期末测试.docx VIP
- 地下管网cctv检测报告.docx VIP
- (高清版)DB12∕T 1115-2021 泵站工程运行管理规程.pdf VIP
- ZP型矿用自动洒水降尘装置说明书.doc VIP
原创力文档


文档评论(0)