Section courante

A propos

Section administrative du site

Assembleur 80x86

XOR

INTEL 8088+ binary eXclusive OR

Syntaxe

XOR OpérandeCible, OpérandeSource

Description

L'instruction XOR effectue un OU exclusif BINAIRE sur les 2 opérandes spécifiés, le calcul est placé dans la première opérande, c'est-à-dire l'Opérande Cible. Rappelons qu'un OU exclusif BINAIRE donne le résultat 1 si une des 2 opérandes vaut 1 et donne 0 si les deux bits valent 0 ou 1.

Algorithme

MODULE XOR(OpérandeCible, OpérandeSource)
   OpérandeCibleOpérandeCible XOR OpérandeSource

Mnémonique

Instruction Opcode Description
XOR AL, imm8 34h ib Effectue un «Ou exclusif binaire» du contenu du registre AL avec une valeur immédiate de 8 bits.
XOR AX, imm16 35h iw Effectue un «Ou exclusif binaire» du contenu du registre AX avec une valeur immédiate de 16 bits.
XOR EAX, imm32 35h id Effectue un «Ou exclusif binaire» du contenu du registre EAX avec une valeur immédiate de 32 bits.
XOR RAX, imm32 35h id Effectue un «Ou exclusif binaire» du contenu du registre RAX avec une valeur immédiate de 32 bits.
XOR reg/mem8, imm8 80h /6 ib Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 8 bits avec une valeur immédiate de 8 bits.
XOR reg/mem16, imm16 81h /6 iw Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 16 bits avec une valeur immédiate de 16 bits.
XOR reg/mem32, imm32 81h /6 id Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 32 bits avec une valeur immédiate de 32 bits.
XOR reg/mem64, imm32 81h /6 id Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 64 bits avec une valeur immédiate de 32 bits.
XOR reg/mem16, imm8 83h /6 ib Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 16 bits avec une valeur immédiate de 8 bits.
XOR reg/mem32, imm8 83h /6 ib Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 32 bits avec une valeur immédiate de 8 bits.
XOR reg/mem64, imm8 83h /6 ib Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 64 bits avec une valeur immédiate de 8 bits.
XOR reg/mem8, reg8 30h /r Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 8 bits avec le contenu d'un registre de 8 bits.
XOR reg/mem16, reg16 31h /r Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 16 bits avec le contenu d'un registre de 16 bits.
XOR reg/mem32, reg32 31h /r Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 32 bits avec le contenu d'un registre de 32 bits.
XOR reg/mem64, reg64 31h /r Effectue un «Ou exclusif binaire» du contenu d'une opérande mémoire ou registre 64 bits avec le contenu d'un registre de 64 bits.
XOR reg8, reg/mem8 32h /r Effectue un «Ou exclusif binaire» du contenu d'un registre de 8 bits avec le contenu d'une opérande mémoire ou registre 8 bits.
XOR reg16, reg/mem16 33h /r Effectue un «Ou exclusif binaire» du contenu d'un registre de 16 bits avec le contenu d'une opérande mémoire ou registre 16 bits.
XOR reg32, reg/mem32 33h /r Effectue un «Ou exclusif binaire» du contenu d'un registre de 32 bits avec le contenu d'une opérande mémoire ou registre 32 bits.
XOR reg64, reg/mem64 33h /r Effectue un «Ou exclusif binaire» du contenu d'un registre de 64 bits avec le contenu d'une opérande mémoire ou registre 64 bits.

Exceptions

Message Mode réel Virtuel 8086 Mode protégé Description
#SS(Pile) X X X Une adresse mémoire dépasse la limite du segment de pile ou n'est pas canonique
#GP(Protection général) X X X Une adresse mémoire dépasse la limite du segment de données ou n'est pas canonique
    X L'opérande de destination n'est pas dans un segment non écrivable
    X Un segment de données nulle est utilisé comme référence mémoire
#PF(Faute de page)   X X Une faute de page résultat de l'exécution de l'instruction
#AC(Vérifie l'alignement)   X X Un désalignement de la référence mémoire est effectué quand une vérification d'alignement est activé

Exemples

Cet exemple permet de mettre la valeur 0 dans le registre EAX (EAX = 0). Cette technique utilise moins d'octets que l'instruction «MOV EAX,0», cependant il modifie l'état du registre des drapeaux, il faut donc l'utiliser avec astuce lors d'optimisation de code :

  1. XOR EAX,EAX

Voici un exemple permettant d'échanger les valeurs des registres AX et BX à l'aide de l'opérateur XOR :

  1. .MODEL small
  2.    .STACK 100h
  3.    .DATA
  4. Message1       DB 'Valeur de AX = ','$'
  5. Message2       DB ', Valeur de BX = ','$'
  6. CRLF           DB 13,10,'$'
  7.    .CODE
  8. PrintDigit PROC NEAR
  9.     OR  AX,AX
  10.     JNS Positif    
  11.     PUSH AX
  12.      MOV AH,02h
  13.      MOV DL,'-'
  14.      INT 21h
  15.     POP AX
  16.     NEG AX
  17. Positif:
  18.     MOV BX,10           
  19.     XOR CX,CX
  20. NextDigit:
  21.     XOR DX,DX
  22.     DIV BX
  23.     PUSH DX
  24.      INC CX              
  25.      OR  AX,AX
  26.      JNZ NextDigit
  27. PrintOneDigit: 
  28.     POP AX       
  29.     ADD AL,48           
  30.     MOV DL,AL           
  31.     MOV AH,02h
  32.     INT 21h             
  33.     LOOP PrintOneDigit
  34.     RET
  35. ENDP
  36.  
  37. Exchange PROC NEAR
  38.     XOR AX,BX
  39.     XOR BX,AX
  40.     XOR AX,BX
  41.     RET
  42. ENDP
  43.  
  44.     .startup   
  45.     MOV  AX,@data
  46.     MOV  DS,AX                  
  47.     MOV  AH,9                   
  48.     MOV  DX,OFFSET Message1
  49.     INT  21h                    
  50.     MOV  AX,-1234
  51.     MOV  BX,76
  52.     CALL Exchange
  53.     PUSH BX
  54.      CALL PrintDigit
  55.      MOV  AX,@data
  56.      MOV  DS,AX                  
  57.      MOV  AH,9                   
  58.      MOV  DX,OFFSET Message2
  59.      INT  21h               
  60.     POP AX
  61.     CALL PrintDigit
  62.     MOV  AH,9                   
  63.     MOV  DX,OFFSET CRLF
  64.     INT  21h
  65.     MOV  AX,4C00h                 
  66.     INT  21h                    
  67.     END

on obtiendra le résultat suivant :

Valeur de AX = 76, Valeur de BX = -1234

Voir également

Instruction assembleur 80x86 - Instruction OR
Instruction assembleur 80x86 - Instruction AND
Instruction assembleur 80x86 - Instruction NOT
Instruction assembleur 80x86 - Instruction NEG
Langage de programmation - Turbo Pascal - Référence de procédures et fonctions - XOR
Mathématique - Algèbre de Boole - Table de vérité

Références

Le livre d'Or PC, Martin Althaus, 1992, ISBN: 2-7361-0934-1, page 839
Assembleur Facile, Philippe Mercier, 1990, ISBN: 2-501-01176-7, page 419
AMD64 Architecture Programmer's Manual Volume 3: General-Purpose and System Instructions, Edition Advanced Micro Devices, Revision 3.14, September 2007, Publication No. 24594, page 248.
Intel® 64 and IA-32 Architectures Software Developer’s Manual Volume 2B: Instruction Set Reference, N-Z, Edition Intel, Mars 2010, Publication No. 253667-034US, page 547 à 549.

Dernière mise à jour : Samedi, le 2 août 2014