GPA770: Micro - PowerPoint PPT Presentation

1 / 34
About This Presentation
Title:

GPA770: Micro

Description:

C.1 Configurations mat rielles: architecture du syst me, m moire, et ... au nombre de registres qu'on peut adresser. M = 2m, o m = largeur du ADDR. capacit : ... – PowerPoint PPT presentation

Number of Views:63
Avg rating:3.0/5.0
Slides: 35
Provided by: RichardL174
Category:
Tags: adresser | gpa770 | micro

less

Transcript and Presenter's Notes

Title: GPA770: Micro


1
CONTENU DU COURS
2
Partie C - Concepts matériels
  • C.1 Configurations matĂ©rielles
  • architecture du système, mĂ©moire, et ports de/s
  • C.2 Gestion dexceptions
  • rĂ©ponses aux remises-Ă -zĂ©ro et aux interruptions
    avec le 68HC12
  • vecteur et prioritĂ© dexceptions, et routines de
    service dinterruption
  • C.3 Module de temporisation
  • module de temporisation standard du 68HC12
  • saisie des entrĂ©es et comparaison de sorties
  • C.4 Convertisseurs analogique-numĂ©rique
  • processus de conversion
  • système de conversion du 68HC12
  • C.5 Interfaces de communications sĂ©rielles
  • communications sĂ©rielles avec un microcontrĂ´leur
  • interfaces sĂ©rielles multiples du 68HC12 SCI et
    SPI

3
Sommaire de la section C.1
  • C.1 Configurations matĂ©rielles
  • Architecture du système 68HC12
  • Sous-système de mĂ©moire
  • Ports dentrĂ©e/sortie

4
C.1(1) Architecture du système
  • CaractĂ©ristiques du 68HC12
  • introduit au marchĂ© en 1997 Ă©volution plus
    performante et versatile (instructions, modes
    dadressage, etc.) du 68HC11
  • microcontrĂ´leur avec CPU Ă  16 bits le chemin de
    données interne est de 16 bits
  • horloge de système Ă  8 MHz gĂ©nĂ©rĂ©e par un
    crystal à 16MHz divisé par 2
  • conçu en technologie CMOS la consommation de
    puissance est basse
  • architecture de système un ensemble de modules
    interconnecté par un bus interne

5
C.1(1) Architecture du système
  • Principaux modules dans tous les 68HC12
  • CPU12 unitĂ© de traitement central Ă  haute
    performance de 16 bits
  • INT module de gestion dinterruption et de RAZ
  • MĂ©moire un bloc de registres (512 octets), de la
    RAM (1Koctets) et de la EEPROM (variable)
  • Bus le module LIM - combine les buses de DATA,
    dADDR et de CTRL
  • PĂ©riphĂ©riques dentrĂ©e/sortie
  • ports dentrĂ©e/sortie
  • module de temporisation (TIM) Ă  16 bits
  • convertisseur analogique-numĂ©rique (ADC) Ă  8
    bits
  • interfaces de communications sĂ©rielles SCI et
    SPI

6
C.1(1) Architecture du système
  • Plusieurs variantes du 68HC12
  • diffĂ©rences entre variantes selon
  • la structure de la mĂ©moire
  • le nombre et partage de canaux dentrĂ©e/sortie
  • la configuration pour les communications
    sérielles
  • en cours MC68HC912B32 ciblĂ© pour mode circuit
    autonome
  • au laboratoire MC9S12C32 (sĂ©rie 68HCS12 -
    introduit au marché en 2002), avec plus de
    mémoire interne et une horloge à 25 MHz

7
C.1(1) Architecture du système
  • MC68HC912B32
  • avec composants propres
  • mĂ©moire (32 Koctets de Flash EEPROM)
  • modulateur de durĂ©e dimpulsion (PWM)
  • En mode Ă©tendu, les bus ADDR et DATA sont
    multiplexés (ports A et B)
  • pas de ports C et D

8
C.1(1) Architecture du système
MC9S12C32
9
C.1(1) Architecture du système
  • Modes dopĂ©ration
  • 3 modes normaux avec protection de rĂ©gions
  • mode normal circuit autonome
  • mode normal Ă©tendu bus DATA de 16 bits
  • mode normal Ă©tendu Ă©troit bus DATA de 8 bits
  • 5 modes spĂ©ciaux
  • pour les tests et le dĂ©veloppement en usine
  • donne daccès aux rĂ©gions protĂ©gĂ©es
  • Configuration du mode dopĂ©ration selon 3 broches
    externes
  • BKGD MODB MODA

10
C.1(1) Architecture du système
  • Mode normal circuit autonome
  • BKGD 1 MODB 0 MODA 0
  • utilisĂ© quand toutes les ressources (mĂ©moire pour
    programmes et variables) sont contenues dans le
    microcontrĂ´leur
  • suppose aucun bus externe ADDR ou DATA
  • les ports A, B, C et D peuvent servir de GPIOs
  • ces ports parallèles font 1 octet chaque

11
C.1(1) Architecture du système
  • Mode dopĂ©ration normal Ă©tendu
  • BKGD 1 MODB 0 MODA 1
  • utilisĂ© quand la mĂ©moire interne nest pas
    suffisante pour lapplication
  • les ports A et B forment un ADDR Ă  16 bits
  • les ports C et D forment un DATA Ă  16 bits
  • remarque C et D sont utilisĂ©s pour DATA car le
    CPU12 lit/Ă©crit 2 octets (16 bits) Ă  la fois,
    alignée sur les adresses paires...

12
C.1(1) Architecture du système
  • Mode dopĂ©ration normal Ă©tendu Ă©troit
  • BKGD 1 MODB 1 MODA 1
  • aussi utilisĂ© quand la mĂ©moire interne nest pas
    suffisante pour lapplication
  • les ports A et B forment un ADDR Ă  16 bits
  • le port C forme un DATA Ă  8 bits
  • les donnĂ©es de 16 bits sont transfĂ©rĂ©es 1 octet Ă 
    la fois le MSB premier, et ensuite le LSB
  • ladresse est auto incrĂ©mentĂ©e pour le LSB
  • le port D peut servir de GPIOs

13
C.1(1) Architecture du système
  • Interface - broches dentrĂ©es/sorties
  • boĂ®tiers de puces pour la famille 68HC12 sont
    disponibles sous plusieurs formes
  • entre 80 et 112 broches, dont la fonction est
    partagée selon le mode dopération
  • pour un circuit ciblĂ© autonome buses ADDR et
    DATA sont multiplexés pour fonctionner en mode
    Ă©tendu
  • types de broches
  • alimentation tension ou de rĂ©fĂ©rence Vxx
  • ports Pxx
  • contrĂ´le externe XTAL, etc.

14
Sommaire de la section C.1
  • C.1 Configurations matĂ©rielles
  • Architecture du système 68HC12
  • Sous-système de mĂ©moire
  • Ports dentrĂ©e/sortie

15
C.1(2) Sous-système de mémoire
  • Modèle gĂ©nĂ©ral liste adressable de registres

16
C.1(2) Sous-système de mémoire
  • CapacitĂ© dune mĂ©moire
  • largeur de mĂ©moire (n)
  • correspond au nombre de bits par registre
  • N largeur du DATA (N pas toujours n)
  • longueur de mĂ©moire (M)
  • correspond au nombre de registres quon peut
    adresser
  • M 2m, oĂą m largeur du ADDR
  • capacitĂ© largeur x longueur n x M bits

17
C.1(2) Sous-système de mémoire
  • CapacitĂ© modèle de mĂ©moire du 68HC12
  • n 8 bits (1 octet) par registre
  • bus DATA (interne) de N 2n 16 bits
  • bus ADDR de m 16 bits
  • adresses de 0000 Ă  FFFF
  • donc on peut adresser
  • M 216 65, 536 64k registres
  • capacitĂ© potentielle de mĂ©moire
  • C n x M 8 x 64 kbits

18
C.1(2) Sous-système de mémoire
  • Composants de mĂ©moire interne au 68HC12
  • bloc de registres configurations du contrĂ´leur
  • RAM variable temporaires
  • Flash EEPROM programmes (i.e., sĂ©quences
    dinstructions) et constantes
  • Allocation des composants
  • dĂ©pend du montage spĂ©cifique (configuration,
    carte, etc.)
  • chaque composant peut ĂŞtre liĂ© Ă  une autre espace
    mémoire sur les bornes 2k ou 4k-octets
  • Expansion mĂ©moire en mode Ă©tendue on peut
    allouer un espace adressable Ă  un composant
    mémoire externe

19
C.1(2) Sous-système de mémoire
MC9S12C32
20
C.1(2) Sous-système de mémoire
  • Bloc de registres
  • dĂ©f. registres (512 octets) Ă  usage spĂ©cial
    qui permettent de configurer le 68HC12
  • contiennent les valeurs dĂ©faut après une remise Ă 
    zéro
  • permettent dactiver un sous-système et de le
    configurer pour des tâches spécifiques
  • Exemples activer le ATD avec le registre ATDCTL2
  • ATDCTL2 EQU 0062 dĂ©claration du registre
  • ......
  • LDAA 10000000 masque pour alimenter
    le ATD
  • STAA ATDCTL2

21
C.1(2) Sous-système de mémoire
  • Les registres de configuration sont liĂ©s Ă  la
    mémoire
  • une adresse spĂ©cifique du bloc est associĂ©e Ă 
    chacun des registres de configuration, permettant
    ainsi
  • dinterroger (lire) les registres avec LDxx...
  • de manipuler (Ă©crire) les registres avec STxx...
  • 000001FF adresses pour lensemble des
    registres du bloc
  • Note lusager devrait Ă©tiqueter chaque registre
    du bloc, et lui associer son adresse avec la
    directive EQU
  • car ce ne sont pas des mots rĂ©servĂ©s pour
    lassembleur

22
Sommaire de la section C.1
  • C.1 Configurations matĂ©rielles
  • Architecture du système 68HC12
  • Sous-système de mĂ©moire
  • Sous-système de ports

23
C.1(3) Sous-système de ports
  • dĂ©finition pĂ©riphĂ©riques permettant la
    communication binaire parallèle avec
    lenvironnement externe
  • Chaque port a un cĂ´tĂ© externe et interne
  • vue externe chaque port est un bus de 8 bits
    permettant la communication de données avec un
    composant externe
  • vue interne chaque port est un registre qui est
    liés à la mémoire (appartient au bloc de
    registres)

24
C.1(3) Sous-système de ports
  • Vue externe
  • Concept dentrĂ©e/sortie parallèle
  • un port de/s est un ensemble de 8 broches quon
    peut connecter avec un bus de 8 bits
  • donc 8 bits peuvent ĂŞtre lues/Ă©crites
    simultanément
  • caractĂ©ristique commune au microprocesseurs qui
    permet des opérations dentrée/sortie rapides

25
C.1(3) Sous-système de ports
  • Vue externe
  • Le 68HC12 est un système Ă  ports multiples
  • A H, J ports de/s dont la fonction dĂ©pend du
    mode dopération et des configurations
  • M, S ports pour les modules SCI et SPI
  • T port pour le module TIM
  • P port pour le module PWM
  • AD port pour le module ATD

26
C.1(3) Sous-système de ports
27
C.1(3) Sous-système de ports
  • Vue interne
  • Architecture dentrĂ©e/sortie liĂ©es Ă  la mĂ©moire
  • on contrĂ´le un port de/s Ă  travers les registres
    internes du port, liés au bloc de registres
  • les bus DATA, ADDR et CTRL internes servent Ă 
    contrôler les ports de/s, comme de la mémoire
  • les instructions LDxx et STxx permettant
    daccéder à la mémoire servent aussi à contrôler
    les ports de/s

28
C.1(3) Sous-système de ports
  • Vue interne
  • ProcĂ©dure pour contrĂ´ler les ports
    dentrée/sortie
  • donnĂ©es en entrĂ©e
  • transfert entre fils connectĂ©s au port dentrĂ©e ?
    reg 68HC12
  • utilise les instructions pour lire des donnĂ©es de
    la mémoire (LDAA, MOVB, etc.)
  • donnĂ©es en sortie
  • utilise les instructions pour Ă©crire des donnĂ©es
    à la mémoire (STAA, MOVB, etc.)
  • transfert entre reg 68HC12 ? fils connectĂ©s au
    port de sortie

29
C.1(3) Sous-système de ports
  • La fonction spĂ©cifique dun port dĂ©pend des
    configurations
  • on configure chaque port comme entrĂ©e, sortie, ou
    bien bi-directionnel (mixte)
  • avec un port bi-directionnel (e.g., A, B, P et
    T), certains bits sont en entrée, dautres sont
    en sortie
  • les adresses de ports devraient aussi ĂŞtre
    étiquetées avec la directive EQU
  • PORTA EQU 0000 voir le bloc de registres
  • DDRB EQU 0003

30
C.1(3) Sous-système de ports
  • Registres pour configurer un port
  • DDRx (Data Direction Register) configure les
    bits du port comme entrée (0) ou sortie (1)
  • PUCR (Pull Up Control Register) permet
    dutiliser des résistances intégrées pull-up
    pour toutes les broches dun port (applications
    dinterface)
  • RDRIV (Reduced Drive of I/O Line Registers)
    permet de réduire la capacité de conduite
    (courant) de toutes broches dun port de sortie

31
C.1(3) Sous-système de ports
  • Exemples configurer les port A et B comme entrĂ©e
    et sortie
  • PORTA EQU 0000 voir le bloc de registres
  • PORTB EQU 0001
  • DDRA EQU 0002
  • DDRB EQU 0003
  • ORG 4000
  • CLRA configurer le PORT A en entrĂ©e
  • STAA DDRA
  • COMA configurer le PORT B en sortie
  • STAA DDRB
  • Ă©crire au port B
  • lire du port A
  • END

32
C.1(3) Sous-système de ports
  • Exemples Ă©limine les rĂ©sistances pull-ups sur
    ports B et C, et réduire le courant sur ports B
    et D
  • PUCR EQU ______ voir le bloc de registres
  • RDRIV EQU ______
  • ............
  • LDAA Ă©limine pull-up sur
    A et B
  • STAA PUCR
  • LDAA _____ rĂ©duire de conduite sur B
  • STAA RDRIV

33
C.1(3) Sous-système de ports
  • Exemple Feux de circulation
  • ORG 0800
  • LDAA 00111111 Broches du PORTA en
    sortie
  • STAA DDRA
  • MAIN LDAA 00100001 RE et VN actifs au
    début
  • STAA PORTA Active les LEDs
  • JSR DELAI3 Sous-routine de dĂ©lai de 3 sec
  • LDAA 00010001 RE et JN actifs
  • STAA PORTA Active les LEDs
  • JSR DELAI1 Sous-routine de dĂ©lai de 1 sec
  • LDAA 00001100 VE et RN actifs
  • STAA PORTA Active les LEDs
  • JSR DELAI3 Sous-routine de dĂ©lai de 3 sec
  • LDAA 00001010 JE et RN are actifs

34
C.1(3) Sous-système de ports
  • Exemple Feux de circulation
  • DELAI3 LDY 120 120 fois en boucle externe
  • Loop2 LDX 50000 50,000 fois en boucle
    interne25 msec
  • Loop1 DEX dĂ©crĂ©mente X
  • BNE Loop1 boucle interne
  • DEY dĂ©crĂ©mente Y
  • BNE Loop2 boucle externe
  • RTS retour de la sous-routine
  • DELAI1 LDY 40 40 fois en boucle externe
  • Loop4 LDX 50000
  • Loop3 DEX
  • BNE Loop3
  • DEY
  • BNE Loop4
  • RTS
Write a Comment
User Comments (0)
About PowerShow.com