Accueil
Démo
Exercices formatifs
Travaux pratiques
Simulation libre
Sessions sauvegardées

Sauvegarde de contexte

Observons comment le contexte (PC et CPSR) est sauvegardé lors d'une interruption.

Registre Généraux (User)

Nom Valeur
R0
R1
R2
R3
R4
R5
R6
R7
R8
R9
R10
R11
R12
R13 (sp)
R14 (lr)
R15 (pc)

Registre Généraux (FIQ)

Nom Valeur
R0
R1
R2
R3
R4
R5
R6
R7
R8 FIQ
R9 FIQ
R10 FIQ
R11 FIQ
R12 FIQ
R13 FIQ (sp)
R14 FIQ (lr)
R15 (pc)

Registre Généraux (IRQ)

Nom Valeur
R0
R1
R2
R3
R4
R5
R6
R7
R8
R9
R10
R11
R12
R13 IRQ (sp)
R14 IRQ (lr)
R15 (pc)

Registre Généraux (SVC)

Nom Valeur
R0
R1
R2
R3
R4
R5
R6
R7
R8
R9
R10
R11
R12
R13 SVC (sp)
R14 SVC (lr)
R15 (pc)

État courant

 CPSRSPSR
Negatif (N)
Zero (Z)
Retenue (C)
Dépassement (V)
Ignore IRQ
Ignore FIQ

Configurations

Interruptions

Activer
Type
 cycles
 cycles (premier)
Vitesse d'exécution :  ms

Français

SECTION INTVEC B main NOP ; "no-operation", donc ne fait rien si cette instruction est rencontrée! B interruptionLogicielle ; toutes les autres interruptions ne sont pas supportées SECTION CODE main ; Modifions la valeur du CPSR (manuellement) NOP ; Stockons quelle sera la valeur de PC à la prochaine instruction ADD R0, PC, #4 ; Déclenchons une interruption logicielle SVC #10 B main interruptionLogicielle ; début de la routine de traitement de l'interruption logicielle ; vérifions que le SPSR (SPSR_svc) contient ce que le CPSR contenait avant NOP ; si on modifie le CPSR, ça ne change pas le SPSR (SPSR_svc) NOP ; vérifions que LR (LR_svc) contient PC NOP ; fin de la routine de traitement de l'interruption logicielle SUBS PC, LR, #4 SECTION DATA

Instruction courante

Mémoire

Suivre PC
Cycle courant :