跳转到内容

360 汇编/360 指令/DR

来自维基教科书,开放的书籍,面向开放的世界

DR - 除以寄存器 - 操作码 1D

DR 2,7

具体的语法是

DR 目标寄存器, 源寄存器.
RR 指令 (2 字节)
字节 1 字节 2
目标寄存器 源寄存器
(8 位)
操作码
1D
(4 位)

0..F
(4 位)

0..F
  • 第一个参数是一个包含较少对目标寄存器的数字,其值受指令影响。
  • 第二个参数是源值寄存器。

可用性

[编辑 | 编辑源代码]

DR 指令在所有型号的 360、370 和 z/System 上都可用。

DR 指令将被除数 - 存储在 T 和 T+1 寄存器对中的 64 位有符号值(其中 T 是目标寄存器号,T 应包含最高有效位,T+1 应包含最低有效位)除以除数 - 源寄存器中的 32 位有符号值。目标寄存器号 T 应为偶数。该指令将商放入寄存器 T,并将余数放入寄存器 T+1,两者均为 32 位有符号值。

除数不应为零。商应符合 32 位有符号值的限制(-2147483648 到 2147483647)。

DR 指令执行所谓的 T 除法,当商被截断为零时;余数符号等于被除数符号,如果两个值都不等于 0;换句话说,(余数 * 被除数 >= 0)。

程序状态字中的条件码字段不会改变。

异常和故障

[编辑 | 编辑源代码]
  • 如果将奇数寄存器号指定为目标寄存器,则会发生操作异常。
  • 如果除数为零,则会发生操作异常。
  • 如果检测到有符号整数溢出并且 PSW 中的第 36 位被设置,则会发生操作异常。

假设寄存器 4 包含 0,5 - 13 和 11 - 4。指令 "DR 4,11" 将 13 寄存器的内容除以 4,将商(等于 3)放入 4 寄存器,并将余数(等于 1)放入 5 寄存器。

[编辑 | 编辑源代码]
  • 要除以内存中的字值,请参见 D
  • 要乘以寄存器中的字值,请参见 MR
  • 要从寄存器中减去字值,请参见 SR
  • 要添加值并根据无符号算术设置条件码,或添加多字整数值的非最高有效位,请参见 ALALR
  • 要除以浮点数,请参见 DERDDRDEDD
上一条指令
DP
360 汇编指令
{{{name}}}
下一条指令
DSG
上一个操作码
1C
下一个操作码
1E
360 汇编语言
360 系列 介绍 · 基本常见问题解答 · 360 系列 · 360 架构
360 指令集 360 指令 · 分支指令 · 数据传输指令 · 控制流指令 · 算术指令 · 逻辑指令 · 移位和旋转指令 · 特权指令 · 其他指令
语法和汇编器 360 汇编器· 伪指令
指令扩展 浮点 · 高级语言


华夏公益教科书