- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
FFH TH-6ren">
来自 https://www.felixcloutier.com/x86/div :
...
temp ← AX / SRC;
IF temp > FFH
THEN #DE; (* Divide error *)
ELSE
AL ← temp;
AH ← AX MOD SRC;
FI;
...
对于
div ah
SRC
将是
ah
.恕我直言
temp
将始终大于
FFH
因此将引发异常,因为:
FFH
最佳答案
没错,就像div edx
如果没有故障,它永远无法使用。 2N/N => N 位的标准 div
不溢出其商是 high_half(dividend) < divisor
,正如你所展示的,所以使用 divisor = high(dividend)
将始终溢出(或除以零)。 Why "DIV EDX" in MASM always generates processor exception?用另一种方式解释同样的事情。
有趣的一点是,这是一种有保证的单指令方式来引发 #DE
但是,不需要任何指令将值放入寄存器。
(在保护模式下,int 0
并不完全相同。例如,在 Linux 下,在用户空间 int 0
将 #GP
-> SIGSEGV,因为对 IDT 条目的权限,而实际的除法异常将 #DE
-> SIGFPE)。
正如 Jester 指出的那样,该编码仅占 F6 /6 div r/m8
的 2^5 种可能编码中的一种。 ,只计算 ModRM 字节(不是寻址模式可以使用的额外字节的巨大可能性)。
使其不可编码将需要在解码器中使用额外的晶体管。然后你如何处理这个 2 字节的序列? #UD
非法指令异常?太傻了,就让它养#DE
在正常解码并像其他任何地方一样进入执行单元后 div
操作说明。或者将它用于其他一些特殊的事情,例如 mfence
?
拥有 div ah
的 2 字节机器码可能并不是真正明智的设计决定。实际上意味着一些完全不同的单一指令。无论如何,那艘船以 8086 航行,它将在那里升起 #DE
,不是 #UD
;任何更改都会破坏向后兼容。由于为新操作码寻找新编码空间的方法较少(例如 the illegal encodings of lds
and les
or whatever that VEX prefixes borrow ),因此英特尔和 AMD 还没有陷入这种疯狂。那些 LES/LDS 32 位模式编码已经提出 #ud
而不是另一个异常(exception),更重要的是有更多的空闲位,因此 VEX 前缀有空间实际编码那些 2 或 3 字节前缀中的某些字段。
关于assembly - i386 指令 "div ah"毫无意义吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63273843/
我有一张 table People (First_Name, Last_Name)。此表包含与示例中一样重复的记录(并非所有行都重复): First_Name Last_Name John
我用 Java 编写过很多程序,之前也涉足过 C++。我在各种 C++ 书籍中阅读了有关指针的内容,并完成了书籍中的各种示例。 我了解指针的基础知识,但有一件事我一直不清楚。指针在现实世界中的应用是什
线 .Mappings(m => m.FluentMappings.AddFromAssemblyOf() 它有什么作用?它会在派生自 ClassMap 的 Product 类的程序集中查找任
我有用于打印数字的自定义打印功能。我制作了一个 ASCII 版本和一个 UTF-16LE 版本。 UTF-16LE 版本对 0-9 使用全角代码/字符,对十六进制使用 A-F。在调试我的函数时,我注意
这是我的代码片段: float ab(float); 以后 if(ab(temp)
我在一个项目文件中包含以下代码: //begin of the file ((window) => { 'use strict'; class View extends GSM.Event
我一直在到处寻找关于 ? 用法的正确解释。和 *。我注意到我可以使用以下方法拒绝所有用户的访问: 如果我想允许某个组,我应该在其上方添加下一行: 但是当我看到人们使用 ? 时,我开始忘记什么意思,
我正在关注 melon js tutorial .这是在我的 HUD.js 文件的顶部。 game.HUD = game.HUD || {} 我以前在其他例子中见过这个。 namespace.some
我正在处理一个包含数千行代码的文件。我正在第 700 行实现一个算法。我经常不得不离开这些行来检查文件中的其他方法。 导航回到我实际编码的地方通常很痛苦。如果我可以在第 700 行设置一个航路点并为其
我遇到了这段代码 do { if (higherQuality && w > targetWidth) { w /= 2; if (w &
uint8_t * const LCDMem = (uint8_t *) &LCDM3; 此代码在 msp430fg4618 培训套件中用于 lcd 配置。谁能解释一下上述代码的含义? 它允许使用 a
上下文 阅读一些内核代码。 问题 我不明白这行是什么意思 *(void **) &(int[2]){0,PAGE_SIZE}; 还有更多,这是什么意思 {0,PAGE_SIZE} 对我来说,它看起来不
我正在查看 Underscore.js 的源代码库,专门用于 map方法(该页面第 85 行左右,并复制到此处): _.map = function(obj, iterator, context)
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我是一名优秀的程序员,十分优秀!