将 AT&T 语法程序转换为英特尔语法



原始代码生成以下输出:处理器供应商ID为'GenuineIntel'这是原始代码:

1.         .section .data
2.   output:
3.         .ascii “The processor Vendor ID is ‘xxxxxxxxxxxx’n”
4.         .section .text
5.         .globl _start
6.   _start:
7.         movl $0, %eax
8.         cpuid
9.         movl $output, %edi
11.        movl %ebx, 28(%edi)
12.        movl %edx, 32(%edi)
13.        movl %ecx, 36(%edi)
14         movl $4, %eax
15.        movl $1, %ebx
16.        movl $output, %ecx
17.        movl $42, %edx
18.        int $0x80
19.        movl $1, %eax
20.        movl $0, %ebx
21.        int $0x80

我对intel的转换执行,但在代码组装后不会在屏幕上显示任何输出:

1.        .intel_syntax noprefix
2.         .section        .data
3.    output:
4.         .ascii "The processor Vendor ID is 'xxxxxxxxxxxx'n"
5.         .section   .text
6.         .globl _start
7.    _start:
8.          mov     eax, 0
9.          cpuid
10.         mov     edi, OFFSET output
11.         mov     [edi+28], ebx
12.         mov     [edi+32], edx
13.         mov     [edi+36], ecx
14.         mov     eax, 4
15.         mov     ebx, 1
16.         mov     ecx, output
17.         mov     edx, 42
18.         int     0x80
19.         mov     eax, 1
20.         mov     ebx, 0
21.         int     0x80

如果您的代码中没有注释,那么您可以从组装开始,然后用其他语法进行反汇编。

如果有评论的话,把评论移过去可能会更容易,也可能不会更容易/更不容易出错。这样做可能不方便保留全局符号名称,但一些反汇编程序可以使用符号表。

即使你决定手动操作,你也可以通过组装AT&T和NASM版本。如果这些二进制文件可以反汇编成相同的代码,那就很好了。如果没有,你应该迅速发现它们不同的地方。

相关内容

最新更新