2

我有以下汇编程序

asm2:
    <+0>:   push   ebp
    <+1>:   mov    ebp,esp
    <+3>:   sub    esp,0x10
    <+6>:   mov    eax,DWORD PTR [ebp+0xc]
    <+9>:   mov    DWORD PTR [ebp-0x4],eax
    <+12>:  mov    eax,DWORD PTR [ebp+0x8]
    <+15>:  mov    DWORD PTR [ebp-0x8],eax
    <+18>:  jmp    0x50c <asm2+31>
    <+20>:  add    DWORD PTR [ebp-0x4],0x1
    <+24>:  add    DWORD PTR [ebp-0x8],0xcc
    <+31>:  cmp    DWORD PTR [ebp-0x8],0x3937
    <+38>:  jle    0x501 <asm2+20>
    <+40>:  mov    eax,DWORD PTR [ebp-0x4]
    <+43>:  leave  
    <+44>:  ret    

据我所知,这会运行一个循环来检查第二个参数是否等于 0x3937 (14647)。如果小于,则在第二个参数上加 204,在第一个参数上加 1。我编写了一个执行此操作的 C 程序,如下所示,但是当我采用其中一个参数,将它们转换为十六进制,然后提交时,它说它是错误的。

#include <stdio.h>

int main() {

  int i = 0;
  int a = 7;
  int b = 24;

  while(b < 14647) {
    a += 1;
    b += 204;
  }

  printf("%d %d", a, b);

  return 0;
}
4

1 回答 1

1

asm2不打印任何内容,它只是将b(在下面的程序中)的最终值写入eax并停止,这意味着它返回b

int asm2(int a1, int b1) 
{
  int a; //DWORD PTR [ebp-0x8]
  int b; //DWORD PTR [ebp-0x4]

  a = a1; // (a = b1 if arguments are pushed from left to right)
  b = b1; // (b = a1 if arguments are pushed from left to right)

  while(a <= 14647) {
    b += 1;
    a += 204;
  }

  return b;
}  

因此,如果您调用asm2(0x7, 0x18)并且
- 如果参数从右到左推送,则返回 96
-如果参数从左到右推送,则返回 79

于 2019-10-06T23:11:25.823 回答