AT&T (assembleur)

Un article de Wikipédia, l'encyclopédie libre.

AT&T est le nom donné à une forme de codage en assembleur pour l'architecture x86. Cette forme de codage est apparue avec les premiers UNIX[réf. nécessaire] (AT&T est la société à l'origine d'UNIX). Cette forme est surtout utilisée sous UNIX. Cette syntaxe est utilisée par GAS, l'assembleur du projet GNU.

Sommaire

[modifier] Concepts

Par opposition à la norme Intel, la norme AT&T place les opérandes dans l'ordre Source avant Destination.

Les principales caractéristiques de cette syntaxe sont :

  • L'assembleur fait toujours la différence entre majuscules et minuscules
  • Les constantes sont écrites avec la notation habituelle en C
  • Les opérandes immédiats (constantes) sont préfixés d'un dollar '$'
  • Les registres sont préfixés d'un '%'
  • Les sauts (jmp/call) absolus sont préfixés d'un astérisque '*'
  • L'indirection (déférenciation) est marquée par des parenthèses : un opérande basé sur EBX+table donne table(%ebx)
  • Ordre des opérandes : Source avant Destination (ordre choisi pour des raisons de compatibilité avec d'autres assembleurs UNIX)
  • La taille des opérandes peut être précisée grâce au dernier caractère de l'opération (en syntaxe Intel, jusqu'au Pentium inclus, des opérateurs spécifiques sur les opérandes sont utilisés, par exemple l'opérateur PTR avec MASM) :
    • b -> byte (8 bits - 1 octet)
    • w -> word (16 bits - 2 octets)
    • s -> short (32 bits - 4 octets, pour les opération en virgule flottante)
    • l -> long (32 bits - 4 octets pour les entiers, 64 bits - 8 octets pour les flottants)
    • q -> quad (64 bits - 8 octets)
    • t -> ten bytes (80 bits - 10 octets)
    • o -> octo (128 bits - 16 octets), pour l'architecture x86-64
  • Les sauts « longs » (ljump/lcall) absolus ont la syntaxe suivante : $sélecteur, $offset, et non pas section:offset comme dans la syntaxe des manuels Intel
  • Pas de support pour de multiples segments, les programes utilisent un unique adressage virtuel linéaire


[modifier] Exemples

Par exemple, une instruction en norme Intel :

 mov eax, 0FFh

Donnera en norme AT&T

 movl $0xFF, %eax

L'équivalent en AT&T de

 mov byte ptr [ebx], 0FFh

Est

 movb $0xFF, (%ebx)

[modifier] Source

[modifier] Voir aussi

[modifier] Articles connexes