This repository has been archived on 2019-08-08. You can view files and clone it, but cannot push or open issues or pull requests.
s6-up-tp/TP4/TP42a.txt
2017-06-09 12:30:34 +02:00

92 lines
1.9 KiB
Plaintext

.equ RAMEND = 0x21FF
.equ SPH = 0x3E
.equ SPL = 0x3D
.equ ADMUX = 0x7C
.equ ADCSRB = 0x7B
.equ ADCSRA = 0x7A
.equ ADCH = 0x79
.equ UBRR0H = 0x00C5
.equ UBRR0L = 0x00C4
.equ UCSR0A = 0x00C0
.equ UCSR0B = 0x00C1
.equ UCSR0C = 0x00C2
.equ UDR0 = 0x00C6
.equ TCCR0A = 0x24
.equ TCCR0B = 0x25
.equ TIMSK0 = 0x6E
.equ TIFR0 = 0x35
.org 0x0000
; Vecteur RESET
jmp debut
.org 0x002E ; Interruption du timer
jmp tm
.def timer = r20
.org 0x0080
debut:
; initialisation du pointeur de pile
ldi r28,low(RAMEND)
ldi r29,high(RAMEND)
out SPL, r28
out SPH, r29
; Port série 16 MHz 2400 Baud
UBRR0H <- 3
UBRR0L <- 64
UCSR0A <- 0b00000110
UCSR0B <- 0b00011000
UCSR0C <- 0b00000110
; Timer toutes les 65 ms
TCCR0A@IO <- 0x00
TCCR0B@IO <- 0b00000101
TIMSK0 <- 0x01
TIFR0 <- 0x01
; ADC en déclenchement manuel
ADMUX <- 0b01100000
ADCSRB <- 0b00000010
ADCSRA <- 0b11010110
sei
timer <- 0
boucleTemps:
si timer < 122 saut boucleTemps ; 8 secondes ne sont pas encore passées
timer <- 0
; Lancement d'une conversion ADC
ADCSRA <- 0b11011101
; Tant que la conversion ADC n'est pas terminée
boucleAdc:
si (ADCSRA & 0x80) == 0 saut boucleAdc
UDR0 <- ADCH / 10
; Tant que le premier caractère n'est pas envoyé, attendre avant d'envoyer le prochain
boucleCar0:
si (UCSR0A & 0x4) == 0 saut boucleCar0
UDR0 <- ADCH % 10
; Tant que le deuxième caractère n'est pas envoyé, attendre avant d'envoyer le prochain
boucleCar1:
si (UCSR0A & 0x4) == 0 saut boucleCar1
UDR0 <- 67
; Tant que le troisième caractère n'est pas envoyé, attendre avant d'envoyer le prochain
boucleCar2:
si (UCSR0A & 0x4) == 0 saut boucleCar2
UDR0 <- 13
; Tant que le quatrième caractère n'est pas envoyé, attendre avant d'envoyer le prochain
boucleCar3:
si (UCSR0A & 0x4) == 0 saut boucleCar3
saut boucleTemps
tm:
inc timer
reti