assembly - assembly 中的段错误

标签 assembly x86 segmentation-fault

我有这个汇编代码:

00000000 <Q2>:
   0:   55                      push   %ebp
   1:   89 e5                   mov    %esp,%ebp
   3:   83 ec 20                sub    $0x20,%esp
   6:   c7 45 fc 1f 00 00 00    movl   $0x1f,-0x4(%ebp)
   d:   c7 45 f8 06 f4 ff ff    movl   $0xfffff406,-0x8(%ebp)
  14:   8b 45 fc                mov    -0x4(%ebp),%eax
  17:   8b 55 08                mov    0x8(%ebp),%edx
  1a:   8d 04 02                lea    (%edx,%eax,1),%eax
  1d:   89 45 f4                mov    %eax,-0xc(%ebp)
  20:   8b 45 08                mov    0x8(%ebp),%eax
  23:   0f af 45 f4             imul   -0xc(%ebp),%eax
  27:   89 45 f0                mov    %eax,-0x10(%ebp)
  2a:   8b 45 f8                mov    -0x8(%ebp),%eax
  2d:   8b 55 f0                mov    -0x10(%ebp),%edx
  30:   8d 04 02                lea    (%edx,%eax,1),%eax
  33:   89 45 ec                mov    %eax,-0x14(%ebp)
  36:   83 7d ec 00             cmpl   $0x0,-0x14(%ebp)
  3a:   74 0a                   je     46 <Q2+0x46>
  3c:   b8 00 00 00 00          mov    $0x0,%eax
  41:   8b 00                   mov    (%eax),%eax
  43:   89 45 f4                mov    %eax,-0xc(%ebp)
  46:   8b 45 f8                mov    -0x8(%ebp),%eax
  49:   89 c2                   mov    %eax,%edx
  4b:   c1 fa 1f                sar    $0x1f,%edx
  4e:   f7 7d 08                idivl  0x8(%ebp)
  51:   c9                      leave  
  52:   c3                      ret  

我认为段错误出现在第 4e 行,在它被右移十进制的 0x1f (31) 后,它会除以 %edx 。我认为答案很可能会被 0 除,除非数字大于或等于 2^31

我被告知是否发生段错误取决于函数的1个参数的值。经过进一步检查汇编代码,我得出的结论是,该故障与参数无关。我似乎找不到我忽略的东西。有人可以帮忙吗?

最佳答案

问题出在这些行上:

3c:   b8 00 00 00 00          mov    $0x0,%eax
41:   8b 00                   mov    (%eax),%eax

您正在将 0 移至 %eax 中,然后尝试访问 (%eax) 处的内存。在许多操作系统(例如 Linux)上,尝试读取地址 0x0 将导致段错误。

如果我正确地读取代码,除非 param * (param + 31) == 3066,否则就会发生这种情况,如果 param 为 -73 或42.

关于assembly - assembly 中的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13617726/

相关文章:

c - 如何使用 Intel 内在函数重新排序 128 位 vector ?

c - 由索引引用时出现段错误

c++ - 在 C++ 中调用汇编

c - 为什么键盘中断在 QEMU 中起作用,但在真实硬件上不起作用?

assembly - 原子指令可以跨越缓存线吗?

c - NASM 在 C 中无法正确运行

c - for 循环中的段错误

linux - FASM SHR 奇怪的行为

c++ - 原生显卡功能

assembly - 哪些 CPU 支持 MOVBE 指令?