## **CORRECTION EXERCICE - CONTRÔLE FINAL**

## 1. Couche ISA

• Traduction assembleur/hexadécimal

| Instruction Pascal | Assembleur (1,5 pt)     | sembleur (1,5 pt) Hexadécimal (1,25 pt) |  |
|--------------------|-------------------------|-----------------------------------------|--|
| Z := X - (Y + 3)   | I <sub>1</sub> LD@ Y    | I <sub>1</sub> A30082h                  |  |
|                    | I <sub>2</sub>   ADD# 3 | I <sub>2</sub> E103h                    |  |
|                    | $I_3$ ST@ Z             | $I_3$ A40082h                           |  |
|                    | I <sub>4</sub> LD@ X    | I <sub>4</sub> A30080h                  |  |
|                    | I <sub>5</sub> SUB@ Z   | I <sub>5</sub> E20082h                  |  |
|                    | $I_6 \mid ST@ Z$        | I <sub>6</sub> A40082h                  |  |

• Adresses des instructions en mémoire (1,75 pt)

| $I_1$ | 1000h |
|-------|-------|
| $I_2$ | 1003h |
| $I_3$ | 1005h |
| $I_4$ | 1008h |
| $I_5$ | 100Bh |
| $I_6$ | 100Eh |

• Contenu des registres CO, RI et ACC (3,5 pts)

| Instruction | CO    | RI  | ACC |
|-------------|-------|-----|-----|
| I1          | 1003h | A3h | 45h |
| I2          | 1005h | E1h | 48h |
| I3          | 1008h | A4h | 48h |
| I4          | 100Bh | A3h | CAh |
| I5          | 100Eh | E2h | 82h |
| I6          | 1011h | A4h | 82h |

## 2. Couche microarchitecture

T<sub>7</sub>: RA<sub>OUT</sub>; MAR<sub>IN</sub>

T<sub>8</sub>: RD T<sub>9</sub>: WMFC

 $T_{10}$ :  $MDR_{OUT}$ 

T<sub>12</sub>: END

 $T_{11}$ : AD; ACC<sub>IN</sub>

| Cycle de Recherche                                                                             | (1 pt)        | LD# <d></d>                                                                                     | <mark>(1 pt)</mark> |
|------------------------------------------------------------------------------------------------|---------------|-------------------------------------------------------------------------------------------------|---------------------|
| T <sub>0</sub> : CO <sub>OUT</sub> ; MAR <sub>IN</sub>                                         |               | T <sub>0</sub> : CO <sub>OUT</sub> ; MAR <sub>IN</sub>                                          |                     |
| $T_1$ : RD; $CO_{INC}$                                                                         |               | $T_1$ : RD; $CO_{INC}$                                                                          |                     |
| T <sub>2</sub> : WMFC                                                                          |               | T <sub>2</sub> : WMFC                                                                           |                     |
| $T_3$ : $MDR_{OUT}$ ; $RI_{IN}$                                                                |               | $T_3$ : $MDR_{OUT}$ ; $ACC_{IN}$                                                                |                     |
|                                                                                                |               | T <sub>4</sub> : END                                                                            |                     |
| ADD# <d></d>                                                                                   | (1 pt)        | PUSH                                                                                            | (1 pt)              |
| T <sub>0</sub> : CO <sub>OUT</sub> ; MAR <sub>IN</sub>                                         | 1 /           | T <sub>0</sub> : ACC <sub>OUT</sub> ; MDR <sub>IN</sub> ; SP <sub>DEC</sub>                     | (1)                 |
| T <sub>1</sub> : RD; CO <sub>INC</sub> ; ACC <sub>OUT</sub> ; RTUAL <sub>IN</sub>              |               | $T_1$ : $SP_{OUT}$ ; $MAR_{IN}$                                                                 |                     |
| T <sub>2</sub> : WMFC                                                                          |               | $T_2$ : WR                                                                                      |                     |
| T <sub>3</sub> : MDR <sub>OUT</sub>                                                            |               | T <sub>3</sub> : WMFC                                                                           |                     |
| $T_4$ : AD; $ACC_{IN}$                                                                         |               | T <sub>4</sub> : END                                                                            |                     |
| T <sub>5</sub> : END                                                                           |               |                                                                                                 |                     |
| LD@ [adr]                                                                                      | (1 pt)        | ST@ [adr]                                                                                       | (1 pt)              |
| T <sub>0</sub> : CO <sub>OUT</sub> ; MAR <sub>IN</sub>                                         | (1 PV)        | $T_0$ : $CO_{OUT}$ ; $MAR_{IN}$                                                                 | (1 P)               |
| $T_1$ : RD; $CO_{INC}$                                                                         |               | $T_1$ : RD; $CO_{INC}$                                                                          |                     |
| T <sub>2</sub> : WMFC                                                                          |               | $T_2$ : WMFC                                                                                    |                     |
| T <sub>3</sub> : MDR <sub>OUT</sub> ; RL <sub>IN</sub> ; CO <sub>OUT</sub> ; MAR <sub>IN</sub> |               | T <sub>3</sub> : MDR <sub>OUT</sub> ; RL <sub>IN</sub> ; CO <sub>OUT</sub> ; MAR <sub>IN</sub>  |                     |
| T <sub>4</sub> : RD ; CO <sub>INC</sub>                                                        |               | T <sub>4</sub> : RD ; CO <sub>INC</sub>                                                         |                     |
| T <sub>5</sub> : WMFC                                                                          |               | T <sub>5</sub> : WMFC                                                                           |                     |
| T <sub>6</sub> : MDR <sub>OUT</sub> ; RH <sub>IN</sub>                                         |               | T <sub>6</sub> : MDR <sub>OUT</sub> ; RH <sub>IN</sub>                                          |                     |
| T <sub>7</sub> : RA <sub>OUT</sub> ; MAR <sub>IN</sub>                                         |               | T <sub>7</sub> : ACC <sub>OUT</sub> ; MDR <sub>IN</sub> ; RA <sub>OUT</sub> ; MAR <sub>IN</sub> |                     |
| T <sub>8</sub> : RD                                                                            |               | T <sub>8</sub> : WR                                                                             |                     |
| T <sub>9</sub> : WMFC                                                                          |               | T <sub>9</sub> : WMFC                                                                           |                     |
| T <sub>10</sub> : MDR <sub>IN</sub> ; ACC <sub>OUT</sub>                                       |               | T <sub>10</sub> : END                                                                           |                     |
| T <sub>11</sub> : END                                                                          |               | - 100 1                                                                                         |                     |
| ADD@ [adr]                                                                                     | (14)          | POP@ [adr]                                                                                      | (1()                |
|                                                                                                | <u>(1 pt)</u> |                                                                                                 | <u>(1 pt)</u>       |
| T <sub>0</sub> : CO <sub>OUT</sub> ; MAR <sub>IN</sub>                                         |               | $T_0: CO_{OUT} ; MAR_{IN}$                                                                      |                     |
| $T_1$ : RD; $CO_{INC}$ ; $ACC_{OUT}$ ; $RTUAL_{IN}$<br>$T_2$ : WMFC                            |               | $T_1$ : RD; $CO_{INC}$ $T_2$ : WMFC                                                             |                     |
| <del>-</del>                                                                                   |               | _                                                                                               |                     |
| T <sub>3</sub> : MDR <sub>OUT</sub> ; RL <sub>IN</sub> ; CO <sub>OUT</sub> ; MAR <sub>IN</sub> |               | T <sub>3</sub> : MDR <sub>OUT</sub> ; RL <sub>IN</sub> ; CO <sub>OUT</sub> ; MAR <sub>IN</sub>  |                     |
| T <sub>4</sub> : RD ; CO <sub>INC</sub>                                                        |               | T <sub>4</sub> : RD ; CO <sub>INC</sub><br>T <sub>5</sub> : WMFC                                |                     |
| T <sub>5</sub> : WMFC                                                                          |               | -                                                                                               |                     |
| T <sub>6</sub> : MDR <sub>OUT</sub> ; RH <sub>IN</sub>                                         |               | $T_6$ : MDR <sub>OUT</sub> ; RH <sub>IN</sub> ; SP <sub>OUT</sub> ; MAR <sub>IN</sub>           |                     |

T<sub>7</sub>: RD ; SP<sub>INC</sub> T<sub>8</sub>: WMFC

T<sub>10</sub>: WR

T<sub>12</sub>: END

T<sub>11</sub>: WMFC

T<sub>9</sub>: RA<sub>OUT</sub>; MAR<sub>IN</sub>