Académique Documents
Professionnel Documents
Culture Documents
Microoexercices 170107224859
Microoexercices 170107224859
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 1 :
*
; ============ Donner le programme qui copie :
*
; *) 35 dans la position 20h
*
; *) 'A' dans la position A0h
*
; *) -5 dans la position 110h
*
; *)35h dans la position 190h
*
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto start
start
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
Loop
goto Loop
END
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;
; pour la simulaion voir la RAM
; voir le contenu des addreses : 20h , A0h ,
110h et 190h
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
EXERCICE2
; =========
; Donner le programme qui :
; *) soustrait la constante 33 de l'accumulateur W (W-33)
; *) Soustrait la constante 40h de la case mémoire d'adresse 70h
([70h]-40h)
; *) qui soustrait le contenu de la case mémoire 70h de
l'accumulateur W avec le résultat dans W
; ( W – [70h] -> W )
; *) qui soustrait le contenu de la case mémoire 71h de
l'accumulateur W avec le résultat dans la
; case mémoire ( W – [71h] -> [71h] )
;
;*********************************************************************************
*****************************
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0X00
goto start
start
bank0
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;fonction
principale;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
main;()
;{
movlw 50 ; // w = 50; : on mettre une valeur
initiale qq dans w pour le test
call void_Wmoin33recoiW;(w) // W - 33 -> W : w =
void_Wmoin33recoiW(w);
movwf 0x21; // pour la simulaion : le resultat
est stoquer dans l'adresse 0X21
; // [0x21] = W - 33 ;
movlw 0X50; // w = 0X50 : on mettre une valeur
initiale qq dans w pour le test
movwf case70h; // case70h = 0X50;
call void_CON70Hmoin40HrecoiW;() // [70h]-40h -> W
movwf 0x22; // pour la simulaion : le resultat
est stoquer dans l'adresse 0X22
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; W - 33 -> W
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
void_Wmoin33recoiW
;{
movwf contenu_w ; contenu_w = w = 50
movlw 33 ; w = 33
subwf contenu_w,w ; w = contenu_w - w c-à-d w = w(initiale) - 33
return
;}
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; [70h]-40h -> W
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
void_CON70Hmoin40HrecoiW
;{
movlw 0x40 ; w = 0x40
subwf case70h,w ; w = case70h - w
return
;}
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; W – [70h] -> W
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
void_WmoinCON70HrecoiW
;{
movwf contenu_w ; contenu_w = w = 0XD3
movf case70h,w ; w = case70h c-à-d w = [0x70] = 0X50
subwf contenu_w,w ; w = contenu_w - w c-à-d w = w - [0x70]
return
;}
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; W – [71h] -> [71h]
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
void_WmCON71Hre71H
;{
movwf contenu_w ; contenu_w = w = 0X55
movf case71h,w ; w = case71h = 0X26
subwf contenu_w,w ; w = contenu_w - w c-à-d w = w - case71h = w
- [0x71] = 0X55 - 0X26 = 0X2F = 00101111
movwf case71h ; case71h = w c-à-d case71h = w -
[0x71] ou bien [71h] = W – [71h] = = 0X2F
return
;}
END
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;
; pour la simulaion voir la RAM
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 3
; ==========
; Donner le programme qui copie l'alphabet majuscule dans la RAM à
partir de la position 190h
;
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank0 macro
bcf STATUS,IRP
endm
bank1 macro
bsf STATUS,IRP
endm
org 0x00
goto start
start
bank1
movlw 90h
movwf FSR ;// pointer sur la case d'addresse 190h : FSR =
&[190h];
movlw 0X41 ;// ASCII de la caracere 'A'
movwf INDF ;// mettre 'A' dans la case pointer par FSR c-à-d
190h
movwf caractere ;// caractere = 'A'
Loop
INCF FSR,f ; // pointer sur suivant : FSR++;
INCF caractere,f ; // caractere++;
movf caractere,w ; // w = caractere
movwf INDF ; // *FSR = w ;
movlw 0x5A ; // ASCII de la caractere 'Z'+1
subwf caractere,w ; // w = caractere - w;
btfss STATUS,Z ; // si le contenu de caractere ateind 'Z'+1 finir,
si no recomencer
goto Loop ; // recomencer
goto Rien ; // finir
Rien
goto Rien
END
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;
; pour la simulaion voir la RAM
; voir le contenu des addreses : 190h , 191h
, 192h........1A9h
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 4
; ==========
; Comparer les contenus des cases mémoire 6Fh et EFh, s’il son égaux
mettre à zéro tous les
; bits de la case 16Fh sinon mettre à 1 tous les bits de la case 1EFh
;
; résumer :
; ======== if([0XF6]==[0XEF]) { [0X16F] = 00000000 }
; else { [0X1EF] = 11111111 }
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto void_main
;**********************************programme principale
********************************************************
void_main;()
;{
call void_INIT
bank0
movf VAR,w
bank1
subwf VAR,w
btfss STATUS,Z
call void_MIZ1_1EF
btfsc STATUS,Z
call void_CLEAR_16F
call void_DORMIR
;}
;******************************** fin programme principale
********************************************************
;********************************* definition des fonction utiliser
************************************************
void_INIT;()
;{
bank0
movlw 0x52 ; valeur initiale pour le test
movwf VAR
bank1
movlw 0x66 ; valeur initiale pour le test
movwf VAR
return
;}
;
void_CLEAR_16F;()
;{
bank2
clrf VAR
return
;}
;
void_MIZ1_1EF;()
;{
bank3
clrf VAR
decf VAR,f
return
;}
;
void_DORMIR;()
;{
Loop
goto Loop
return
;}
END
;*********************************************************************************
**************************
; voir RAM adresses : 6F , EF , 16F et 1EF
*
;*********************************************************************************
**************************
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 5
; ==========
; Comparer les contenus des cases mémoire 6Fh et EFh,
; si [6Fh] = [EFh] copier la lettre E dans la case mémoire
16Fh–
; si [6Fh] > [EFh] copier la lettre copier la lettre S dans la
case mémoire 16Fh
; si [6Fh] < [EFh] I dans la case mémoire 16Fh
;
; résumer
; =======
; if([6Fh] = [EFh]) { [16Fh] = 'E' ; }
; if([6Fh] > [EFh]) { [16Fh] = 'S' ; }
; if([6Fh] < [EFh]) { [16Fh] = 'I' ; }
;
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto void_main
void_main;()
;{
call void_INIT
bank1
movf VAR,w
bank0
subwf VAR,w
btfsc STATUS,Z
call void_EGALITE
btfsc STATUS,C
call void_SUPERIEUR
btfss STATUS,C
call void_INFIRIEUR
call void_RIEN
;}
;************************************* fin fonction principale
****************************************************
void_INIT;()
;{
bank0
movlw 75 ; valeur qq pour le test
movwf VAR
bank1
movlw 80 ; valeur qq pour le test
movwf VAR
return
;}
;
void_EGALITE;()
;{
bank2
movlw 'E'
movwf VAR
return
;}
;
void_SUPERIEUR;()
;{
bank2
btfsc STATUS,Z
return
movlw 'S'
movwf VAR
return
;}
;
void_INFIRIEUR;()
;{
bank2
btfsc STATUS,Z
return
movlw 'I'
movwf VAR
return
;}
;
void_RIEN;()
;{
Loop
sleep
goto Loop
return
;}
;
END
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;
; pour la simulaion voir la RAM
; voir l'addresse : 16Fh
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 6
; =========
; Donner le programme qui fait clignoter une LED branchée sur RA0 avec
une temporisation
; voisine de 0.5s. Sachant que le PIC est doté d'un quartz de 4 MHz,
la temporisation sera réalisée à
; l'aide de boucles imbriquées
;
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
X1 EQU 0x20
X2 EQU 0x21
X3 EQU 0x22
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto main
main;()
;{
call void_INIT
bank0
loop
bsf PORTA,0
call void_delay500ms
bcf PORTA,0
call void_delay500ms
goto loop
;}
;
void_INIT;()
;{
bank1
clrf TRISA ; les pins A en sortie
movlw 0x06
movwf ADCON1 ; les pins A utiliser en numérique
return
;}
;
void_delay500ms
;{
;_________________________________________________________________________________
_____________
movlw 205 ;1 cycle
|
movwf X1 ;1 cycle
|
boucle1 ;
|
;____________________________________________________________________
|
movlw 5 ;1 cycle |
|
movwf X2 ;1 cycle |
|
boucle2 ; |
|
;______________________________________________ |
|
movlw 161 ;1 cycle | |
|
movwf X3 ;1 cycle | |
|
boucle3 ; | |
|
;__________________________________ | |
|==> 2439*205-1+2+2+2= 500000 µs
decfsz X3,f ;1 (2) cycle| | |
| = 0.5 s
goto boucle3 ;2 cycle|==>3 cycle |==>3*161-1+2+3 =487µs|
==>487*5-1+2+3=2439 µs |
;__________________________________| | |
|
decfsz X2,f ;1 (2) cycle | |
|
goto boucle2 ;2 cycle | |
|
;______________________________________________| |
|
decfsz X1,f ;1 (2) cycle |
|
goto boucle1 ;2 cycle |
|
;____________________________________________________________________|
|
return ;2 cycle
|
;_________________________________________________________________________________
____________|
;}
;
END
;*********************************************************************************
****************************
;
*
;*********************************************************************************
*****************************
;*********************************************************************************
*****************************
; Exercice 7
;*********************************************************************************
*****************************
; compteur impulsions
*
;
*
; Programme qui :
*
; – Allume la LED branchée sur RB0
*
; – Compte 150 impulsions sur l'entrée RA4 (la case mémoire
70h servira de compteur) *
; – Eteint la LED branchée sur RB0
*
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
;*********************************************************************************
****************************
; declaration des variable
*
;*********************************************************************************
****************************
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto main
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
main
;{
bank1
movlw 0x06
movwf ADCON1
bcf TRISB,0
bsf TRISA,4
bank0
clrf conteur
Loop
bsf PORTB,0
call delay
bcf PORTB,0
call delay
goto Loop
;}
;
;*********************************************************************************
****************************
; sous programme de la temporisation
*
;*********************************************************************************
****************************
delay
;{
movlw 151
movwf conteur
test1
btfss PORTA,4
goto test1
goto test_d_arrite
test0
btfsc PORTA,4
goto test0
goto test1
test_d_arrite
decf conteur,f
movf conteur,f
btfss STATUS,Z
goto test0
return
;}
;*********************************************************************************
***************************
END
;*********************************************************************************
****************************
;
*
;*********************************************************************************
*****************************
;*********************************************************************************
*****************************
; Exercice 8
*
;*********************************************************************************
*****************************
; BCD 7 segments
*
;
*
; – On branche un bouton poussoir sur la broche RA4 de sorte que celle-ci
passe à 0 quand on appuie *
; – On branche un afficheur 7 segments cathode commune sur le port C
*
; – Chaque fois qu’on appuie sur le bouton poussoir, le contenu de
l’afficheur doit s’incrémenter *
; Indication : Le décodage BCD-7 segment sera fait par le programme. On
peut utiliser l’instruction *
; RETLW et goto calculé pour réaliser cette tache
*
;*********************************************************************************
*****************************
; shema à dessiner sur isis
*
;*********************************************************************************
*****************************
;
*
; +5V
*
; ^ ________
*
; |_ -| |-
*
; 220oms|_| -| |-
*
; |----|RA4 |-
*
; | -| |-
*
; button | -| |- _
*
; | -| RC |--------- |_| 7segment
*
; | -| |- |_|
*
; | -|________|-
*
; | pic16f877
*
; |-|-|-|
*
; GND
*
;
*
;*********************************************************************************
*****************************
;*********************************************************************************
****************************
; declaration des variables
*
;*********************************************************************************
****************************
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto void_main
;*********************************************************************************
******************************
; programme principale
*
;*********************************************************************************
******************************
void_main;()
;{
call INITIALISATION
bank0
debut
clrf set_segment ;initialisation de la variable set_segment
: [set_segment] = 0x00.
movf set_segment,w ; w = [set_segment].
call décoder_cette_valeur ; apelle de la fonction
décoder_cette_valeur , la valeur à décoder est envoier par le registre w.
movwf PORTC ; charger la valeur emet par la fonction
dans port c.
call delay ; attender.....
Loop
btfsc PORTA,4 ; test l'etat de la button,
goto Loop ;tant que j'ai pas apui sur le button , ne
rien faire; si je clic sur le button incrimenter
;le contenu de la variable set_segment.
incf set_segment,f
movf set_segment,w
call décoder_cette_valeur ; apelle de la fonction
décoder_cette_valeur , la valeur à décoder est envoier par le registre w.
movwf PORTC ;charger le contenu envoier par la
fonction décoder_cette_valeur.
call delay ;............
movlw 0x09 ; w = 0x09
subwf set_segment,w ;
btfss STATUS,Z
goto Loop ;goto Loop si set_segment != 9.
es
btfsc PORTA,4 ; test l'etat de la button,
goto es
goto debut ;goto debut si set_segment = 9.
;}
;*********************************************************************************
******************************
; definitions des sous programmes
*
;*********************************************************************************
******************************
INITIALISATION;()
;{
bank1
movlw 0x06 ;charger la valeur 6 dans le registre w : w =
0x06.
movwf ADCON1 ;tout les pins de la poete déclarer comme
entrer numérique : ADCON1 = 0x06.
clrf TRISC ;tout la port C en sortie : TRISC = 0x00.
bsf TRISA,4 ;bit 4 de la port A en entrer : TRISA.b4 = 1 .
return
;}
;
décoder_cette_valeur;()
;{
movwf w_temp ;conserver le contenu de w dans w_temp (le
contenu de w c'est la valeur à décoder).
sublw 0x00 ; w = 0 - W
btfsc STATUS,Z ;est ce que w = 0, si oui test reuisser ,
decoder la valeur et le resultat envoier dans w
;si no sauter l'instruction suivant
retlw 0x3f ;return avec w = 0x3f
sublw 0x01
btfsc STATUS,Z
retlw 0x06
movf w_temp,w
sublw 0x02
btfsc STATUS,Z
retlw 0x5b
movf w_temp,w
sublw 0x03
btfsc STATUS,Z
retlw 0x4f
movf w_temp,w
sublw 0x04
btfsc STATUS,Z
retlw 0x66
movf w_temp,w
sublw 0x05
btfsc STATUS,Z
retlw 0x6d
movf w_temp,w
sublw 0x06
btfsc STATUS,Z
retlw 0x7d
movf w_temp,w
sublw 0x07
btfsc STATUS,Z
retlw 0x07
movf w_temp,w
sublw 0x08
btfsc STATUS,Z
retlw 0x7f
movf w_temp,w
sublw 0x09
btfsc STATUS,Z
retlw 0x6f
;}
;
delay
;{
clrf X1
boucle1
clrf X2
boucle2
nop
nop
decfsz X2,f
goto boucle2
decfsz X1,f
goto boucle1
return
;}
;
;*********************************************************************************
*****************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
;*********************************************************************************
*****************************
; Exercice 9
;*********************************************************************************
***************************** *
; EXERCICE 9
; ==========
; Programme qui écrit l alphabet majuscule dans la mémoire EEPROM de
données à partir de la
; position 20h.
*
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
;*********************************************************************************
********************************
org 0x00
goto start
start
bank2
movlw 0X20 ; l'adresse ou on veut ecrire dans l'EEPROM
movwf ADRESSE ; adresse = 0X20
movlw 0X41 ; la donnée à ecrire ASCII de la caracterre 'A'
movwf DATAA ; dataa = 0X41
WHILEE;(DATAA != 'Z+1')
;{
call EEPROM_Write;(ADRESSE,DATAA)
bank2
incf ADRESSE,f ; adresse++;
incf DATAA,f ; dataa++;
movlw 0x5B ; ASCII de la caractere 'Z'+1
subwf DATAA,w ; w = caractere - w;
btfss STATUS,Z ; si le contenu de caractere ateind 'Z'+1 finir, si
no recomencer
goto WHILEE ; recomencer
;}
;
bcf EECON1,WREN ; interdir l'écriture dans l'EEPROM
goto Rien ; finir
;*********************************************************************************
*********************************
Rien
goto Rien ; rien fait : dormir
END
;******************************************Remarque*******************************
*********************************
;
*
;*********************************************************************************
*********************************
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
;
;*********************************************************************************
***************************** *
; EXERCICE 10
; ==========
; Programme qui utilise la directive DE pour initialiser les premières
positions de l'EEPROM de
; données avec la chaîne "BONJOUR CHER AMI". Le programme doit ensuite
lire ces caractères (1
; par 1) dans l' EEPROM et les copier dans la RAM à partir de la
position 110h
*
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x2100
DE "BONJOUR CHER AMI"
;*********************************************************************************
********************************
org 0x00
goto start
start
bank0
movlw 0X00 ;
movwf ADESSE ; adresse dans l'EEPROM
bsf STATUS,IRP ; bank 2
movlw 0X10 ;
movwf FSR ; FSR = & 0X110;
WHILEE;(DATAA != 0XFF)
;
call EEPROM_Read;(ADESSE) ;
bsf STATUS,IRP ; bank 2
movwf INDF ; *FSR = EEDATA;
incf FSR,f ; FSR++;
bank0 ;
incf ADESSE,f ; ADESSE++;
movlw 0XFF ; la valeur par defaut existe dans l'EEPROM
est FF , si on lis FF c-à-d le mos lis est terminer
bank2
subwf EEDATA,w
btfss STATUS,Z
goto WHILEE
goto Rien
Rien
goto Rien
EEPROM_Read;(ADESSE)
;{
bank0 ;
movf ADESSE,w ;
bank2 ;
movwf EEADR ;
bank3 ;
bcf EECON1,EEPGD ; pointer sur l'EEPROM
bsf EECON1,RD ; démarer la l'écture
bank2 ; 2 cycles machine pour finir la l'ecture
movf EEDATA,w ; w = EEDATA;
return; la resultat dans W
;}
;
;**********************************************<Fin>******************************
**********************************
END
;***************************************< Remarque
>****************************************************************
; ===========
; voir la RAM (adresse 110...) et EEPROM (adresse 00...)
pour la simulation
;*********************************************************************************
**********************************
;*********************************************************************************
*****************************
;
;*********************************************************************************
*****************************
; Exercice 11
*
; Mem-Prog vers RAM
; Programme qui lit 20 positions de la mémoire programme débutant à la
position 12FAh et les copie
; dans la RAM à partir de la position 110h. Attention :
; * Le contenu d’une position mémoire programme permet de remplir 2
positions de la RAM.
; * Le débordement de EEADR n’affecte pas EEADRH
*
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto start
start
bank0
movlw 20
movwf conteur
movlw 0XFA ;
movwf ADRL ; adresse dans l'EEPROM 8 bits faible
movlw 0X12 ;
movwf ADRH ; adresse dans l'EEPROM 8 bits fort
bsf STATUS,IRP ; bank 2
movlw 0X10 ;
movwf FSR ; FSR = & 0X110; pointer sur l'adresse
0X110
_FOR;(conteur = 20;conteur>0;conteur--)
;{
call FLASH_Read;(ADRH,ADRL) ;
bank2
movf EEDATH,w ; w = EEDATH ;
bsf STATUS,IRP ; bank2
movwf INDF ; *FSR = EEDATAH ;
incf FSR,f ; FSR++ ;
movf EEDATA,w ; w = EEDATA ;
bsf STATUS,IRP ; bank2;
movwf INDF ; *FSR = EEDATA;
incf FSR,f ; FSR++;
bank0 ;
incf ADRL,f ; ADRL++;
movf ADRL,f ; ADRL = ADRL : utile pour
l'instruction qui suit
btfss STATUS,Z ;( ADRL = 0)? ADRH++ : ( goto
suivant ) ;
goto $ + 2 ; sauter 2 instrictions
incf ADRH,f ;
decfsz conteur,f ;premierment conteur-- apres la test
suivant (conteur = 0) ? (goto Rien) : (goto Rien)
goto _FOR ;
;}
;
goto Rien
Rien
goto Rien
FLASH_Read;(ADRH,ADRL)
;{
bank0 ;
movf ADRL,w ;
bank2 ;
movwf EEADR ;
bank0 ;
movf ADRH,w ;
bank2 ;
movwf EEADRH ;
bank3 ;
bsf EECON1,EEPGD ; pointer sur l'EEPROM PROGRAMME
bsf EECON1,RD ; démarer la l'écture
nop ; atender 2 cycle machine pour finir la l'ecture
nop ;
return
;}
;
;**********************************************<Fin>******************************
**********************************
END
;***************************************< Remarque
>****************************************************************
; ===========
; voir la RAM (adresse 110...124) et EEPROM PROGRAMME (adresse
12FA...130E) pour la simulation
;*********************************************************************************
**********************************
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 12
; ==========
; Programme qui utilise l’interruption INT comme suit :
; Chaque fois que l’entrée RB0 passe de 1 à 0, la LED branchée sur RB1
clignote 4 fois au rythme de
; la ½ seconde
;
;*********************************************************************************
*****************************
list p= 16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
cblock 0x20
tompo1 : 1
tompo2 : 1
tompo3 : 1
endc
cblock 0x70
w_temp : 1
status_temp : 1
endc
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0X00
goto main
;**************************************programme de l'interuption
RB0************************************************
org 0x04
movwf w_temp
swapf STATUS,w
movwf status_temp
bank0
btfss INTCON,INTF
goto fin_intereption
call LED_ONOFF
call LED_ONOFF
call LED_ONOFF
call LED_ONOFF
bcf INTCON,INTF
fin_intereption
swapf status_temp,w
movwf STATUS
swapf w_temp,f
swapf w_temp,w
retfie
;***************************************fin intereption
*********************************************
;****************************************programme principale
****************************************
main;()
;{
call INITIALISATION;
Loop
goto Loop
;}
;
LED_ONOFF;()
;{
bsf LED
call delay500ms
bcf LED
call delay500ms
return
;}
;
INITIALISATION;()
;{
bank1
movlw b'00000000'
movwf OPTION_REG
movlw b'10010000'
movwf INTCON
movlw b'00000001'
movwf TRISB
bank0
clrf PORTB
return
;}
;
delay500ms;()
;{
movlw 65
movwf tompo1
boucle500ms1
movlw 50
movwf tompo2
boucle500ms2
movlw 49
movwf tompo3
boucle500ms3
decfsz tompo3,f
goto boucle500ms3
decfsz tompo2,f
goto boucle500ms2
decfsz tompo1,f
goto boucle500ms1
return
;}
;******************************************************fin
programme******************************************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 13
; ==========
; PIC doté d'un quartz de 4 MHz. Programme qui fait clignoter une LED
branchée sur RB0, delay
; voisin de 0.5s à l'aide de TMR0
; a) Par scrutation du drapeau T0IF (pas d'interruption)
; b) En utilisant l'interruption T0I
;
;*********************************************************************************
*****************************
list p= 16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
cblock 0x70
conteur : 1
w_temp : 1
status_temp : 1
endc
#define LED PORTB,0
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto main
;*********************************************************************************
****************************
; programme de l'interuption RB0
*
;*********************************************************************************
****************************
org 0x04
movwf w_temp
swapf STATUS,w
movwf status_temp
decf conteur,f
bcf INTCON,T0IF
swapf status_temp,w
movwf STATUS
swapf w_temp,f
swapf w_temp,w
retfie
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
main;()
;{
bank1
movlw b'10000100'
movwf OPTION_REG
movlw b'10100000'
movwf INTCON
bcf TRISB,0
bank0
Loop
bsf LED
call delay500ms
bcf LED
call delay500ms
goto Loop
;}
;
;*********************************************************************************
****************************
; sous programme de la temporisation
*
;*********************************************************************************
****************************
delay500ms
;{
movlw 61
movwf conteur
clrf TMR0
debut500ms
movlw 0x00
subwf conteur,w
btfss STATUS,Z
goto debut500ms
return
;}
;
;*********************************************************************************
***************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 13
; ==========
; PIC doté d'un quartz de 4 MHz. Programme qui fait clignoter une LED
branchée sur RB0, delay
; voisin de 0.5s à l'aide de TMR0
; a) Par scrutation du drapeau T0IF (pas d'interruption)
; b) En utilisant l'interruption T0I
;
;*********************************************************************************
*****************************
list p= 16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto main
;**************************************programme
principale**************************************************
main;()
;{
call INITIALISATION
bank0
Loop
call LED_ONOFF
goto Loop
;}
;
;**********************************fin programme
principale**************************************************
LED_ONOFF;()
;{
bsf LED
call delay500ms
bcf LED
call delay500ms
return
;}
;
delay500ms
;{
movlw 61
movwf conteur
clrf TMR0
debut500ms1
bcf INTCON,T0IF
debut500ms2
btfss INTCON,T0IF
goto debut500ms2
decfsz conteur,f
goto debut500ms1
return
;}
;
;*********************************************************************************
***************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 14
; ==========
; Clignoter une LED reliée à RE0. La temporisation voisine de 0.5s sera
réalisée à l'aide de TMR1 par
; scrutation du drapeau TMR1IF
;*********************************************************************************
*****************************
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto start
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
start
bank1
clrf TRISE ; E en sortie
bank0
movlw b'00110000' ;bit 7 et 6: existe pas
;bit 5 et 4 : prescalier / 8
;bit 3 : non utiliser
;bit 2 : chois de l'horloge interne du systeme
;bit 1 : demarage de Timer 1 : pas encors
movwf T1CON
Loop
movlw 0xff
movwf PORTE
call delay
clrf PORTE
call delay
goto Loop
;*********************************************************************************
****************************
; sous programme de la temporisation avec
Timer 1 *
;*********************************************************************************
****************************
delay
bcf PIR1,TMR1IF ;baisser le flag de Timer 1 (pas obligatoire!)
movlw 0xdc
movwf TMR1L ;initialisation de Timer 1 pour obtenaire exactement
0,5 s pour les 8 bits les plus faibles
movlw 0x0b
movwf TMR1H ; pour les 8 bits les plus forts
;
_________________________________________________
; coment calculer 0,5 s
; le Timer 1 compte de 0 à 2^16 =
65536
; T = 65536*10^-6 = 0,065536 s
; prescalier utiliser = 8, donc
; T = 0,065536*8 = 0,524288 s >
0,5 s , donc comment resoudre ce probleme?
; la repence à cette quetion peut
etre resolu par plusieur méthode , mais la pus exact
; c est de modifier la valeur
initiale de Timer 1
; soit x la valeur initiale de
Timer 1 : je veut T = 0,5 s
; donc 0,5 = 65536-x ==> x= 3036
= 0xbdc
; pour cette raison je met dans
TMR1L dc et dans TMR1H 0b
;__________________________________________________
bsf T1CON,0 ; demarer le Timer 1
debut
btfss PIR1,TMR1IF ;est ce que le Timer est terminer
goto debut ;si no : repeter
bcf PIR1,TMR1IF ;si oui: baisser le flag de Timer 1
return
;*********************************************************************************
***************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 15
; ==========
; Clignoter une LED reliée à RD0. La temporisation voisine de 0.5s sera
réalisée à l'aide de TMR1 est
; son interruption TMR1I
;*********************************************************************************
*****************************
cblock 0x20
conteur : 1
w_temp : 1
status_temp : 1
endc
#define LED PORTB,1
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto main
;*********************************************************************************
****************************
; programme de l'interuption RB0
*
;*********************************************************************************
****************************
org 0x04
movwf w_temp
swapf STATUS,w
movwf status_temp
bank0
decf conteur,f
bcf PIR1,TMR1IF
swapf status_temp,w
movwf STATUS
swapf w_temp,f
swapf w_temp,w
retfie
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
main;()
;{
bank1
movlw b'11000000'
movwf INTCON
bcf TRISD,0
bsf PIE1,TMR1IE
bank0
Loop
bsf PORTD,0
call delay
bcf PORTD,0
call delay
goto Loop
;}
;
;*********************************************************************************
****************************
; sous programme de la temporisation
*
;*********************************************************************************
****************************
delay
;{
movlw 8
movwf conteur
bsf T1CON,0
movlw 0xdc
movwf TMR1L ;initialisation de Timer 1 pour obtenaire exactement
0,5 s pour les 8 bits les plus faibles
movlw 0x0b
movwf TMR1H
debut
movlw 0x00
subwf conteur,w
btfss STATUS,Z
goto debut
return
;}
;
;*********************************************************************************
***************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 16
; ===========
; Programme qui génère le signal ci-dessous sur la sortie RE0 en utilisant TMR1
associé à CCP1
;
; __________ __________
; | | | |
; | | | |
; __________| |__________| |__________
; <--------> <-------->
; 500 µs 500 µs
;*********************************************************************************
*****************************
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
;*********************************************************************************
***************************
org 0x00
goto main
;*********************************************************************************
****************************
; configuration des portes et des regestres
*
;*********************************************************************************
****************************
main
bank1
movlw 0X06
movwf ADCON1 ; utiliser port E numérique (par defaut port E
travait en analogique)
CLRF TRISE ; port E en entrer
bank0
movlw b'00001011' ; mode comparaison + TMR1 = 0 (voir le registre
CCP1CON)
movwf CCP1CON ; bits 7 : -
; bits 6 : -
; bits 5 : non utiliser mettre 0
; bits 4 : non utiliser mettre 0
; bits 3,2,1,0: Mode comparaison (drapeau CCP1IF +
RAZ TMR1)
;*********************************************************************************
*****************************
; programme principale
*
;*********************************************************************************
*****************************
Loop
btfss PIR1,CCP1IF ; tester le flag de CCP1 si si ...
goto Loop ;
comf PORTE,f ; PORTE = ~PORTE
bcf PIR1,CCP1IF ; baisser le flag de CCP1 (pour autre utilisation )
goto Loop
;*******************************************fin***********************************
***************************
END
;*********************************************************************************
****************************
;
*
;*********************************************************************************
****************************
; EXERCICE 18
; ===========
; Programme qui génère le signal ci-dessous sur la sortie RB0 en
utilisant TMR2
;
; __________ __________
; | | | |
; | | | |
; __________| |__________| |__________
; <--------> <-------->
; 30 µs 30 µs
;*********************************************************************************
*****************************
cblock 0x20
conteur : 1
w_temp : 1
status_temp : 1
endc
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto main
;*********************************************************************************
****************************
; programme de l'interuption RB0
*
;*********************************************************************************
****************************
org 0x04
movwf w_temp ; ces instrictions sont facultatifs dans ce programme
swapf STATUS,w ; facultatifs
movwf status_temp ; facultatifs
bank0
comf PORTB,f
bcf PIR1,TMR2IF
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
main;()
;{
bsf INTCON,GIE
bsf INTCON,PEIE
bank1
bcf TRISB,0
bsf PIE1,TMR2IE ;activer l'intereption de Timer 2
movlw 29
movwf PR2
bank0
movlw b'00000100' ; bits 6 à 3 : peéscalier = 1
; bits 2 : démarer le Timer 2
; bits 1 à 0 : peéscalier 2 = 1
movwf T2CON
Loop
; atender l'intereption de Timer 2, il est géniré chaque 30µs
NOP
NOP
goto Loop
;}
;
;*********************************************************************************
***************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 18-b
; ===========
; Clignoter une LED reliée à RE0. La temporisation voisine de 0.5s est
réalisée à l'aide de TMR2 :
; 1) Par scrutation du drapeau TMR2IF
; 2) En utilisant l’interruption TMR2I
;*********************************************************************************
*****************************
cblock 0x20
conteur : 1
w_temp : 1
status_temp : 1
endc
#define LED PORTB,1
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto main
;*********************************************************************************
****************************
; programme de l'interuption RB0
*
;*********************************************************************************
****************************
org 0x04
movwf w_temp
swapf STATUS,w
movwf status_temp
bank0
incf conteur,f
bcf PIR1,TMR2IF
swapf status_temp,w
movwf STATUS
swapf w_temp,f
swapf w_temp,w
retfie
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
main;()
;{
bank1
movlw b'11000000'
movwf INTCON
bcf TRISE,0
bsf PIE1,TMR2IE ;activer l'intereption de Timer 2
movlw 199
movwf PR2
bank0
movlw b'00100001' ; bits 6 à 3 : peéscalier = 5
; bits 2 : démarer le Timer: pas maintenant
; bits 1 à 0 : peéscalier 2 = 4
movwf T2CON
Loop
clrf PORTE
call delay
comf PORTE,f
call delay
goto Loop
;}
;
delay
;{
bsf T2CON,TMR2ON ;démarer le Timer
movlw 125
non
subwf conteur,w
btfss STATUS,Z
goto non
return
;}
;
;*********************************************************************************
***************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 18
; ===========
; Clignoter une LED reliée à RE0. La temporisation voisine de 0.5s est
réalisée à l'aide de TMR2 :
; 1) Par scrutation du drapeau TMR2IF
; 2) En utilisant l’interruption TMR2I
;*********************************************************************************
*****************************
cblock 0x20
conteur : 1
w_temp : 1
status_temp : 1
endc
#define LED PORTB,1
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto main
;*********************************************************************************
****************************
; programme de l'interuption RB0
*
;*********************************************************************************
****************************
org 0x04
movwf w_temp
swapf STATUS,w
movwf status_temp
bank0
incf conteur,f
bcf PIR1,TMR2IF
swapf status_temp,w
movwf STATUS
swapf w_temp,f
swapf w_temp,w
retfie
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
main;()
;{
bank1
movlw b'11000000'
movwf INTCON
bcf TRISE,0
bsf PIE1,TMR2IE ;activer l'intereption de Timer 2
movlw 199
movwf PR2
bank0
movlw b'00100001' ; bits 6 à 3 : peéscalier = 5
; bits 2 : démarer le Timer: pas maintenant
; bits 1 à 0 : peéscalier 2 = 4
movwf T2CON
Loop
clrf PORTE
call delay
comf PORTE,f
call delay
goto Loop
;}
;
delay
;{
bsf T2CON,TMR2ON ;démarer le Timer
movlw 125
non
subwf conteur,w
btfss STATUS,Z
goto non
return
;}
;
;*********************************************************************************
***************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
;*********************************************************************************
*****************************
EXERCICE 19
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
;*********************************************************************************
****************************
; declaration des variable
*
;*********************************************************************************
****************************
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto start
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
start
bank1
movlw B'10001111'
movwf ADCON1
bank0
movlw B'01000000'
movwf ADCON0
bsf ADCON0,ADON ; fermer l'interepteur
Loop
call delay ; temps d'aquisition
bsf ADCON0,GO_DONE ; démarer la convertion
atender
btfsc ADCON0,GO_DONE
goto atender
bank0
movf ADRESH,w ; w = ADRESH ;
movwf adr_70 ; adr_70 = ADRESH ;
bank1
movf ADRESL,w ; w = ADRESL ;
bank0
movwf adr_71 ; adr_71 = ADRESL ;
goto Loop
;=================================================================================
=============================
delay ; T = 3*4-1+2+1+2+2 = 18 µs
movlw 4
movwf tompo
lala
decfsz tompo,f
goto lala
nop
return
;*********************************************************************************
***************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 20
; ==========
; Sur un PIC doté d'un quartz de 4 MHz, Donner le programme qui fait
l'acquisition de 40
; échantillons du signal appliqué sur RA0, et recopie les résultats dans
la RAM à partir de la
; position 190h. L'échantillonnage se fera à la vitesse la plus rapide
possible
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
;*********************************************************************************
*****************************
; declaration des variable
*
;*********************************************************************************
*****************************
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto start
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
start
bank1
bsf TRISA,0
movlw B'10001111'
movwf ADCON1
bank0
movlw B'01000000'
movwf ADCON0
movlw 40
movwf conteur
bsf ADCON0,ADON
Loop
bcf STATUS,IRP
call delay
bsf ADCON0,GO_DONE
atender
btfsc ADCON0,GO_DONE
goto atender
bsf STATUS,IRP
movf adr_190,w
movwf FSR
bcf STATUS,IRP
movf ADRESH,w
bsf STATUS,IRP
movwf INDF
incf FSR,f
bcf STATUS,IRP
movf ADRESL,w
bsf STATUS,IRP
movwf INDF
incf FSR,f
decfsz conteur,f
goto Loop
Rien
goto Rien
;=================================================================================
=============================
delay
movlw 4
movwf tompo
lala
decfsz tompo,f
goto lala
nop
return
;*********************************************************************************
***************************
END
;*********************************************************************************
*****************************
;
*
;*********************************************************************************
*****************************
; EXERCICE 21
; ==========
; Sur un PIC doté d'un quartz de 4 MHz, Donner le programme qui fait
l'acquisition de 40
; échantillons du signal appliqué sur RA0, et recopie les résultats dans
la RAM à partir de la
; position 190h.avec une fréquence d’échantillonnage fe = 8000Hz
;*********************************************************************************
*****************************
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
;*********************************************************************************
*****************************
; declaration des variable
*
;*********************************************************************************
*****************************
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto start
;*********************************************************************************
****************************
; configuration des portes des variable
*
;*********************************************************************************
****************************
start
bank1
bsf TRISA,0
movlw B'01001111'
movwf ADCON1
bank0
movlw B'10000000'
movwf ADCON0 ; bits 7 et 6 :Choix de l'horloge de conversion 00=
1:2 01= 1:8 10= 1:32 11:Oscillateur RC dédié au CAN
; bits 5,4 et 3:
; bits 2 : démarer la convertion
; bits 1 : -
; bits 0 : activer la convertion
movlw 40
movwf conteur ; pour faire l'acquisition de 40 échantillons;
;*********************************************************************************
********************************
; programme principale
;*********************************************************************************
********************************
Loop
bcf STATUS,IRP ;
call delay ; Tacq = 85 µs
bsf ADCON0,GO_DONE
atender
btfsc ADCON0,GO_DONE ; |
goto atender ; | === > 24 µs
bsf STATUS,IRP ; 1 µs
movf adr_190,w ; 1 µs
movwf FSR ; 1 µs
bcf STATUS,IRP ; 1 µs
movf ADRESH,w ; 1 µs
bsf STATUS,IRP ; 1 µs
movwf INDF ; 1 µs ====== > 16 µs
incf FSR,f ; 1 µs
bcf STATUS,IRP ; 1 µs
movf ADRESL,w ; 1 µs
bsf STATUS,IRP ; 1 µs
movwf INDF ; 1 µs
incf FSR,f ; 1 µs
decfsz conteur,f ; 1 µs
goto Loop ; 2 µs
;*****************************Remarque********************************************
***********************************
; comment calculer fe = 8000 Hz
*
; =============================
*
; ce fréquence dépent de 3 parametre fondammentals
*
; *) le temps d'aquisition : c'est le temps entre le ferméture de
l'interepteur et le démarage de la conversion *
; *) le temps de conversion de la données, il dépend de la
fréquence de l'hourloge choisis *
; Tcon = 12*Tad ; avec Tad est le temps de conversion
d'un bit *
; Tad = div* 1/Fosc
*
; *) les instruction de commende , pour nous : Tu = 16 µs
*
;
*
; on choisis div = 8 ; donc Tad = 8*1/4 = 2 µs ;donc Tcon = 12*2 =
24 µs *
; donc le temps totale d'un cycle est T= Tcon + Tacq + Tu = 24 +
Tacq + 16 = 40 + Tacq *
; on veut optenir f = 8000 Hz = 1/T ==> T = 1/8000 = 40*10^-6 +
Tacq ==> Tacq = 1/8000-40*10^-6= 85 µs *
; conclusion pour avoir f = 8000 Hz il faut utiliser Tacq = 85 µs;
*
; remarque : ce n'est pas la seule méthode on peut agir sur le
temps Tu et div pour trouver la frequence demender *
; ========
*
;*********************************************************************************
***********************************
Rien
goto Rien
;=================================================================================
=============================
delay ; 85 µs
movlw 26
movwf tompo
lala
decfsz tompo,f
goto lala
nop
nop
return
;*********************************************************************************
***************************
END
exercice 22
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto start
;*********************************************************************************
*****************************
; configuration des portes
*
;*********************************************************************************
*****************************
start
call EUSART_INIT
bank0
movlw 'A'
movwf DATAA
Loop
call void_dely500ms
bank0
movf DATAA,w
call EUSART_DATA_SEND
bank0
incf DATAA,f
movf DATAA,w
sublw 0X5B ;// 'Z+1'
btfss STATUS,Z
goto Loop
bcf RCSTA,SPEN
goto Rien
Rien
goto Rien
EUSART_INIT
;{
bank1
movlw B'00100100'
movwf TXSTA
bank0
bsf RCSTA,SPEN
bank1
movlw 12
movwf SPBRG
return
;}
EUSART_DATA_SEND
;{
bank0
NON
btfss PIR1,TXIF
goto NON
movwf TXREG
return
;}
;
void_dely500ms;()
;{
movlw 205
movwf tompo1
boucle1
movlw 5
movwf tompo2
boucle2
movlw 161
movwf tompo3
boucle3
decfsz tompo3,f
goto boucle3
decfsz tompo2,f
goto boucle2
decfsz tompo1,f
goto boucle1
return
;}
;
END
;*********************************************************************************
************************
;
;*********************************************************************************
************************
EXERCICE 23
list p=16f877 , r=dec
#include p16f877.inc
__CONFIG H'3F39'
bank0 macro
bcf STATUS,RP0
bcf STATUS,RP1
endm
bank1 macro
bsf STATUS,RP0
bcf STATUS,RP1
endm
bank2 macro
bcf STATUS,RP0
bsf STATUS,RP1
endm
bank3 macro
bsf STATUS,RP0
bsf STATUS,RP1
endm
org 0x00
goto start
;*********************************************************************************
*****************************
; configuration des portes
*
;*********************************************************************************
*****************************
start
bank1
clrf TRISB
call EUSART_INIT
Loop
call void_TEST_ERREUR
call void_dely500ms
call EUSART_DATA_RECEPT
bank0
movwf DATAA
movwf PORTB
goto Loop
goto Rien
Rien
goto Rien
EUSART_INIT
;{
bank1
movlw B'00000100'
movwf TXSTA
bank0
movlw B'10010000'
movwf RCSTA
bank1
movlw 12
movwf SPBRG
return
;}
EUSART_DATA_RECEPT
;{
bank0
NON
btfss PIR1,RCIF
goto NON
movf RCREG,w
return
;}
void_TEST_ERREUR
;{
bank0
clrf ERR
btfsc RCSTA,FERR
bsf ERR,0
movf ERR,w
btfsc RCSTA,OERR
iorlw 1
btfss ERR,0
return
call void_RESET
return
;}
;
void_dely500ms;()
;{
bank0
movlw 205
movwf tompo1
boucle1
movlw 5
movwf tompo2
boucle2
movlw 161
movwf tompo3
boucle3
decfsz tompo3,f
goto boucle3
decfsz tompo2,f
goto boucle2
decfsz tompo1,f
goto boucle1
return
;}
;
void_RESET
;{
bank0
bcf RCSTA,SPEN
nop
bsf RCSTA,SPEN
return
;}
;
END