- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在VS2017中调试了以下代码(注意下面的断点):
下面你会发现上面提到的断点的反汇编:
如上图所示,编译器为指令call dword ptr [fp]
生成的机器码是 FF 55 F8
哪里FF
是调用指令的操作码,55
是 ModeR/M
的值字节和 F8
是一个值为 -8 的 8 位位移,我将在下面解释。
现在,如果您查看下面的“表 2-2:带有 ModeR/M 的 32 位寻址形式”字节,该字节来自英特尔的“64 位 IA-32 架构软件开发人员手册”的第 2A 卷,您会注意到我突出显示了上面提到的数字55对应一个有效地址[EBP]+disp8
.也就是说,CALL
汇编器中的指令将跳转到其地址是从寄存器EBP中的地址加上上面提到的8位位移值-8得到的指令。而且这个地址是正确的。它对应于最终将代码传输到函数 f
的 JMP 指令的地址。 .
因此,一切看起来都很好。但是我遗漏了一个重要的点:我应该获得 ModeR/M
byte 使用英特尔手册中的 CALL 指令引用和上面显示的表 2.2。但我仍然不知道如何做到这一点。任何提示都将受到高度赞赏,因为我已经为此工作了几天,但我对此仍然一无所知。
最佳答案
您缺少的是操作码的一部分是在 ModR/M 字节中编码的。通常,ModR/M 字节编码两个操作数。第一个操作数是表左侧行标签中给出的寄存器或内存操作数,而第二个操作数是表顶部列标题给出的寄存器。对于只有一个操作数的指令,如 CALL 指令,第二个操作数用于提供额外的操作码位。
如果您查看 CALL 指令的文档,您会看到“在 r/m32 中给出的绝对间接地址调用”指令的操作码被列为 FF /2
. /2
表示 ModR/M 字节中的附加操作码位在该指令中的值为 2。如果您随后查看“(十进制)/数字(操作码)”列标题,您将看到数字 2 出现在列的开头。如果你往下看那一栏,你会看到 55
在标有“[EBP] + disp8”的行上。
这在英特尔软件开发人员手册第 2 卷的指令汇总表中的 3.1.1.1 操作码列(不带 VEX 前缀的指令)部分中有记录:
- /digit — A digit between 0 and 7 indicates that the ModR/M byte of the instruction uses only the r/m (register or memory) operand. The reg field contains the digit that provides an extension to the instruction's opcode.
call dword ptr [fp]
是反汇编程序生成的文本。它从未组装过,如何组装取决于如何
fp
被定义为。反汇编器从编译器生成的调试信息中知道局部变量
fp
在哪里。存在于堆栈中,并且知道
[ebp - 8]
可以用来访问它。它显示
fp
而不是
[ebp - 8]
因为在大多数情况下前者更有意义。您应该可以稍后通过取消选中“显示符号名称”来查看。
call std::operator<<std:char_traits<char> >
无论如何都无法组装生产线
std
,
operator
等被定义,因此表明您正在查看的反汇编实际上并不意味着要组装。反汇编程序经常出现这种情况。输出旨在提供信息,这是比查看十六进制字节序列更好的替代方法。这并不意味着是一个可逆的过程。
关于assembly - 我应该如何使用英特尔的文档获取与 x86 中的 `ModeR/M` 指令相对应的 `call dword ptr` 字节?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58651136/
在过去的几个月里,我一直在研究 Haskell,我遇到了一个我不太确定如何处理的单子(monad)的情况。 我有一个 a -> m a 类型的值第二个类型为 m (a -> a)我需要对它们进行组合,
仿函数有 (a -> b) -> m a -> m b 应用程序有 f (a -> b) -> f a -> f b Monad 有 m a -> (a -> m b) -> m b 但是,是否有扩展
我是 Haskell 的新手,我想知道是否有比 Hoogle 更好的方法来确定一个库功能是否重复? 举个例子:我有很多函数f :: Monad a => a -> m a我想链接在一起,比如 f123
将存储在一系列列表中的 m、m、n 维数组组合成一个 m、m、n 维数组的方法是什么? 示例: 这是三个包含 m,m,n 维数组的列表: list1 <- array (1, dim = c(5, 5
有没有办法写一个函数f::(a -> b -> ... -> t) -> (Monad m => m a -> m b -> ... -> m t ),基本上是 liftMn 对于任何 n? (编辑:
我有一个像这样的 pandas 数据框: df = pd.DataFrame({'A':[1,3,2,9],'B':[2,1,2,7],'C':[7,2,4,6],'D':[8,1,6,4]},ind
这个问题来自文章“Trivial Monad”,地址:http://blog.sigfpe.com/2007/04/trivial-monad.html 。提供的答案是 h x y = x >>= (
所以>>= :: m a -> (a -> m b) -> m b和>> :: m a -> m b -> m b . 而 f b -> f a . 但我想要一些能m a -> (a -> m b)
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 3 年前。 Improve
当我安装 rakudo来源: $ git clone git@github.com:rakudo/rakudo.git $ cd rakudo $ perl Configure.pl --gen-mo
我正在尝试通过查看一些练习来提高我的 Idris 技能 Software Foundations (最初是为 Coq 设计的,但我希望对 Idris 的翻译不会太糟糕)。我在使用 "Exercise:
我想知道以下是否可行。 与服务器交换密码时,应保护密码。因此,用户可以使用生成的 key kUser 来加密密码。 Encrypt(m, kUser) 生成加密消息 eU(m)。现在用户将此信息发送到
这两个表之间存在什么样的关系(1:1、1:m、m:m,等等)? CREATE TABLE IF NOT EXISTS `my_product` ( `id` int(11) NOT NULL au
有人可以解释类型的含义以及如何实现吗? class Foldable f where foldMap :: (Monoid m) => (a -> m) -> f a -> m 基于 https:
例如,在 MVC 应用程序中,我可以使用 Html 助手来创建这样的标签: @Html.LabelFor(m => m.ProductName) 我没有在任何地方声明变量“m”,但 IDE 会自动找出
更新:澄清、更明确的重点和缩短的示例: 我可以避免 M op+(M&&,M&&) 过载吗?假设,我想很好地处理 RValues?我想其他三个重载是必需的。 我首先使用 (&&,&&) 重载的原因: 通
假设我有一个函数,它接受两个向量并返回一个整数,例如一个向量中也存在另一个向量中的元素数量。喜欢: f m [,1] [,2] [,3] [1,] "c" "i" "c" [2,] "
我想将字符串(字幕)转换为: 585 00:59:59,237 --> 01:00:01,105 - It's all right. - He saw us! 586 01:00:01,139 -->
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及预
是否可以将 Linux 中的大文件将 d.m.Y h:m:s 转换为 Y-d-m h:m:s? 示例数据 "30.07.2016 00:00:00",DN123,PAPN,PAPN,TEST,9189
我是一名优秀的程序员,十分优秀!