Gestione delle subroutine - PowerPoint PPT Presentation

About This Presentation
Title:

Gestione delle subroutine

Description:

Title: Gestione delle subroutine Author: OPNET WARRIORS Last modified by: Roberto Palmieri Created Date: 4/18/2003 6:43:09 AM Document presentation format – PowerPoint PPT presentation

Number of Views:40
Avg rating:3.0/5.0
Slides: 8
Provided by: OPNE
Category:

less

Transcript and Presenter's Notes

Title: Gestione delle subroutine


1
Esercizio Esame
Un processore PD32 è interfacciato a due
periferiche di input A e B, e ad un DMAC il quale
puo gestire trasferimento di dati da B verso la
memoria. A e B lavorano a 8 bit. Il processore
acquisisce 2048 dati da B tramite il DMAC il
quale li memorizza in un buffer di 2048 byte ad
indirizzo ABCDh. Al termine dellacquisizione, il
DMAC avverte il processore tramite una
interruzione, il cui servizio e il seguente il
processore acquisisce 2048 dati da A tramite la
tecnica delle interruzioni e verifica, per
ciascuno di essi, luguaglianza con il
corrispondente dato precedentemente acquisito da
B. Se almeno uno dei dati non soddisfa
luguaglianza, il processore deve porre ad 1 il
valore di un byte ad indirizzo 0BBBh. Progettare
linterfaccia tra il DMAC ed il PD32. Progettare
inoltre il software per attivare DMAC ed A, e per
gestirne le interruzioni. Si ipotizzi che un
buffer di 6 byte sia disponibile ad indirizzo
000Ah per la programmazione e la gestione
dellinput dalla periferica A e che nessun altro
buffer di memoria possa essere utilizzato. Si
ipotizzi inoltre che i servizi di interruzione di
DMAC ed A siano non interrompibili.
2
Logica dellinterfaccia del DMAC per le
interruzioni
IRQ
CPU
I/O AB
I/O DB
I/O CB
START
CLEAR
IACKIN
IRQ
IVN
STARTD
Decoder
O.C.
SELECT
COMPLETE
SCO DMAC
STARTDEV
IACKOUT
3
AB
PD32
DB
MEMORIA
CB
8 bit
I/O WR
INC
CAR
8 bit
LD
REG
REG
SELECT
DECR
MRD
WC
I/O WR
TC
NEXT DATO
Q
MBR
I/O AB
I/O DB
SCO DMAC
SCO DEV_B
IRQ
MBR F/F
O.C.
DATO PRONTO
MBG
I/O CB
STATUS F/F
4
Interfaccia DEV_A
CPU
IRQ
I/O AB
I/O DB
I/O CB
IRQ
START
IORD
CLEAR
IACKIN
IVN
Dec
SELECT
OR
REG
COMPLETE
SCA
SCO
STARTDEV
IACKOUT
5
org 400h INIZIO PROGRAMMA dev_a equ 0h
indirizzo device A dev_b equ 1h indirizzo
device B dmac equ 2h indirizzo
dmac CAR equ 3h indirizzo dmac WC
equ 4h indirizzo dmac risultato equ
0BBBh indirizzo byte riservato
alluscita buffer_lavoro equ 000Ah indirizzo 6
byte riservato alla logica del programma code j
sr init seti abilita PD32 ad accettare
interruzioni main ... jmp main init outl
2048, WC outl ABCDh, CAR start dmac ret
6
DRIVER DMAC driver 0, 600h push r0 salva
contenuto dei registri sporcati nella
routine clear dmac elimino la causa
dellinterruzione sul dmac movl ABCDh,
buffer_lavoro movl buffer_lavoro, r0 addl 4,
r0 movw 0, (r0) start dev_a pop r0 rti
7
DRIVER dev_A driver 1, 700h push r0, r1, r2,
r3 salva contenuto dei registri sporcati nella
routine inb dev_A, r0 acquisisco il dato dalla
periferica dev_A movl buffer_lavoro,
r1 acquisisco lindirizzo corrente per il
controllo cmpb (r1), ro r0- valore
corrispondente in memoria JNZ set_flag aggiorna
addl 1, r1 movl r1, buffer_lavoro aggiorno
lindirizzo che punterà al prossimo dato da
controllare movl buffer_lavoro, r2 addl 4,
r2 movw (r2), r3 sposto in r3 il valore del
contatore addw 1,r3 aggiorno il
contatore cmpw 2048, r3 jz interrompi_esecuzion
e start dev_A jmp fine set_flag movb 1,
0BBBh jmp aggiorna interrompi_esecuzione clear
dev_A fine pop r3, r2, r1, r0 RTI
Write a Comment
User Comments (0)
About PowerShow.com