.equ PINA = 0x00 ; définition des adresses des ports .equ DDRA = 0x01 .equ PORTA = 0x02 .equ WDTCSR = 0x60 .equ RAMEND = 0x21FF .equ SPH = 0x3E ; initialisation de la pile .equ SPL = 0x3D .org 0x000 ; Vecteur RESET jmp debut .org 0x0080 debut: DDRA@IO <- 0x01 ; Configuration du port pour mettre la LED en sortie et le bouton en entrée attend: ; On reste là si le bouton n'est pas appuyé si (PINA@IO & 0x02) == 0 saut attend ; Dès que le bouton est appuyé cli ; Activation du chien de garde en mode RESET WDTCSR <- 0b00010000 ; Autorise la modification du chien de garde WDTCSR <- 0b00001110 ; Reset le programme après 1 seconde sei PORTA@IO <- 0x01 ; On allume la LED boucle: ; On reste ici en attendant que le watchdog arrive à expiration si le bouton est relâché si (PINA@IO & 0x02) = 0 saut boucle wdr ; Sinon si le bouton est appuyé on bloque le watchdog à 1s jmp boucle