Le gcc -S
option générera le code Assembly en syntaxe AT & T, existe-t-il un moyen de générer des fichiers en syntaxe Intel? Ou y a-t-il un moyen de convertir entre les deux?
Avez-vous essayé cela?
gcc -S -masm=intel test.c
Non testé, mais je l'ai trouvé dans ce forum où quelqu'un a prétendu que cela fonctionnait pour eux.
Je viens d'essayer cela sur le mac et ça a échoué, alors j'ai regardé dans ma page de manuel:
-masm=dialect
Output asm instructions using selected dialect. Supported choices
are intel or att (the default one). Darwin does not support intel.
Cela peut fonctionner sur votre plate-forme.
Pour Mac OSX:
clang++ -S -mllvm --x86-asm-syntax=intel test.cpp
Le
gcc -S -masm=intel test.c
Ça marche avec moi. Mais je peux dire une autre façon, bien que cela n’ait rien à voir avec l’exécution de gcc. Compilez l'exécutable ou le fichier de code objet, puis désassemblez le code objet dans la syntaxe Intel asm avec objdump comme ci-dessous:
objdump -d --disassembler-options=intel a.out
Cela pourrait aider.
J'ai ce code dans le fichier CPP:
#include <conio.h>
#include <stdio.h>
#include <windows.h>
int a = 0;
int main(int argc, char *argv[]) {
asm("mov eax, 0xFF");
asm("mov _a, eax");
printf("Result of a = %d\n", a);
getch();
return 0;
};
Ce code a fonctionné avec cette ligne de commande GCC:
gcc.exe File.cpp -masm=intel -mconsole -o File.exe
Il en résulte un fichier * .exe, et cela a fonctionné selon mon expérience.
Notes:
immediate operand must be use _variable in global variabel, not local variable.
example: mov _nLength, eax NOT mov $nLength, eax or mov nLength, eax
A number in hexadecimal format must use at&t syntax, cannot use intel syntax.
example: mov eax, 0xFF -> TRUE, mov eax, 0FFh -> FALSE.
C'est tout.