Что выводит эта программа при параметрах 0x7 и 0x18 - PullRequest
1 голос
/ 07 октября 2019

У меня есть следующая программа сборки

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;
}

1 Ответ

1 голос
/ 07 октября 2019

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

...