Nome: Benfenati Domenico

#### Prova CSD 9 Maggio 2022



#### Traccia

Un sistema è composto da tre 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 in due fasi successive, come descritto di seguito:

- Fase 1: inizialmente A riceve da B un messaggio di N caratteri con N non definito inizialmente, il cui primo carattere è proprio uguale ad N. La ricezione da B deve essere gestita con il meccanismo delle interruzioni. In questa fase si assume che C non possa interrompere A.
- Fase 2: successivamente dopo aver completato la ricezione del primo messaggio da B, A riceve altri T, con T non noto, messaggi di lunghezza N, ricevendo un carattere da B e uno da C in modo alternato, iniziando da B.

Per la Fase 2 è possibile considerare due diverse ipotesi di funzionamento:

- ipotesi semplificativa: B e C si coordinano esternamente, e B ha una priorità superiore rispetto a C. Vengono prima inviati tutti i messaggi da B e poi tutti i messaggi da C.
- ipotesi standard: non è possibile stabilire a priori l'ordine di arrivo dei caratteri da B e C; A deve gestire in SW l'alternanza.

#### Architettura



# Protocolli



# Mappa della memoria

### Pseudocodice

```
MAIN(){
       inizializza PIA 1;
2
       inizializza PIA 2;
3
       Enable stato utente;
4
       Enable interruzioni;
5
       while(true);
                                 //attendo l'interruzione di uno dei due sistemi
6
   }
   ISR_B(){
       if(fase1){
10
           ricevi Carattere da PIA1;
11
            if (primo = true){
12
                salva N;
13
                primo = false;
                                   //primo verifica che sia il primo carattere
14
15
           num_car ++ ;
                            //num_car e' una variabile comune che conta i caratteri ricevuti
16
                da B e da C insieme
       }
17
       else{
18
            if (attiva_C = false){
19
                ricevi Carattere da PIA1;
20
                num_car ++ ;
21
                attiva_C = true;
22
                if (num_car == N){
23
                    num_car = 0;
24
                    num_mess ++ ;  //num_mess tiene traccia dei T messaggi ricevuti
25
                    if(num_mess == T){
26
                        disattiva PIA1;
                        disattiva PIA2;
28
29
                    if(CRA7C == 1){
```

```
ricevi Carattere da PIA2;
31
                         num_car ++ ;
32
                     }
33
                }
34
            }
35
        }
36
   }
37
38
   ISR_C(){
39
        if(!fase1){
40
            if(attiva_C = true){
41
                ricevi Carattere da PIA2;
42
                num_car ++ ;
43
                 attiva_C = false;
                 if (num_car == N){
45
                     num_car = 0;
46
                     num_mess ++;
47
                     if(num_mess == T){
48
                         disattiva PIA1;
49
                         disattiva PIA2;
50
                     }
51
                     if(CRA7B == 1){
52
                         ricevi Carattere da PIA1;
53
                         num_car ++ ;
54
                     }
55
                }
56
            }
57
        }
58
   }
59
```

# Programma assembly