## Lucas Bezerra Storino

Descrição de cada período de clock para executar a instrução ADD ax, bx contida no endereço de memória 0x0053.

Busca e incremento de IP:

- RE ← PC, T1 ← IP(L) [Conteúdo de IP (0x0053) é depositado no registrador de endereço, ao mesmo tempo, por se tratarem de barramentos diferentes, passamos o conteúdo menos significativo de IP no registrador T1 para podermos fazer o incremento de IP]
- 2. IP(L) ← ULA, FC ← COUT [Com UC nos dando o comando de incremento de T1 para a ULA (comando 0b0110), a soma da parte menos significativa de IP é realizada e depositada no registrador. COUT é guardado como flag para que podemos verificar se ocorreu um carry out na soma e assim propagar para a parte mais significativa de IP]
- 3. T1 ← IP(H)
- **4. IP(H)** ← **ULA** [Caso FC == 1, então o comando que UC deve dar para ULA será o de incremento (comando 0b0110), caso contrário, o comando será o de dar T1 como resultado, sem alterar o valor (comando 0b0011)]
- 5. IR ← RD [A instrução contida na memória chega no registrador de instrução para assim ser decodificada dado seu OPCODE pela UC]

Execução da instrução ADD ax, bx:

- 6. T1 ← A
- 7. T2 ← B
- 8. A  $\leftarrow$  ULA, FC  $\leftarrow$  COUT