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
Rust
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

Introduction

Le MMX, tirant son nom de l'anglicisme «MultiMedia eXtensions», arriva au moment où l'on misait encore beaucoup sur le microprocesseur pour améliorer le graphismes des jeu et obtenir une plus grande fluidité des effets multimédia. L'entreprise Intel, en 1997, proposa donc un jeu d'instructions MMX allant permettre de répondre à se besoin en se basant sur deux idées simples, si les registres sont plus grand, on aura plus de précision et si les instructions traitent davantage l'information à la manière d'une matrice, on aura un gain de rapidité. Aussi, il s'agit de la première extension SIMD (Single Instruction, Multiple Data) que proposa Intel pour résoudre le problème. Aujourd'hui, on ne mise plus sur ce jeu d'instructions mais plutôt sur les cartes vidéos. Ainsi, dans les faits, ce jeu d'instructions est dépassé. Cependant, un système d'exploitation voulant réduire l'électronique supporté pourrait trouver cet ensemble d'instructions encore intéressant aujourd'hui. Également, l'une des raisons pour lequel cette ensemble d'instructions fut un échec découle du fait qu'au moment de ça sortie, la vitesse des microprocesseur augmentaient rapidement et il était beaucoup plus facile pour les entreprises et développeurs de rien faire et d'attendre que le matériel soit plus puissance que de profiter de ses nouvelles techniques.

Le premier microprocesseur supportant ce jeu d'instructions est le Intel Pentium MMX. Par la suite, les concurrents comme l'AMD K6 et le Cyrix MII prirent en charge eux aussi ses instructions. La plupart des compilateurs ne support pas ses instructions et sinon de façon légerte, cependant les compilateurs Free Pascal, Intel C++ et Visual C++ .NET le supporte très bien.

Les registres MMX

L'ensemble de jeu d'instructions MMX dispose de 8 registres d'utilisation général de 64 bits, numéroté de MM0 à MM7. Ils peuvent être utilisé de plusieurs manières, soit en une quantité simple de 64 bits, soit en deux quantités de 32 bits, soit en 4 quantités de 16 bits ou soit 8 quantités de 8 bits. Toutefois, lorsqu'on applique une action à un registre MMX, elle est appliqué à tous les éléments du registre en même temps. Ainsi, en théorie, dans le meilleur des cas, on peut aller jusqu'à 8 fois plus vite. Voici la liste des registres MMX dans l'espace de registre FPU :

Registre 79 à 64 63 à 0
ST0 xx MM0
ST1 xx MM1
ST2 xx MM2
ST3 xx MM3
ST4 xx MM4
ST5 xx MM5
ST6 xx MM6
ST7 xx MM7

Voici comment les registres MMX sont organisés :

Registre Description
63 à 0 Un simple quadruple mot en 64 bits
63 à 32 31 à 0 2 double mots de 32 bits
63 à 48 47 à 32 31 à 16 15 à 0 4 mots de 16 bits
63 à 56 55 à 48 47 à 40 39 à 32 31 à 24 23 à 16 15 à 8 7 à 0 8 octets de 8 bits

Les instructions MMX

Les instructions commence généralement par la lettre «P». Voici la liste d'une partie des 57 instructions supplémentaires offert pour le jeu d'instructions MMX :

Instruction Signification Description
EMMS Empty MMX State Cette instruction fixe les mots marqués du MPU de chacun un.
MOVD Move Doubleword Cette instruction permet de copier l'opérande dans un registre XMM ou vice-versa.
MOVQ Move Quadword Cette instruction permet de copier un quadruple mot d'une opérande source vers une opérande destination dans le cas des registres XMM.
PACKSSDW Pack with Signed Saturation DoubleWord Cette instruction permet de compacté 8 paquets de double mots en mots.
PACKSSDW Pack with Signed Saturation DoubleWord Cette instruction permet de compacté 8 paquets de double mots en mots.
PACKSSWB Pack with Signed Saturation Word Byte Cette instruction permet de compacté 8 paquets d'entier en octets.
PACKUSWB Pack with Signed Saturation Unsigned Word Byte Cette instruction permet de compacté 8 paquets de mots en octets.
PADDB Packed Add Byte Cette instruction permet d'effectuer une addition scalaire sur un paquet de 8 octets.
PADDD Packed Add Double Cette instruction permet d'effectuer une addition scalaire sur un paquet de 2 double mots.
PADDSB Packed Add with Saturation Byte Cette instruction permet d'effectuer une addition scalaire avec saturation sur un paquet de 8 octets signés.
PADDSW Packed Add with Saturation Word Cette instruction permet d'effectuer une addition scalaire avec saturation sur un paquet de 4 entiers.
PADDUSB Packed Add Unsigned with Saturation Byte Cette instruction permet d'effectuer une addition scalaire avec saturation sur un paquet de 8 octets.
PADDUSW Packed Add Unsigned with Saturation Word Cette instruction permet d'effectuer une addition scalaire avec saturation sur un paquet de 4 mots.
PADDW Packed Add Word Cette instruction permet d'effectuer une addition scalaire sur un paquet de 4 mots.
PAND Bitwise Logical AND Cette instruction permet d'effectuer un «ET BINAIRE» d'un quadruple mot d'une opérande source avec une opérande destination dans le cas des registres XMM.
PANDN Bitwise Logical AND Cette instruction permet d'effectuer un «ET BINAIRE» et une «NEGATION» de chacun des bits d'un quadruple mot d'une opérande source avec une opérande destination dans le cas des registres XMM.
PCMPEQB Packed Compare for Equal Byte Cette instruction permet d'effectuer une comparaison sur un paquet d'octets et fixe la valeur de chacun d'eux à FFh s'ils sont égales sinon à 00h.
PCMPEQD Packed Compare for Equal Byte Cette instruction permet d'effectuer une comparaison sur un paquet de double mots et fixe la valeur de chacun d'eux à FFFFFFFFh s'ils sont égales sinon à 00000000h.
PCMPEQW Packed Compare for Equal Word Cette instruction permet d'effectuer une comparaison sur un paquet de mots et fixe la valeur de chacun d'eux à FFFFh s'ils sont égales sinon à 0000h.
PCMPGTB Packed Compare for Greater Than Byte Cette instruction permet d'effectuer une comparaison sur un paquet d'octets et fixe la valeur de chacun d'eux à FFh si l'opérande destinataire est supérieur à l'opérande source sinon à 00h.
PCMPGTD Packed Compare for Greater Than Doubleword Cette instruction permet d'effectuer une comparaison sur un paquet de double mots et fixe la valeur de chacun d'eux à FFFFFFFFFh si l'opérande destinataire est supérieur à l'opérande source sinon à 00000000h.
PCMPGTW Packed Compare for Greater Than Word Cette instruction permet d'effectuer une comparaison sur un paquet de mots et fixe la valeur de chacun d'eux à FFFFFh si l'opérande destinataire est supérieur à l'opérande source sinon à 0000h.
PMADDWD Packed Multiply and Add Word Cette instruction permet d'effectuer une multiplication de 2 registres MMX contenant dans un paquet de mots d'un emplacement/mémoire.
PMULHW Packed Multiply and Add Word Cette instruction permet d'effectuer la multiplication de la partie haute de chacun des mots des 2 paquets d'opérandes.
PMULLW Packed Multiply and Add Word Cette instruction permet d'effectuer la multiplication de la partie basse de chacun des mots des 2 paquets d'opérandes.
POR Bitwise Logical OR Cette instruction permet d'effectuer un «OU BINAIRE» d'un quadruple mot d'une opérande source avec une opérande destination dans le cas des registres XMM.
PSLLD Packed Shift Left Logical Doubleword Cette instruction permet d'effectuer le décalage de bits vers la gauche d'un paquet de double mots.
PSLLQ Packed Shift Left Logical Quadword Cette instruction permet d'effectuer le décalage de bits vers la gauche d'un quadruple mot.
PSLLW Packed Shift Left Logical Word Cette instruction permet d'effectuer le décalage de bits vers la gauche d'un paquet de mots.
PSRAD Packed Shift Right Arithmetic Doubleword Cette instruction permet d'effectuer le décalage arithmétique de bits vers la droite d'un paquet de double mots.
PSRAW Packed Shift Right Arithmetic Word Cette instruction permet d'effectuer le décalage de bits vers la droite d'un paquet de mots.
PSRLD Packed Shift Right Logical Doubleword Cette instruction permet d'effectuer le décalage de bits vers la droite d'un paquet de double mots.
PSRLQ Packed Shift Right Logical Quadword Cette instruction permet d'effectuer le décalage de bits vers la droite d'un quadruple mot.
PSRLW Packed Shift Right Logical Word Cette instruction permet d'effectuer le décalage de bits vers la droite d'un paquet de mots.
PSUBB Packed Subtract Byte Cette instruction permet d'effectuer la soustraction de la valeur de chacun des octets d'un paquet contenu dans des opérandes de 64 bits.
PSUBD Packed Subtract Byte Cette instruction permet d'effectuer la soustraction de la valeur de chacun des doubles mots d'un paquet contenu dans des opérandes de 64 bits.
PSUBSB Packed Subtract with Saturation Byte Cette instruction permet d'effectuer la soustraction avec saturation de la valeur de chacun des octets signés d'un paquet contenu dans des opérandes de 64 bits.
PSUBSW Packed Subtract with Saturation Word Cette instruction permet d'effectuer la soustraction du mot de format entier de l'opérande source au mot de format entier de l'opérande de destination et écrit le résultat dans l'opérande destinataire.
PSUBUSB Packed Subtract with Saturation Unsigned Byte Cette instruction permet d'effectuer la soustraction avec saturation de la valeur de chacun des octets d'un paquet contenu dans des opérandes de 64 bits.
PSUBUSW Packed Subtract Unsigned with Saturation Word Cette instruction permet d'effectuer la soustraction avec saturation de la valeur de chacun des mots d'un paquet contenu dans des opérandes de destinations.
PSUBW Packed Subtract Words Cette instruction permet d'effectuer la soustraction de la valeur de chacun des mots d'un paquet contenu dans des opérandes de 64 bits.
PUNPCKHBW Unpack High Bytes to Words Cette instruction permet de décompacter des octets en mots dans le haut d'un paquets de 64 bits.
PUNPCKHDQ Unpack High Dwords to Qwords Cette instruction permet de décompacter des doubles mots en quadruples mots dans le haut d'un paquets de 64 bits.
PUNPCKHWD Unpack High Words to Dwords Cette instruction permet de décompacter des mots en double mots dans le haut d'un paquets de 64 bits.
PUNPCKLBW Unpack Low Bytes to Words Cette instruction permet de décompacter des octets en mots dans le bas d'un paquets de 64 bits.
PUNPCKLDQ Unpack Low Dwords to Qwords Cette instruction permet de décompacter des doubles mots en quadruples mots dans le bas d'un paquets de 64 bits.
PUNPCKLWD Unpack Low Words to Dwords Cette instruction permet de décompacter des mots en double mots dans le bas d'un paquets de 64 bits.
PXOR Bitwise Logical Exclusive OR Cette instruction permet d'effectuer un ou exclusif binaire d'un quadruple mot d'une opérande source avec une opérande destination dans le cas des registres XMM.
RDPMC Read the Performance Monitoring Counter Cette instruction permet d'effectuer la lecture du compteur du moniteur de performance.

Voir également

Langage de programmation - Free Pascal - Prise en charge d'Intel MMX

PARTAGER CETTE PAGE SUR
Dernière mise à jour : Mercredi, le 15 février 2017