

Scuola Politecnica e delle Scienze di Base Corso di Laurea Magistrale in Ingegneria Informatica

## ELABORATO CSD

Anno Accademico 2022/2023

Candidato
PAOLO RUSSO
matr.M63001426

# Contents

| 1 | Spe  | ecifiche di Progetto                                      | 1  |
|---|------|-----------------------------------------------------------|----|
| 2 | Solu | uzione                                                    | 5  |
|   | 2.1  | Architettura complessiva                                  | 6  |
|   |      | 2.1.1 Collegamento Pia                                    | 6  |
|   | 2.2  | Protocolli                                                | 7  |
|   | 2.3  | Mappa della memoria                                       | 8  |
|   | 2.4  | Descrizione di alto livello delle condizioni di funziona- |    |
|   |      | mento                                                     | 9  |
|   | 2.5  | Descrizione alto livello                                  | 10 |
|   |      | 2.5.1 PSEUDO_CODICE IRQB NODO A                           | 10 |
|   |      | 2.5.2 PSEUDO_CODICE IRQC NODO A                           | 11 |
|   | 2.6  | Implementazione Assembly nodo A                           | 11 |
|   | 2.7  | Risultati Simulazione                                     | 18 |
|   | 2.8  | Risposta Aggiuntiva PIC                                   | 19 |
|   |      | 2.8.1 Architettura nodo A con PIC                         | 19 |
|   |      | 2.8.2 Possibili Approcci                                  | 19 |
|   | 2.9  | Risposta Aggiuntiva DMA                                   | 20 |
|   |      | 2.9.1 Architettura nodo A con DMA                         | 20 |

|       |                    |      | CONTE | NTS |
|-------|--------------------|------|-------|-----|
|       |                    |      |       |     |
| 2.9.2 | Possibili Approcci | <br> | <br>  | 20  |

# Chapter 1

# Specifiche di Progetto

Un sistema è composto da 3 unità, A, B e C, tra loro collegate mediante due periferiche parallele che interconnettono A con B e A con C rispettivamente. Il sistema opera effettuando K iterazioni (con K > 2 a scelta dello studente), in ciascuna delle quali A deve ricevere globalmente 2 messaggi di N caratteri da B e 1 messaggio di N caratteri da C (con N > 2 a scelta dello studente). I messaggi da B e da C possono essere ricevuti in un ordine qualsiasi ma non deve essere mai possibile ricevere caratteri appartenenti a messaggi diversi intervallati tra di loro. In altre parole, detto  $msgB_i$  un generico messaggio completo ricevuto da B e  $msgC_j$  un generico messaggio completo ricevuto da C, in ogni iterazione si possono avere le seguenti situazioni:

- $< msgB_1 msgB_2 msgC_1 > (s1)$
- $< msgC_1 msgB_1 msgB_2 > (s2)$
- $< msgB_1 msgC_1 msgB_2 > (s3)$

Esempio: Un esempio con K=3; N=3 di funzionamento del sistema è il seguente:

- Iter1:  $msgB_1(1)msgB_1(2)msgB_1(3)$   $msgC_1(1)msgC_1(2)msgC_1(3)$  $msgB_2(1)msgB_2(2)msgB_2(3)$  (s3)
- $Iter 2: msgC_1(1)msgC_1(2)msgC_1(3) msgB_1(1)msgB_1(2)msgB_1(3)$  $msgB_2(1)msgB_2(2)msgB_2(3) \ (s2)$
- $Iter 3: msgC_1(1)msgC_1(2)msgC_1(3) msgB_1(1)msgB_1(2)msgB_1(3)$  $msgB_2(1)msgB_2(2)msgB_2(3) \ (s2)$

Si progetti e implementi l'unità A specificando:

- 1. Architettura complessiva: rappresentazione grafica schematica dell'architettura complessiva del sistema, in termini dei componenti di ciascuna unità (CPU, memoria, bus, dispositivi) e delle relative interconnessioni, in cui siano evidenziati i principali collegamenti e le linee di interruzione previste.
- 2. Protocolli: diagrammi temporali che rappresentino i principali protocolli di comunicazione utilizzati fra i dispositivi (ad es. i protocolli utilizzati per la scrittura e/o la lettura su/da periferica parallela).
- 3. Mappa della memoria: rappresentazione grafica schematica del contenuto della memoria RAM e ROM con riferimento alle aree

dati e codice del programma implementato e al vettore delle eccezioni (solo per la specifica unità richiesta).

- 4. Descrizione di alto livello delle condizioni di funzionamento considerate e dei meccanismi usati per garantire lo svolgimento della logica prevista dall'esercizio (es. è stato usato un flag che....); descrizione di alto livello dei problemi ravvisati di conflitto sui dati e/o di gestione di possibili "sovrapposizioni" di messaggi dovute alla diversa velocità di elaborazione dei dispositivi coinvolti) e delle principali soluzioni scelte (es. mutua esclusione con istruzione TAS, disattivazione selettiva interruzioni periferiche, ecc.).
- 5. Descrizione di alto livello del programma implementato: descrizione, mediante diagramma a blocchi o pseudocodice o automa, dei principali passi effettuati in ciascuno dei moduli software che compongono il programma (si richiede cioè un diagramma separato per il "main" e per ciascuna ISR prevista).
- 6. Implementazione: codice Assembly Motorola 68000 per il sistema progettato. Gli studenti sono invitati a inserire commenti nel codice almeno nelle parti salienti (ad esempio, nella configurazione delle periferiche e nell'utilizzo di variabili globali) per favorire una migliore leggibilità e comprensione dell'elaborato.

Dopo aver sviluppato l'intero progetto, si illustri come cambiereb-

bero l'architettura complessiva e la logica del driver se venisse inserito un PIC. Opzionalmente, si discuta cosa accade inserendo un DMA (lo studente scelga la configurazione più opportuna) specificando le eventuali modifiche necessarie alla logica del programma.

Nota: per rispondere alla domanda su PIC/DMA non è richiesta l'implementazione completa di un nuovo programma, ma lo studente dovrà indicare schematicamente le principali modifiche necessarie al codice assembly già prodotto (è preferibile a tale scopo indicare a parte gli stralci di codice da inserire ove necessario).

# Chapter 2

# Soluzione

Andiamo a svolgere tutti i punti necessari, che partano dalla scelta del modello di programmazione, i protocolli delle rispettive periferiche in questo caso la PIA,la mappatura della memoria RAM e ROM con riferimento alle aree dati e codice del programma implementato e al vettore delle eccezioni fino ad arrivare allo sviluppo software.

## 2.1 Architettura complessiva



#### 2.1.1 Collegamento Pia



Per quanto riguarda le PIA, quella del SistemaA è configurata in ricezione sul porto A, mentre la PIA del SistemaB è configurata in

trasmissione sul porto B. IL protocollo di comunicazione, tra le due PIA, funziona nel seguente modo :

- In uscita dal porto B della PIA del SistemaB abbiamo il segnale CB2, che va in entrata al segnale CA1, che comunica l'interruzione al SistemaA;
- In uscita dal porto A della PIA del SistemaA abbiamo il segnale CA2, che va in entrata al segnale CB1, che comunica l'interruzione al SistemaB.

#### 2.2 Protocolli

Nella figura viene rappresentata la comunicazione tra le due PIA: nel momento in cui il porto B della PIA comincia la trasmissione abbassa CB2, che a sua volta è collegato al segnale CA1. Quando quest'ultimo si abbassa, si alza CRA7 ( bit collegato all'interruzione del Porto A ), scatenando di conseguenza l'alzarsi del segnale IRQA, CA2 e CB1. Nel momento in cui l'ISR effettua la lettura, invece ,si abbassano i segnali IRQA, CA2 e CB1, causando l'alzarsi del segnale CRB7, il quale si abbasserà soltanto con una lettura fittizia.



### 2.3 Mappa della memoria

• Mappatura PIA\_C

| PIABD_C | \$2004 |
|---------|--------|
| PIABC_C | \$2005 |

• Mappatura PIA\_D

| PIABD_B | \$2008 |
|---------|--------|
| PIABC_B | \$2009 |

• Mappatura vettore delle eccezioni

La modalità di riconoscimeto dell'interruzione utilizzata è quella autovettorizata, dove il dispositivo che interrompe richiede una gestione automatica dell'interruzioni. Per calcolare l'indirizzo, dunque, dobbiamo fare~(24+IPL)\*4.

| IRQB | \$6C |
|------|------|
| IRQC | \$70 |

• Mappatura aree dati e codice del programma

| AREA DATI | \$8000 |
|-----------|--------|
| AREA MAIN | \$8300 |
| IRQ_B     | \$8700 |
| IRQ_C     | \$8900 |

# 2.4 Descrizione di alto livello delle condizioni di funzionamento

1. La PIA\_B ha gia ricevuto un messaggio intero e due caratteri del secondo messaggio. Arriva l'interruzione di C che entra nell'area critica. Poi, arriva l'interruzione di B che provando ad entrare nell'area critica si sospende. C capisce che non è il suo turno e si sospende e poi risveglia B che finisce di leggere l'intero messaggio fa le sue operazioni e poi riveglia C.

2. La PIA\_C ha gia ricevuto due caratteri del messaggio arriva l'interruzione di C che entra nell'area critica, esce e sta per fare Rx\_C.Arriva l'interruzione di B che entra nell'area critica ma capisce che non è il suo turno e si sospende C completa il messaggio, fa le sue operazioni e risveglia B.

B: #.....B

C: C C C C C

3. C ha gia letto il suo messaggio arriva un'interruzione di C che capisce che non è ancora il suo turno e si sospende.

B:

C: C1 C1 C1 C1 SOS\_C

#### 2.5 Descrizione alto livello

#### 2.5.1 PSEUDO\_CODICE IRQB NODO A

```
IRQ B{
    tas(LOCK):
        if[(possesso è di B or possesso di nessuno) and FLAG_B == 0]:
            assegno il possesso a B
            LOCK= 0
            Rx_B
            incremento contatore caratteri ricevuti di B
            if(ho ricevuto N caratteri):
                azzero il contatore dei caratteri ricevuti di B
                incremento contatore messaggi ricevuti di B
                if(ho ricevuto 2 messaggi):
                    azzero il contatore dei caratteri ricevuti di B
                    alzo FLG B per segnalare l'avvenuta letttura del secondo messaggio
                    imposto possesso a 0
                    if(FLG_C è alto):
                        incremento il contatore delle iterazioni K
                        if(ho effettuato k iterazioni):
                            disabilito le periferiche
                        else:
                            azzero FLG B
                            azzero FLG_C
                            if(C è sospeso):
                                risveglio C
                    else:
                        if(C è sospeso):
                            risveglio C
                else:
                    imposto possesso a 0
                    if(C è sospeso):
                        risveglio C
            else:
                fine_b
        else:
            LOCK=0
            sospendi B
    else:
        sospendo B
    fine_B
}
```

#### 2.5.2 PSEUDO\_CODICE IRQC NODO A

```
IRQ_C{
    tas(LOCK):
        if[(posesso è di C o possesso non è assegnato) and FLAG_C == 0]:
            imposto il possesso a C
            LOCK=0
            Rx_C
            incremento il contatore die caratteri ricevuti di c
            if(ho ricevuto N caratteri):
                azzero il contatore dei caratteri ricevuti di C
                alzo il FLG_C per segnalare la lettura dell'intero messaggio
                if(FLG_B è alto):
                    incremento il contatore delle interazioni k
                    if(ho effettuato k iterazioni):
                        disabilitop le periferiche
                    else:
                        azzero FLG C
                        azzero FLB B
                        imposto possesso a 0
                        if(B è sospeso):
                            risveglio B
                else:
                    imposto il possesso a 0
                    if(B è sospeso):
                        risveglio B
            else:
                fine_c
        else:
            sospendo C
            LOCK=0
            if(B è sospeso):
                risveglio B
    else:
        sospendo C
        if(B è sospeso):
            risveglio B
    fine_C
}
```

#### 2.6 Implementazione Assembly nodo A

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

```
PIABD_C
                                      EQU
                                                                          $2004
                                                                                                                  ; indirizzo di PIA-B dato per il nodo b
PIABC C
                                      EQU
                                                                            $2005
                                                                                                                   ; indirizzo di PIA-B stato/controllo per il nodo b
PIABD_B
                                      EQU
                                                                            $2008
                                                                                                                   ; indirizzo di PIA-B dato per il nodo c
PIABC B
                                                                            $2009
                                                                                                                   ; indirizzo di PIA-B stato/controllo per il nodo c
                                      EQU
N CAR
                                                         EQU
                                                                                               5
                                                                                               $8000
                                                         ORG
Ν
                                                         DC.B
                                                                                               5
                                                                                                                   ;\ numero\ di\ caratteri\ dei\ messaggi
мв
                                                         \mathrm{DC}.\,\mathrm{B}
                                                                                                                   ; numero di messaggi di b
K
                                                         DC.B
                                                                                                                   ; numero di iterazioni
CONT K
                                      DC.B
                                                                                               ; contatore delle iterazioni
MSG B
                                      DS.B
                                                                           N CAR
                                                                                               ;\ messaggio\ di\ b\ (di\ volta\ in\ volta\ velta\ velta
MSG_C
                                      \mathrm{DS.B}
                                                                            N_{CAR}
                                                                                               ; messaggio\ di\ c\ (di\ volta\ in\ volta\ velta velta)
CONT_C_B
                                                         DC.B
                                                                                                                   ; \ contatore \ caratteri \ ricevuti \ da \ b
                                                                                                                   ; contatore caratteri ricevuti da c
CONT C C
                                                         DC.B
CONT M B
                                                         DC.B
                                                                                                                   ; contatore messaggi ricevuti da b
FLG B
                                                         DC B
                                                                                               0
                                                                                                                   ; flag che indica se ho ricevuto 2 messaggi interi da b
FLG_C
                                                         \mathrm{DC}.\,\mathrm{B}
                                                                                                                   ; flag che indica se ho ricevuto un intero messaggio da c
LOCK
                                                         \mathrm{DC}.\,\mathrm{B}
                                                                                                                   ; variabile per l'uso del TAS
POS
                                                         DC.B
                                                                                                                   ; POS = 0 indica nessun possesso, POS = 1 indica possesso di b,
SOS B
                                                         DC B
                                                                                               0
                                                                                                                  ; SOS\_B = 1 \ indica \ che [b+FFFBbspeso]
                                                                                                                  ; SOS\_C = 1 indica che[@+FFFBbspeso
SOS_C
                                                         \mathrm{DC}\,.\,\mathrm{B}
                                                                                               0
 ORG
                                                                                               $8300
MAIN
                                                         _{
m JSR}
                                                                                               INITB PIAB
                                                                                                                                     ; inizializza PIA porto B di b
                                                         JSR.
                                                                                               INITC_PIAB
                                                                                                                                     ; inizializza PIA porto B di c
                                                          *MOVE.W SR, D0
                                                                                                                                      ; legge il registro di stato
                                                         ANDI #$00FF, SR
                                                                                                                                     ; maschera per reg stato (stato utente, int abilitati)
                                                         *MOVE.W D0,SR
                                                                                                                                     ; pone liv int a 000
LOOP
                                                                                              LOOP
                                                         .TMP
INITB PIAB
                                                        MOVE.B #$00, PIABC B
                                                        MOVE.B #$00,PIABD_B
                                                        \textbf{MOVE}.\, \textbf{B} \quad \#\%11100101, \textbf{PIABC\_B}
                                                        MOVE. B
                                                                                              PIABD B, D0
```

RTS

```
INITC_PIAB
                        MOVE.B #$00,PIABC_C
                        MOVE.B #$00, PIABD C
                        MOVE. B #%11100101,PIABC C
                        MOVE. B
                                        PIABD_C, D0
                        RTS
*La\ pia-B\ ha\ ricevuto\ un\ carattere\ dalla\ pia-A\ partner,\ interrompe\ il\ processore\ che
*con\ la\ ISR\ riceve\ il\ carattere\ e\ lo\ salva\ in\ memoria
*ISR~a~\$8700~associata~all~'~interrupt~di~liv~.~3~~\#vect~27~~mappato~a~\$6C~della~ROM
                        ORG
                                         $8700
IRQ_B
                        IF_B_1
                        TAS
                                         LOCK
                        BNE
                                         ELSE B 1
                        MOVE.B POS, D0
                        CMP.B
                                         #1,D0
IF\_B\_2
                                         SKIPB
                        BEQ
                        CMP. B
                                         #0,D0
                        BNE
                                         ELSE_B_2
                        MOVE.B FLG_B, D0
                        CMP.B
                                         \#0,D0
                        BNE
                                         ELSE_B_2
SKIPB
                        MOVE.B #1,POS
                        MOVE. B #0,LOCK
RX\_B
                        \mathbf{M\!O\!V\!E\!A}.\ L\ \#\mathrm{PIABD}\_\mathrm{B}\,, A0
                        \mathbf{M\!O\!V\!E\!A}.\,L\ \#\!\mathrm{MSG}_B,A1
                        \mathbf{M\!O\!V\!E}.\, \mathbf{B} \quad \mathbf{CONT\_C\_B}, \mathbf{D0}
                        \mathbf{M\!O\!V\!E}.\,B\quad \, (\,A0\,)\,\,,(\,A1\,,D0\,)
                        ADD. B
                                         #1,D0
                        \mathbf{M\!O\!V\!E}.\, \mathbf{B} \quad \, \mathbf{D0}\,, \mathbf{CO\!NT}\_\mathbf{C}\_\mathbf{B}
                        MOVE.B N, D1
IF_B_3
                        CMP
                                         D0, D1
                                         FINE B
```

MOVE.B #0,CONT\_C\_B

```
\mathbf{MOVE}.\,\mathrm{B}\quad\mathrm{CONT\_M\_B},\mathrm{D0}
                             ADD. B #1,D0
                             MOVE. B D0, CONT_M_B
                             MOVE.B M B, D1
                             CMP D0, D1
IF_B_4
                             BNE
                                               ELSE B 4
                             \mathbf{MOVE}.\,\mathbf{B} \quad \#0\,,\! \mathbf{CONT}_{\mathbf{M}}\mathbf{B}
                             MOVE.B #1,FLG_B
                             MOVE.B #0,POS
                             MOVE.B FLG_C, D0
                             CMP.B
IF\_B\_5
                                      \#1,\! D0
                             BNE
                                                RISVEGLIO_C
                             MOVE. B CONT_K, D0
                             ADD. B #1,D0
                             MOVE.B D0, CONT K
                             MOVE.B K, D1
IF_B_6
                             CMP.B
                                                D0, D1
                                               ELSE_B_6
                             BNE
                             MOVE.B #0,PIABC B
                             MOVE.B #0,PIABC_C
                             BRA
                                               FINE_B
{\tt ELSE\_B\_2}
                             \mathbf{MOVE}.\,\mathrm{B} \quad \#0\,\mathrm{,LOCK}
{\tt ELSE\_B\_1}
                             MOVE.B #1,SOS_B
                             BRA FINE_B
                             MOVE.B #0,POS
ELSE_B_4
                             BRA RISVEGLIO_C
                             MOVE.B #0,FLG B
ELSE_B_6
                             MOVE.B #0,FLG_C
RISVEGLIO C
                             MOVE.B SOS C, D0
IF_B_7
                             CMP.B
                                       #1,D0
                             BNE
                                                FINE_B
                             \mathbf{MOVE}.\,\mathrm{B} \quad \#2\,\mathrm{,POS}
                             \mathbf{MOVE}.\,\mathrm{B} \quad \#0\,\mathrm{,SOS\_C}
                             \mathbf{M\!O\!V\!E}.\,\mathrm{B}\quad\mathrm{CONT}_{}\mathrm{C}_{}\mathrm{C},\mathrm{D}0
                             MOVEA. L #PIABD_C, A0
                             \mathbf{M\!O\!V\!E}.\, B \quad \left(\,A0\,\right)\,, \left(\,A1\,, D0\,\right)
                             ADD.B
                                        \#1,D0
                             MOVE.B D0,CONT C C
FINE B
                  MOVEM. L (A7)+,A1-A0/D1-D0
                             RTE
```

```
*La\ pia-B\ ha\ ricevuto\ un\ carattere\ dalla\ pia-A\ partner\ ,\ interrompe\ il\ processore\ che
*con la ISR riceve il carattere e lo salva in memoria
*ISR a $8800 associata all' interrupt di liv. 4 mappato a $70 della ROM
ORG
                                            $8900
IRQ\_C
                          IF_C_1
                          TAS
                                            LOCK
                          BNE
                                            {\rm ELSE\_C\_2}
                          \mathbf{M\!O\!V\!E}.\,\mathrm{B}\quad\mathrm{FLG}\_\mathrm{C},\mathrm{D}0
                          CMP. B
                                            \#0,D0
                          BNE
                                            {\rm ELSE\_C\_2}
                          MOVE.B POS, D0
                          CMP.B
                                            #2,D0
                                           SKIPC
                          BEQ
_{\rm IF\_C\_2}
                          CMP.B
                                            #0,D0
                          BNE
                                            {\rm ELSE\_C\_2}
                          MOVE.B #2,POS
SKIPC
                          MOVE.B #0,LOCK
RX_C
                          \mathbf{M\!O\!V\!E\!A}.\,L\ \#\mathrm{PIABD\_C}\,,\mathrm{A0}
                          \mathbf{M\!O\!V\!E\!A}.\ L\ \#\!\mathrm{MSG\_C}, A1
                          \label{eq:move.b} \textbf{MOVE}.\, \textbf{B} \quad \textbf{CONT\_C\_C}, \textbf{D0}
                          MOVE. B (A0), (A1, D0)
                          ADD.B
                                  #1,D0
                          MOVE. B D0, CONT_C_C
                          MOVE.B N, D1
IF_C_3
                          CMP.B
                                           D0, D1
                          BNE
                                           FINE C
                          MOVE.B #0,CONT C C
                          MOVE.B #1,FLG_C
                          \mathbf{MOVE}.\,\mathrm{B}\quad\mathrm{FLG}_{-}\mathrm{B},\mathrm{D0}
_{\rm IF\_C\_4}
                          CMP.B
                                          \#1,D0
                                          ELSE_C_4
                          \mathbf{M\!O\!V\!E}.\,\mathrm{B}\quad\mathrm{CONT}_{}\mathrm{K},\mathrm{D}0
                          ADD. B
                                            #1,D0
                          MOVE. B D0, CONT_K
                          MOVE.B K, D1
IF C 5
                          CMP. B
                                            D0, D1
                                           ELSE C 5
```

MOVE.B #0,PIABC\_C

 $\mathbf{M\!O\!V\!E}.\,\mathrm{B} \quad \#0\,\mathrm{,PIABC\_B}$ BRA FINE\_C ELSE C 2 MOVE.B #1,SOS C MOVE. B #0,LOCK RIS\_B\_TOTALE MOVE.B SOS\_B, D0 **CMP**. B #1,D0  ${\rm FINE\_C}$ BNE MOVE.B #1,POS  $\mathbf{MOVE}.\,\mathrm{B} \quad \#0\,,\!\mathrm{SOS\_B}$  $\mathbf{M\!O\!V\!E}.\,\mathrm{B}\quad\mathrm{CONT}_{-}\mathrm{C}_{-}\mathrm{B},\mathrm{D}0$  $\mathbf{M\!O\!V\!E}.\,\mathrm{B}\quad\mathrm{CONT}\_\mathrm{C}\_\mathrm{B},\mathrm{D}1$ **ADD**. B #1,D1 MOVE.B D1,CONT\_C\_B MOVE.B N, D2  $IF_C_6$ CMP.B D1,D2 BNE  $ELSE\_C\_6$ MOVE.B #0,CONT\_C\_B  $\mathbf{M\!O\!V\!E}.\, \mathbf{B} \quad \mathbf{CONT} \ \mathbf{M} \ \mathbf{B}, \mathbf{D2}$ **ADD**. B #1,D2 MOVE.B D2,CONT M B **MOVE**. B M\_B, D1  $_{\rm IF\_C\_7}$  $\mathbf{C\!M\!P}.\,\mathrm{B} \qquad \qquad \mathrm{D1}\,,\mathrm{D2}$ BNE  $ELSE_C_8$ MOVE.B #1,FLG B MOVE. B #0,CONT\_M\_B MOVE.B #0,POS MOVE. B FLG\_C, D1 **CMP**. B #1,D1 **BNE** ELSE\_C\_8 IF\_C\_8 MOVE.B CONT K, D1 **ADD**. B #1,D1 MOVE. B D1, CONT\_K MOVE.B K, D2  $\begin{array}{ll} \textbf{CMP}. \textbf{B} & \quad \textbf{D1}\,, \textbf{D2} \\ \\ \textbf{BNE} & \quad \textbf{ELSE\_C\_9} \\ \end{array}$  $IF_C_9$ MOVEA. L #PIABD\_B, A0 MOVEA. L #MSG\_B, A1 **MOVE**. B (A0), (A1, D0) MOVE.B #0,PIABC C MOVE.B #0,PIABC B

BRA

FINE C

 $ELSE\_C\_9$  $\mathbf{MOVE}.\,\mathrm{B} \quad \#0\,\mathrm{,FLG\_B}$ MOVE.B #0,FLG\_C ELSE\_C\_8 MOVE.B #2,POS MOVEA. L #PIABD\_B, A0 MOVEA. L #MSG\_B, A1 **MOVE**. B (A0), (A1, D0) JMP RX\_C  ${\tt ELSE\_C\_6}$  $\mathbf{M\!O\!V\!E\!A}.\ L\ \#\mathrm{PIABD}\_\mathrm{B}\,, \mathrm{A0}$  $\mathbf{M\!O\!V\!E\!A}.\,L\ \#\!\mathrm{MSG}_{-}\mathrm{B},\mathrm{A}1$  $\mathbf{M\!O\!V\!E}.\,B\quad \, (\,A0\,)\,\,,(\,A1\,,D0\,)$ BRA FINE\_C ELSE\_C\_4 MOVE.B #0,POS BRA RIS\_B MOVE.B #0,FLG\_C  $ELSE_C_5$ MOVE.B #0,FLG B MOVE.B #0,POS  $RIS_B$  $\mathbf{MOVE}.\,\mathrm{B}\quad\mathrm{SOS}_{-}\mathrm{B}\,,\mathrm{D0}$  $\mathbf{CMP}.\,\mathrm{B} \qquad \qquad \#1,\!\mathrm{D}0$ BNE  $FINE_C$  $\mathbf{MOVE}.\,\mathrm{B} \quad \#1\mathrm{,POS}$ MOVE.B #0,SOS B MOVE.B CONT\_C\_B, D0  $\mathbf{M\!O\!V\!E}.\,\mathrm{B}\quad\mathrm{CONT}\_\mathrm{C}\_\mathrm{B},\mathrm{D}1$ ADD.B #1,D1MOVE.B D1,CONT\_C\_B

 ${\rm FINE\_C}$ 

END MAIN

$$\label{eq:moveal} \begin{split} & \textbf{MOVEA}. \ L \ \ \#PIABD\_B \, , A0 \\ & \textbf{MOVEA}. \ L \ \ \#MSG\_B \, , A1 \\ & \textbf{MOVE}. \ B \quad \ \ (A0) \, , (A1 \, , D0) \end{split}$$

 $\label{eq:movem.L} \begin{array}{ccc} \textbf{MOVEM.} \ L & (A7)+, A1-A0/D2-D0 \\ \\ \textbf{RTE} \end{array}$ 

#### 2.7 Risultati Simulazione



Testando i tre casi, il sistema si è dimostrato robusto, e non ha generato alcun tipo di deadlock, proseguendo l'esecuzione attesa.



## 2.8 Risposta Aggiuntiva PIC

#### 2.8.1 Architettura nodo A con PIC



#### 2.8.2 Possibili Approcci

Il Pic in questo caso, non migliora significativamente la gestione delle due ISR, in quanto devono alternarsi, introdurre il Round Robin, rende il tutto più complicato pertanto l'unica possibilità, è giocare con la maschera delle interruzioni, in modo che, quando C invia il proprio messaggio, non possa essere interrotto.

## 2.9 Risposta Aggiuntiva DMA

#### 2.9.1 Architettura nodo A con DMA



#### 2.9.2 Possibili Approcci

Potrei optare tre eventuali soluzioni.

- 1. Uso i canali in maniera mutuamente esclusiva, in cui ogni volta che inizia B, disabilito C e viceversa.
- 2. Imponendo un ordine,posso abilitare B dopo aver terminato lo disabilito, e applico lo stesso meccanismo con C.
- 3. Se non faccio nessuna ipotesi, non posso usare il DMA,poichè i caratteri arriveranno in maniera casuale.