Section courante

A propos

Section administrative du site

 Langage  Elément  Tutoriel  Programmation  Plateforme  Compilateur  Outils  Emulateur  Annexe  Aide 
ABAP/4
Ada
Assembleur
Assembly & bytecode
ASP (Active Server Pages)
Basic
C
C++
C# (C Sharp)
Cobol
ColdFusion
Fortran
HTML
Java
JavaScript
LISP
Logo
LotusScript
Oberon
Pascal
Perl
PHP
PL/1
Prolog
Python
Rebol
REXX
Ruby
SAS
NoSQL
SQL
Swift
X++ (Axapta)
GNAT
SMALLAda
VHDL
Assembleur 370
Assembleur 1802
Assembleur 4004
Assembleur 6502
Assembleur 6800
Assembleur 68000
Assembleur 8080 et 8085
Assembleur 8089
Assembleur 80x86
Assembleur AGC4
Assembleur ARM
Assembleur DPS 8000
Assembleur i860
Assembleur Itanium
Assembleur MIPS
Assembleur PDP-11
Assembleur PowerPC
Assembleur RISC-V
Assembleur SPARC
Assembleur SuperH
Assembleur UNIVAC I
Assembleur VAX
Assembleur Z80
Assembleur Z8000
Assembleur z/Architecture
ASSEMBLER/MONITOR 64
Micol Assembler
GFA Assembler
A86
MASM (Macro Assembler)
TASM (Turbo Assembler)
CIL
Jasmin
LLVM
MSIL
Parrot
P-Code (PCode)
SWEET16
G-Pascal
ASP 1.0
ASP 2.0
ASP 3.0
ASP.NET
ASP.NET Core
ABasiC (Amiga)
Adam SmartBASIC
Altair BASIC
AmigaBASIC (Amiga)
AMOS Basic (Amiga)
Atari Basic (Atari 400, 600 XL, 800, 800XL)
Basic Apple II (Integer BASIC/APPLESOFT)
Basic Commodore 64 (CBM-BASIC)
Basic Commodore 128 (BASIC 7.0)
Basic Commodore VIC-20 (CBM-BASIC 2.0)
Basic Coco 1 (Color Basic)
Basic Coco 2 (Extended Color Basic)
Basic Coco 3 (Extended Color Basic 2.0)
BASICA (PC DOS)
Basic Pro
BBC BASIC
Blitz BASIC (Amiga)
DarkBASIC
Dartmouth BASIC
GFA-Basic (Atari ST/Amiga)
GWBASIC (MS-DOS)
Liberty BASIC
Locomotive BASIC (Amstrad CPC)
MSX-Basic
Omikron Basic (Atari ST)
Oric Extended Basic
Power Basic
Quick Basic/QBasic (MS-DOS)
Sinclair BASIC (ZX80, ZX81, ZX Spectrum)
ST BASIC (Atari ST)
Turbo Basic
Vintage BASIC
VBScript
Visual Basic (VB)
Visual Basic .NET (VB .NET)
Visual Basic pour DOS
Yabasic
BeckerBASIC
SIMONS' BASIC
Basic09 d'OS-9
Disk Extended Color Basic
Basic09 d'OS-9
Disk Extended Color Basic
Access
Excel
Visual Basic pour Windows
Visual Basic .NET pour Windows
C Shell Unix (csh)
C pour Amiga
C pour Atari ST
C pour DOS
C pour Falcon030
C pour GEMDOS (Atari ST)
C pour Linux
C pour PowerTV OS
C pour OS/2
C pour Unix
C pour Windows
Aztec C
CoCo-C
GNU C
HiSoft C
IBM C/2
Introl-C
Lattice C
Microsoft C
MinGW C
MSX-C
Open Watcom C
OS-9 C Compiler
Pure C
Quick C
Turbo C
HiSoft C for Atari ST
HiSoft C for CP/M (Amstrad CPC)
C++ pour OS/2
C++ pour Windows
Borland C++
C++Builder
IBM VisualAge C++
Intel C++
MinGW C++
Open Watcom C++
Symantec C++
Turbo C++
Visual C++
Visual C++ .NET
Watcom C++
Zortech C++
C# (C Sharp) pour Windows
Apple III Cobol
Microsoft Cobol
BlueDragon
Lucee
OpenBD
Railo
Smith Project
Microsoft Fortran
WATFOR-77
CSS
FBML
Open Graph
SVG
XML
XSL/XSLT
LESS
SASS
GCJ (GNU)
JSP
Jython
Visual J++
Node.js
TypeScript
AutoLISP
ACSLogo
LotusScript pour Windows
Amiga Oberon
Oberon .NET
Apple Pascal
Delphi/Kylix/Lazarus
Free Pascal
GNU Pascal
HighSpeed Pascal
IBM Personal Computer Pascal
Lisa Pascal
Maxon Pascal
MPW Pascal
OS-9 Pascal
OSS Personal Pascal
Pascal-86
Pascal du Cray Research
Pascal/VS
Pascal-XT
PURE Pascal
QuickPascal
RemObjets Chrome
Sun Pascal
THINK Pascal
Tiny Pascal (TRS-80)
Turbo Pascal
UCSD Pascal
VAX Pascal
Virtual Pascal
Turbo Pascal for CP/M-80
Turbo Pascal for DOS
Turbo Pascal for Macintosh
Turbo Pascal for Windows
CodeIgniter (Cadre d'application)
Drupal (Projet)
Joomla! (Projet)
Phalanger (PHP .NET)
phpBB (Projet)
Smarty (balise)
Twig (balise)
Symfony (Cadre d'application)
WordPress (Projet)
Zend (Cadre d'application)
PL360
PL/M-80
PL/M-86
Turbo Prolog
CPython
IronPython
Jython
PyPy
AREXX
Regina REXX
JMP
Btrieve
Cassandra
Clipper
CouchDB
dBASE
Hbase
Hypertable
MongoDB
Redis
Access
BigQuery
DB2
H2
Interbase
MySQL
Oracle
PostgreSQL
SAP HANA
SQL Server
Sybase
U-SQL
Introduction
Les remarques
Les opérateurs
Les instructions conditionnelles
Les instructions de boucles
Type de données élémentaire
Référence des registres
Mode d'adressage du processeur
Structure de données
Référence des instructions par catégories
Référence, lexique et dictionnaire des instructions 80x86
Les symboles prédéfinies
Les directives
Mode 8080
Mode réel
Mode protégé
Mode virtuel 8086
Mode SMM
Format du descripteur de segment
Format du TSS
Format du SMM
Format BCD
Format des nombres réels
8086/8088
Série NEC V20/V30
80286
80386
Pentium
Pentium Pro
AVX-512
MMX (MultiMedia eXtensions)
MPX (Memory Protection Extensions)
SGX (Software Guard Extensions)
SHA extensions
SMX (Safer Mode Extensions)
SSE (Streaming SIMD Extensions)
SSE2 (Streaming SIMD Extensions 2)
SSE3 (Streaming SIMD Extensions 3)
SSSE3 (Supplemental Streaming SIMD Extensions 3)
SSE4.1 (Streaming SIMD Extensions 4.1)
SSE4.2 (Streaming SIMD Extensions 4.2)
TSX (Transactional Synchronization Extensions)
VMX (Virtual-Machine eXtensions)
x86-64
Les boucles
Les chaînes
les comparaisons
Les conversions
Les décalages de bits
Les drapeaux
Les opérateurs
Saut conditionnel
Saut inconditionnel
Les transferts de données
Utilisation de la pile
Accès mémoire
Ensemble d'instructions pour les applications 80386
BIOS compatible au micro-ordinateur IBM PC
Démarrage du système
Détermination de la version du BIOS
Détermination du type de PC
Fonctions de sortie de l'écran du BIOS
Détermination de la configuration du système à l'aide du BIOS
Détermination de la RAM disponible à l'aide du BIOS
Accéder à la disquette depuis le BIOS
Accéder au disque dur depuis le BIOS
Accéder au port série depuis le BIOS
L'interruption de la cassette
Accéder au clavier depuis le BIOS
Accéder à l'imprimante à partir du BIOS
Lecture de la date et de l'heure à partir du BIOS
Variables du BIOS
Bonjour
Application
Détection
Mathématique
Temps
Stationnement de voiture
BIOS SCSI
CMOS de XT
DesqView
Valeur absolue (ABS)
Triangle Pascal
Année bissextile
DOS
GeoWorks
86-DOS
MS-DOS 2
MS-DOS 6
A86
LZASM
MASM
NASM
TASM
CodeView
Free Hex Editor Neo
OllyDbg
SoftICE
Turbo Debugger
DOSBox
emu8086
PCE - PC Emulator
PCem
Interruptions
Port d'entrée/sortie
RAM de l'IBM PC
Téléchargement
00h à 07h: Processeur
08h à 0Fh: Périphériques (IRQ0 à IRQ7)
10h: Gestionnaire vidéo
13h: Accès aux disques
14h: Gestion des ports séries
15h: Extension d'Entrée/Sortie
16h: Gestion du clavier
17h: Gestion de l'imprimante
21h: Service DOS
2Ah: Interface de service réseau
2Fh: Multiplexe
33h: Interface du pilote de souris
59h: GSS Computer Graphics Interface
5Ch: Réseau BIOS (NetBIOS)
67h: Gestionnaire EMM/EMS
00h: Mode vidéo
01h: Sélection du type de curseur
10h, F0h: Tseng Labs HiColor
4Fh: Pilote VESA
5Fh: Realtek RTVGA
6Fh: Video 7
18h: Demande des informations SCSI
01h: Écrit dans la RAM non-volatile (Amstrad PC1512)
02h: Lecture dans la RAM non-volatile (Amstrad PC1512)
10h: Gestionnaire principal TopView
89h: Entrée en mode protégé
64h: OS/2 API DOS32StartSession
FFh, 92h: Détecte la présence du pilote «PREDIR.EXE»
16h: Windows & DPMI
0Ah: Détection de Windows
84h: Demande le point d'entrée
86h: Détection du mode DPMI
87h: Détecte l'installation DPMI
8Eh: Machine virtuel et application
Préface
Notes légal
Dictionnaire
Recherche
Assembleur 80x86

CMOV

INTEL P6+ Conditionnel MOVe

Syntaxe

CMOVcc registre, valeur

Paramètres

Nom Description
cc Ce paramètre permet d'indiquer le code de condition : O, NO, B, C,...
registre Ce paramètre permet d'indiquer le registre à affecter.
valeur Ce paramètre permet d'indiquer la valeur à copier dans le registre.

Description

C'est l'équivalent d'un MOV conditionnel. Cette instruction copie des données d'une source (valeur) à une destination (registre) à la condition que la condition (cc) demandé soit remplie.

Algorithme

MODULE CMOV(cc,registre,valeur)
   SI cc ALORS
      registre ← valeur
   FIN SI

Remarque

Mnémonique

Instruction Opcode Description
CMOVO reg16, reg/mem16 0Fh 40h /r Copie si débordement (OF = 1)
CMOVO reg32, reg/mem32 0Fh 40h /r Copie si débordement (OF = 1)
CMOVO reg64, reg/mem64 0Fh 40h /r Copie si débordement (OF = 1)
CMOVNO reg16, reg/mem16 0Fh 41h /r Copie si pas de débordement (OF = 0)
CMOVNO reg32, reg/mem32 0Fh 41h /r Copie si pas de débordement (OF = 0)
CMOVNO reg64, reg/mem64 0Fh 41h /r Copie si pas de débordement (OF = 0)
CMOVB reg16, reg/mem16 0Fh 42h /r Copie si retenu (CF = 1)
CMOVB reg32, reg/mem32 0Fh 42h /r Copie si retenu (CF = 1)
CMOVB reg64, reg/mem64 0Fh 42h /r Copie si retenu (CF = 1)
CMOVC reg16, reg/mem16 0Fh 42h /r Copie si retenu (CF = 1)
CMOVC reg32, reg/mem32 0Fh 42h /r Copie si retenu (CF = 1)
CMOVC reg64, reg/mem64 0Fh 42h /r Copie si retenu (CF = 1)
CMOVNAE reg16, reg/mem16 0Fh 42h /r Copie si retenu (CF = 1)
CMOVNAE reg32, reg/mem32 0Fh 42h /r Copie si retenu (CF = 1)
CMOVNAE reg64, reg/mem64 0Fh 42h /r Copie si retenu (CF = 1)
CMOVNB reg16,reg/mem16 0Fh 43h /r Copie si pas retenu (CF = 0)
CMOVNB reg32,reg/mem32 0Fh 43h /r Copie si pas retenu (CF = 0)
CMOVNB reg64,reg/mem64 0Fh 43h /r Copie si pas retenu (CF = 0)
CMOVNC reg16,reg/mem16 0Fh 43h /r Copie si pas retenu (CF = 0)
CMOVNC reg32,reg/mem32 0Fh 43h /r Copie si pas retenu (CF = 0)
CMOVNC reg64,reg/mem64 0Fh 43h /r Copie si pas retenu (CF = 0)
CMOVAE reg16, reg/mem16 0Fh 43h /r Copie si pas retenu (CF = 0)
CMOVAE reg32, reg/mem32 0Fh 43h /r Copie si pas retenu (CF = 0)
CMOVAE reg64, reg/mem64 0Fh 43h /r Copie si pas retenu (CF = 0)
CMOVZ reg16, reg/mem16 0Fh 44h /r Copie si drapeau du zéro (ZF = 1)
CMOVZ reg32, reg/mem32 0Fh 44h /r Copie si drapeau du zéro (ZF = 1)
CMOVZ reg64, reg/mem64 0Fh 44h /r Copie si drapeau du zéro (ZF = 1)
CMOVE reg16, reg/mem16 0Fh 44h /r Copie si drapeau du zéro (ZF = 1)
CMOVE reg32, reg/mem32 0Fh 44h /r Copie si drapeau du zéro (ZF = 1)
CMOVE reg64, reg/mem64 0Fh 44h /r Copie si drapeau du zéro (ZF = 1)
CMOVNZ reg16, reg/mem16 0Fh 45h /r Copie si drapeau de pas de zéro (ZF = 0)
CMOVNZ reg32, reg/mem32 0Fh 45h /r Copie si drapeau de pas de zéro (ZF = 0)
CMOVNZ reg64, reg/mem64 0Fh 45h /r Copie si drapeau de pas de zéro (ZF = 0)
CMOVNE reg16, reg/mem16 0Fh 45h /r Copie si drapeau de pas de zéro (ZF = 0)
CMOVNE reg32, reg/mem32 0Fh 45h /r Copie si drapeau de pas de zéro (ZF = 0)
CMOVNE reg64, reg/mem64 0Fh 45h /r Copie si drapeau de pas de zéro (ZF = 0)
CMOVBE reg16, reg/mem16 0Fh 46h /r Copie si drapeau de zéro (ZF = 1) ou drapeau de retenu (CF = 1)
CMOVBE reg32, reg/mem32 0Fh 46h /r Copie si drapeau de zéro (ZF = 1) ou drapeau de retenu (CF = 1)
CMOVBE reg64, reg/mem64 0Fh 46h /r Copie si drapeau de zéro (ZF = 1) ou drapeau de retenu (CF = 1)
CMOVNA reg16, reg/mem16 0Fh 46h /r Copie si drapeau de zéro (ZF = 1) ou drapeau de retenu (CF = 1)
CMOVNA reg32, reg/mem32 0Fh 46h /r Copie si drapeau de zéro (ZF = 1) ou drapeau de retenu (CF = 1)
CMOVNA reg64, reg/mem64 0Fh 46h /r Copie si drapeau de zéro (ZF = 1) ou drapeau de retenu (CF = 1)
CMOVNBE reg16, reg/mem16 0Fh 47h /r Copie si drapeau de pas de zéro (ZF = 0) et drapeau de pas de retenu (CF = 0)
CMOVNBE reg32, reg/mem32 0Fh 47h /r Copie si drapeau de pas de zéro (ZF = 0) et drapeau de pas de retenu (CF = 0)
CMOVNBE reg64, reg/mem64 0Fh 47h /r Copie si drapeau de pas de zéro (ZF = 0) et drapeau de pas de retenu (CF = 0)
CMOVA reg16, reg/mem16 0Fh 47h /r Copie si drapeau de pas de zéro (ZF = 0) et drapeau de pas de retenu (CF = 0)
CMOVA reg32, reg/mem32 0Fh 47h /r Copie si drapeau de pas de zéro (ZF = 0) et drapeau de pas de retenu (CF = 0)
CMOVA reg64, reg/mem64 0Fh 47h /r Copie si drapeau de pas de zéro (ZF = 0) et drapeau de pas de retenu (CF = 0)
CMOVS reg16, reg/mem16 0Fh 48h /r Copie si drapeau de signe (SF = 1)
CMOVS reg32, reg/mem32 0Fh 48h /r Copie si drapeau de signe (SF = 1)
CMOVS reg64, reg/mem64 0Fh 48h /r Copie si drapeau de signe (SF = 1)
CMOVNS reg16, reg/mem16 0Fh 49h /r Copie si drapeau de pas de signe (SF = 0)
CMOVNS reg32, reg/mem32 0Fh 49h /r Copie si drapeau de pas de signe (SF = 0)
CMOVNS reg64, reg/mem64 0Fh 49h /r Copie si drapeau de pas de signe (SF = 0)
CMOVP reg16, reg/mem16 0Fh 4Ah /r Copie si drapeau de parité (PF = 1)
CMOVP reg32, reg/mem32 0Fh 4Ah /r Copie si drapeau de parité (PF = 1)
CMOVP reg64, reg/mem64 0Fh 4Ah /r Copie si drapeau de parité (PF = 1)
CMOVPE reg16, reg/mem16 0Fh 4Ah /r Copie si drapeau de parité (PF = 1)
CMOVPE reg32, reg/mem32 0Fh 4Ah /r Copie si drapeau de parité (PF = 1)
CMOVPE reg64, reg/mem64 0Fh 4Ah /r Copie si drapeau de parité (PF = 1)
CMOVNP reg16, reg/mem16 0Fh 4Bh /r Copie si drapeau de pas de parité (PF = 0)
CMOVNP reg32, reg/mem32 0Fh 4Bh /r Copie si drapeau de pas de parité (PF = 0)
CMOVNP reg64, reg/mem64 0Fh 4Bh /r Copie si drapeau de pas de parité (PF = 0)
CMOVPO reg16, reg/mem16 0Fh 4Bh /r Copie si drapeau de pas de parité (PF = 0)
CMOVPO reg32, reg/mem32 0Fh 4Bh /r Copie si drapeau de pas de parité (PF = 0)
CMOVPO reg64, reg/mem64 0Fh 4Bh /r Copie si drapeau de pas de parité (PF = 0)
CMOVL reg16, reg/mem16 0Fh 4Ch /r Copie si SF <> OF
CMOVL reg32, reg/mem32 0Fh 4Ch /r Copie si SF <> OF
CMOVL reg64, reg/mem64 0Fh 4Ch /r Copie si SF <> OF
CMOVNGE reg16, reg/mem16 0Fh 4Ch /r Copie si SF <> OF
CMOVNGE reg32, reg/mem32 0Fh 4Ch /r Copie si SF <> OF
CMOVNGE reg64, reg/mem64 0Fh 4Ch /r Copie si SF <> OF
CMOVNL reg16, reg/mem16 0Fh 4Dh /r Copie si SF = OF
CMOVNL reg32, reg/mem32 0Fh 4Dh /r Copie si SF = OF
CMOVNL reg64, reg/mem64 0Fh 4Dh /r Copie si SF = OF
CMOVGE reg16, reg/mem16 0Fh 4Dh /r Copie si SF = OF
CMOVGE reg32, reg/mem32 0Fh 4Dh /r Copie si SF = OF
CMOVGE reg64, reg/mem64 0Fh 4Dh /r Copie si SF = OF
CMOVLE reg16, reg/mem16 0Fh 4Eh /r Copie si ZF = 1 ou SF <> OF
CMOVLE reg32, reg/mem32 0Fh 4Eh /r Copie si ZF = 1 ou SF <> OF
CMOVLE reg64, reg/mem64 0Fh 4Eh /r Copie si ZF = 1 ou SF <> OF
CMOVNG reg16, reg/mem16 0Fh 4Eh /r Copie si ZF = 1 ou SF <> OF
CMOVNG reg32, reg/mem32 0Fh 4Eh /r Copie si ZF = 1 ou SF <> OF
CMOVNG reg64, reg/mem64 0Fh 4Eh /r Copie si ZF = 1 ou SF <> OF
CMOVNLE reg16, reg/mem16 0Fh 4Fh /r Copie si ZF = 0 et SF = OF
CMOVNLE reg32, reg/mem32 0Fh 4Fh /r Copie si ZF = 0 et SF = OF
CMOVNLE reg64, reg/mem64 0Fh 4Fh /r Copie si ZF = 0 et SF = OF
CMOVG reg16, reg/mem16 0Fh 4Fh /r Copie si ZF = 0 et SF = OF
CMOVG reg32, reg/mem32 0Fh 4Fh /r Copie si ZF = 0 et SF = OF
CMOVG reg64, reg/mem64 0Fh 4Fh /r Copie si ZF = 0 et SF = OF

Exceptions

Message Mode réel Virtuel 8086 Mode protégé Description
#UD(Opcode invalide) X X X Cette instruction n'est pas supporté. C'est instruction est supporté si l'indicateur de bit 15 du registre EDX de l'instruction CPUID avec la fonction 0000_0001h ou 8000_0001h.
#SS(Pile non-canonique) 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 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é

Voir également

Instruction assembleur 80x86 - Instruction MOV

Références

Intel® 64 and IA-32 Architectures Software Developer’s Manual Volume 2A: Instruction Set Reference, A-M, Edition Intel, Mars 2010, Publication No. 253666-034US, page 199 à 204.

PARTAGER CETTE PAGE SUR
Dernière mise à jour : Mercredi, le 17 septembre 2014