ARM协处理器处理指令介绍

ARM指令协处理器处理指令

ARM支持16个协处理器,在程序执行过程中,每个协处理器忽略属于ARM处理器和其他协处理器指令,当一个协处理器硬件不能执行属于她的协处理器指令时,就会产生一个未定义的异常中断,在异常中断处理程序中,可以通过软件模拟该硬件的操作,比如,如果系统不包含向量浮点运算器,则可以选择浮点运算软件模拟包来支持向量浮点运算

 

ARM协处理器指令包括如下三类:

1用于ARM处理器初始化ARM协处理器的数据操作

2:用于ARM处理器的寄存器和ARM协处理器的寄存器间的数据传送操作

3:用于在ARM协处理器的寄存器和内存单元之间传送数据

 

这些指令包括如下5条

CDP协处理器数据操作指令

LDC协处理器数据读入指令

STC协处理器数据写入指令

MCR ARM寄存器到协处理器寄存器的数据传送指令

MRC 协处理器寄存器到ARM寄存器的数据传送指令

 

 

使用方法:

CDP p5, 2,c12,c10,c3,4  ;协处理器p5的操作初始化,其中操作码1为2,操作码2为4,目标寄存器为c12,源操作数寄存器位c10,和c3

 

LDC 指令从一系列连续的内存单元将数据读取到协处理器的寄存器中,如果协处理器不能成功的执行该操作,将产生未定义的指令异常操作

实例:
LDC p6, CR4,[R2,#4];R2为ARM寄存器,指令读取内存单元R2+4的字数据,传送到协处理器p6的CR4寄存器中

 

 

STC(协处理器数据写入指令)

STC指令将协处理器的寄存器中的数据写入一些列内存单元中

实例:

STC p8,CR8,[R2,#4]! ;R2为ARM寄存器,
指令将协处理器P8的CR8寄存器中的字数据写入到内存单元(R2+4)中,
然后执行R2=R2+4操作

 

 

 

MCR(ARM寄存器到协处理器寄存器的数据传送指令)

MCR 指令将ARM处理器的寄存器中的数据传送到协处理器的寄存器中,如果协处理器不能成功执行该操作,将产生未定义的指令异常中断

实例

MCR p14,3,R7,c7,c11,6 ;指令从ARM寄存器中将数据传送到协处理器p14的寄存器中,
其中R7为ARM寄存器,存放源操作数,C7和C11位协处理器
寄存器,为目标寄存器,操作码1为3,操作码2为6

 

 

MRC协处理器寄存器到ARM寄存器的数据传送指令

MRC指令将协处理器寄存器中的数值传送到ARM的寄存器中,如果协处理器不能成功的执行这些操作,那么将产生未定义的指令异常中断

实例
MRC p15,2,R5,c0,c2,4  ;指令将协处理器p15寄存器中的数据传送到ARM寄存器中,
其中,R5为ARM寄存器,是目标寄存器,C0和C2为协处理器
寄存器,存放源操作数,操作码1为2,操作码2为4

 

转载请注明链接地址:http://www.cnblogs.com/fengdashen/p/3858441.html

0
0
« 上一篇: C++ 编程输入输出语句
» 下一篇: C++的笔记学习第一篇,认识C++
	</div>
	<div class="postDesc">posted @ <span id="post-date">2014-07-21 15:10</span> <a href="https://www.cnblogs.com/fengdashen/">跨七海的风</a> 阅读(<span id="post_view_count">1205</span>) 评论(<span id="post_comment_count">0</span>)  <a href="https://i.cnblogs.com/EditPosts.aspx?postid=3858441" rel="nofollow">编辑</a> <a href="#" "AddToWz(3858441);return false;">收藏</a></div>
</div>
<script type="text/javascript">var allowComments=true,cb_blogId=159269,cb_entryId=3858441,cb_blogApp=currentBlogApp,cb_blogUserGuid='d2beb5d0-eefb-e211-8d02-90b11c0b17d6',cb_entryCreatedDate='2014/7/21 15:10:00';loadViewCount(cb_entryId);var cb_postType=1;var isMarkdown=false;</script>
</div><!--end: forFlow -->
</div>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值