0

我在 C 中创建了一个程序来生成一个 char* 处理数据。我发送到我的汇编程序并将其放入寄存器中:

mov     edx, [ebp+12]
mov     edi, edx

我怎样才能在其中写入一个字符。我知道我需要循环编写一个 char 和 inc edi ...。但是我怎么能写一个字符,我已经把这个值放到另一个寄存器中了。但是如果我做 mov edx, 49; 字符代码我会丢失指针。我想做类似的事情

for(p=malloc(100*sizeof(char*)); p!=NULL;p++){
    *p=//my char code
}

用于 linux (DEBIAN) x86 的程序集

4

1 回答 1

1

edx是字符的目标地址。也就是说,edx是指向您要写入的位置的指针。因此,请执行以下操作:

mov byte ptr ds:[edx], 49

这甚至可能有效:

mov byte ptr ds:[edx], '1'

你说你的角色已经在某个寄存器中。我假设它是一个 8 位寄存器 ( ah/al/bh/bl/ch/cl/dh/dl),在这种情况下你可以这样做:

mov [edx], ah

在这种情况下,汇编器可以推断出数据[edx]指向的大小。


我现在在 Windows 上,所以这段代码适用于 VC++。它演示了复制字符串:

#include <stdlib.h>
#include <stdio.h>

char src[] = "hello";
char dest[8];

int main( void )
{
   __asm
   {
      xor ecx, ecx

      mov eax, offset src
      mov edx, offset dest

        loop_dest:

      mov bh, byte ptr ds:[eax+ecx]
      mov [edx+ecx], bh

      inc ecx
      cmp ecx, size src
      jnz loop_dest
   }

   printf("%s\n", dest);
   return EXIT_SUCCESS;
}

如果您的汇编器使用 AT&T 语法,您需要做一些小的翻译,但希望这会为您指明正确的方向。

于 2012-05-03T21:07:06.887 回答