原始代码生成以下输出:处理器供应商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版本。如果这些二进制文件可以反汇编成相同的代码,那就很好了。如果没有,你应该迅速发现它们不同的地方。