or1200处理器的数据处理类指令说明

以下内容摘自《步步惊芯——软核处理器内部设计分析》一书


      在笔者的分类中,数据处理类指令有48条。表4.1给出了OR1200中实现的所有算术处理类指令及其说明。




      笔者将OR1200的数据处理类指令再细分为如下类别:

  •   比较指令

l.sfeq、l.sfeqi、l.sfges、l.sfgesi、l.sfgeu、l.sfgeui、l.sfgts、l.sfgtsi、l.sfgtu、l.sfgtui、l.sfleu、l.sfleui、l.sfles、l.sflesi、l.sflts、l.sfltsi、l.sfltu、l.sfltui、l.sfne、l.sfnei

  •   移位指令

l.rori、l.sll、l.slli、l.sra、l.srai、l.srl、l.srli

  •   逻辑运算指令

l.and、l.andi、l.or、l.ori、l.xor、l.xori

  •   算术运算指令

l.add、l.addc、l.addi、l.addi

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
开源处理器源代码,学习优秀的代码编写 ////////////////////////////////////////////////////////////////////// //// //// //// OR1200's ALU //// //// //// //// This file is part of the OpenRISC 1200 project //// //// http://www.opencores.org/cores/or1k/ //// //// //// //// Description //// //// ALU //// //// //// //// To Do: //// //// - make it smaller and faster //// //// //// //// Author(s): //// //// - Damjan Lampret, lampret@opencores.org //// //// //// ////////////////////////////////////////////////////////////////////// //// //// //// Copyright (C) 2000 Authors and OPENCORES.ORG //// //// //// //// This source file may be used and distributed without //// //// restriction provided that this copyright statement is not //// //// removed from the file and that any derivative work contains //// //// the original copyright notice and the associated disclaimer. //// //// //// //// This source file is free software; you can redistribute it //// //// and/or modify it under the terms of the GNU Lesser General //// //// Public License as published by the Free Software Foundation; //// //// either version 2.1 of the License, or (at your option) any //// //// later version. //// //// //// //// This source is distributed in the hope that it will be //// //// useful, but WITHOUT ANY WARRANTY; without even the implied //// //// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR //// //// PURPOSE. See the GNU Lesser General Public License for more //// //// details. //// //// //// //// You should have received a copy of the GNU Lesser General //// //// Public License along with this source; if not, download it //// //// from http://www.opencores.org/lgpl.shtml //// //// //// //////////////////////////////////////////////////////////////////////
这些指令都是ARM处理器指令,用于进行数据处理。下面是每个指令的简要说明: - MOV:将数据从一个寄存器移动到另一个寄存器中。例如:`MOV r1, r2` 将r2中的值移动到r1中。 - MVN:对一个寄存器中的值取反,并将结果存储到另一个寄存器中。例如:`MVN r1, r2` 将r2中的值取反后存储到r1中。 - CMP:比较两个寄存器中的值,不改变任何寄存器的值。例如:`CMP r1, r2` 比较r1和r2中的值。 - CMN:比较两个寄存器中的值的补码,不改变任何寄存器的值。例如:`CMN r1, r2` 比较r1和r2中的值的补码。 - TST:对两个寄存器中的值进行位运算 AND 操作,并设置标志位。例如:`TST r1, r2` 对r1和r2中的值进行 AND 运算,设置标志位。 - TEQ:对两个寄存器中的值进行异或操作,并设置标志位。例如:`TEQ r1, r2` 对r1和r2中的值进行异或运算,设置标志位。 - SUB:从一个寄存器中的值中减去另一个寄存器中的值,并将结果存储到另一个寄存器中。例如:`SUB r1, r2, r3` 将r2中的值减去r3中的值,结果存储到r1中。 - RSB:从一个寄存器中的值中减去另一个寄存器中的值的相反数,并将结果存储到另一个寄存器中。例如:`RSB r1, r2, r3` 将r3中的值减去r2中的值的相反数,结果存储到r1中。 - AND:对两个寄存器中的值进行位运算 AND 操作,并将结果存储到另一个寄存器中。例如:`AND r1, r2, r3` 对r2和r3中的值进行 AND 运算,结果存储到r1中。 - BIC:对两个寄存器中的值进行位运算 AND NOT 操作,并将结果存储到另一个寄存器中。例如:`BIC r1, r2, r3` 对r2和NOT r3的值进行 AND 运算,结果存储到r1中。 - EOR:对两个寄存器中的值进行异或操作,并将结果存储到另一个寄存器中。例如:`EOR r1, r2, r3` 对r2和r3中的值进行异或运算,结果存储到r1中。 - ORR:对两个寄存器中的值进行位运算 OR 操作,并将结果存储到另一个寄存器中。例如:`ORR r1, r2, r3` 对r2和r3中的值进行 OR 运算,结果存储到r1中。 - CLZ:计算一个寄存器中值的二进制表示中前导零的个数,并将结果存储到另一个寄存器中。例如:`CLZ r1, r2` 计算r2中值的二进制表示中前导零的个数,结果存储到r1中。 这些指令可以通过汇编语言编写成程序,用于数据处理

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值