

|                                                                       |                                                                                                                     |                         |                    |
|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------|
| <b>P.PORTO</b><br><br>ESCOLA<br>SUPERIOR<br>DE TECNOLOGIA<br>E GESTÃO | Tipo de Prova<br>Teste 2                                                                                            | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                       | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança<br>Informática em Redes de Computadores | Hora<br>14H00           |                    |
|                                                                       | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                               | Duração<br>00:30 horas  |                    |

1. A principal função da ALU é:
  - a) Armazenar dados temporariamente
  - b) Realizar operações aritméticas e lógicas
  - c) Controlar o fluxo de dados entre a ALU e a memória
  - d) Nenhuma das anteriores
  
2. O componente que contém o endereço da próxima instrução a ser executada pelo processador é:
  - a) Instruction Register (IR)
  - b) Program Counter (PC)
  - c) Unidade de Controlo
  - d) Nenhuma das anteriores
  
3. A largura de um barramento é determinada:
  - a) Pela quantidade de memória cache utilizada
  - b) A tecnologia de implementação
  - c) O número de fios no barramento
  - d) Nenhuma das anteriores
  
4. Hierarquia de memória representa:
  - a) A organização dos diferentes níveis de memória num sistema de computação
  - b) A quantidade de memória cache utilizada
  - c) A tecnologia de implementação da memória
  - d) Nenhuma das anteriores
  
5. Num barramento síncrono:
  - a) Todos os eventos ocorrem de forma independente
  - b) Todos os eventos são controlados pelo sinal de relógio
  - c) Os eventos ocorrem apenas quando há uma interrupção
  - d) Nenhuma das anteriores
  
6. A vantagem de um barramento multiplexado é que:
  - a) Requer menos linhas
  - b) Permite operações de armazenamento simultâneas
  - c) Tem um protocolo de comunicação mais simples
  - d) Nenhuma das anteriores

|                                                                                                                                                |                                                                                                                     |                         |                    |
|------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------|
| <br><b>ESCOLA<br/>SUPERIOR<br/>DE TECNOLOGIA<br/>E GESTÃO</b> | Tipo de Prova<br>Teste 2                                                                                            | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                                                                                                | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança<br>Informática em Redes de Computadores | Hora<br>14H00           |                    |
|                                                                                                                                                | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                               | Duração<br>00:30 horas  |                    |

7. A principal função da memória cache é:
- a) Armazenar dados permanentemente
  - b) Aumentar a velocidade de acesso aos dados frequentemente usados pelo processador
  - c) Armazenar dados temporariamente durante a execução de programas
  - d) Nenhuma das anteriores
8. O algoritmo de substituição LRU substitui o bloco:
- a) Que está na cache há mais tempo
  - b) Que menos vezes foi utilizado
  - c) Que não é usado há mais tempo
  - d) Nenhuma das anteriores
9. Numa célula de memória, um erro grave é:
- a) Um defeito que impede a célula de armazenar dados com segurança
  - b) Um evento aleatório não destrutivo que altera o conteúdo da célula
  - c) Um problema de fornecimento de energia
  - d) Nenhuma das anteriores
10. A latência rotacional num disco magnético representa:
- a) O tempo necessário para mover a cabeça de leitura/escrita para a pista correta
  - b) O tempo gasto enquanto os dados não começam a passar debaixo da cabeça de leitura/escrita
  - c) O tempo necessário para ler ou escrever dados
  - d) Nenhuma das anteriores
11. Ache o complemento para um do conteúdo de uma posição de memória (1030H) e guarde o resultado na posição de memória seguinte (1031H).
12. Subtraia o conteúdo de duas posições de memória consecutivas (1040H e 1041H) e guarde o resultado na posição de memória seguinte (1042H), utilizando o par de registos HL como apontador da memória.
13. Elabore um programa que leia o conteúdo de uma posição de memória (1050H) e que guarde nas duas posições de memória seguintes (1051H e 1052H) o complemento para um e o complemento para dois do valor lido.

|                                                                                                                                    |                                                                                                                  |                         |                    |
|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------|
| <br><b>ESCOLA SUPERIOR DE TECNOLOGIA E GESTÃO</b> | Tipo de Prova<br>Teste 2                                                                                         | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                                                                                    | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança Informática em Redes de Computadores | Hora<br>14H00           |                    |
|                                                                                                                                    | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                            | Duração<br>00:30 horas  |                    |
|                                                                                                                                    |                                                                                                                  |                         |                    |

Cotação:

1. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
2. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
3. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
4. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
5. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
6. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
7. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
8. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
9. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
10. Pergunta de escolha múltipla:
  - Resposta correta 1.5 valores, resposta errada -0.5 valor, sem resposta 0 valores
11. 1 valor
12. 2 valores
13. 2 valores

|                                                                                                                                    |                                                                                                                  |                         |                    |
|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------|
| <br><b>ESCOLA SUPERIOR DE TECNOLOGIA E GESTÃO</b> | Tipo de Prova<br>Teste 2                                                                                         | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                                                                                    | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança Informática em Redes de Computadores | Hora<br>14H00           |                    |
|                                                                                                                                    | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                            | Duração<br>00:30 horas  |                    |

## Instruções do microprocessador da INTEL 8085

Nomenclatura:

### LEGENDA

|        |                                                                             |
|--------|-----------------------------------------------------------------------------|
| pr     | Par de registos: HL, BC, DE, SP, PC                                         |
| reg    | Registo: A, B, C, D, E, H, L                                                |
| M      | Posição de memória                                                          |
| addr   | Endereço de 16 bits de uma posição de memória                               |
| x      | O bit do registo de flags é afetado                                         |
| byte   | Constante, ou expressão lógica/aritmética que representa um dado de 8 bits  |
| double | Constante, ou expressão lógica/aritmética que representa um dado de 16 bits |
| []     | Conteúdo do que se encontra dentro de parênteses retos                      |
| [[ ]]  | Conteúdo do conteúdo do que se encontra dentro de parênteses retos          |
| CS     | Flag de carry                                                               |
| label  | Endereço de uma posição de memória                                          |
| port   | Endereço de um dispositivo I/O                                              |

## Grupo de transferência de dados

### INSTRUÇÃO OPERANDOS STATUS DO REGISTO DE OPERAÇÃO REALIZADA

#### FLAGS

|  |  | CS | AC | Z | S | P |
|--|--|----|----|---|---|---|
|--|--|----|----|---|---|---|

|      |      |                                                                            |
|------|------|----------------------------------------------------------------------------|
| LDAX | pr   | [A] ← [[pr]]<br>Load A using implied addressing by BC (pr=B) or DE (pr=D)  |
| STAX | pr   | [[pr]] ← [A]<br>Store A using implied addressing by BC (pr=B) or DE (pr=D) |
| MOV  | r,M  | [r] ← [[HL]]<br>Load any register using implied addressing by HL           |
| MOV  | M,r  | [[HL]] ← [r]<br>Store any register using implied addressing by HL          |
| LDA  | addr | [A] ← [addr]<br>Load A using direct addressing                             |

|                                                                                     |                                                                                                                     |  |                         |                    |
|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--|-------------------------|--------------------|
| <b>P.PORTO</b><br><small>ESCOLA<br/>SUPERIOR<br/>DE TECNOLOGIA<br/>E GESTÃO</small> | Tipo de Prova<br>Teste 2                                                                                            |  | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                                     | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança<br>Informática em Redes de Computadores |  | Hora<br>14H00           |                    |
|                                                                                     | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                               |  | Duração<br>00:30 horas  |                    |
|                                                                                     |                                                                                                                     |  |                         |                    |

|      |           |                                                                                                          |
|------|-----------|----------------------------------------------------------------------------------------------------------|
| STA  | addr      | [addr] $\leftarrow$ [A]<br>Store A using direct addressing                                               |
| LHLD | addr      | [L] $\leftarrow$ [addr] and [H] $\leftarrow$ [addr+1]<br>Load H and L registers using direct addressing  |
| SHLD | addr      | [addr] $\leftarrow$ [L] and [addr+1] $\leftarrow$ [H]<br>Store H and L registers using direct addressing |
| MOV  | r,r       | [r] $\leftarrow$ [r]<br>Move any register to any register                                                |
| XCHG |           | [D] $\leftarrow \rightarrow$ [H] and [E] $\leftarrow \rightarrow$ [L]<br>Exchange DE with HL             |
| SPHL |           | [HL] $\leftarrow$ [SP]<br>Move HL to SP                                                                  |
| LXI  | pr,double | [pr] $\leftarrow$ double<br>Load 16 bits immediate data into BC (pr=B), DE (pr=D), HL (pr=H), SP (pr=SP) |
| MVI  | M,byte    | [[HL]] $\leftarrow$ byte<br>Load 8 bit immediate data into memory location with implied addressing by HL |
| MVI  | r,byte    | [r] $\leftarrow$ byte<br>Load 8 bit immediate data into any register                                     |

### Grupo aritmético, lógico e de rotação

| INSTRUÇÃO | OPERANDO | STATUS DO REGISTO DE |    |   |   |   | OPERAÇÃO REALIZADA                                                                                                                      |  |
|-----------|----------|----------------------|----|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------------|--|
|           |          | FLAGS                |    |   |   |   |                                                                                                                                         |  |
|           |          | CS                   | AC | Z | S | P |                                                                                                                                         |  |
| ADD       | M        | x                    | x  | x | x | x | [A] $\leftarrow$ [A] + [[HL]]<br>Add register A with implied addressing by HL and store the result in register A                        |  |
| ADC       | M        | x                    | x  | x | x | x | [A] $\leftarrow$ [A] + [[HL]] + [CS]<br>Add register A with carry with implied addressing by HL and store the result in register A      |  |
| SUB       | M        | x                    | x  | x | x | x | [A] $\leftarrow$ [A] - [[HL]]<br>Subtract register A with implied addressing by HL and store the result in register A                   |  |
| SBB       | M        | x                    | x  | x | x | x | [A] $\leftarrow$ [A] - [[HL]] - [CS]<br>Subtract register A with carry with implied addressing by HL and store the result in register A |  |
| ANA       | M        | 0                    | 1  | x | x | x | [A] $\leftarrow$ [A] AND [[HL]]<br>AND between register A with implied addressing by HL and store the result in register A              |  |
| XRA       | M        | 0                    | 0  | x | x | x | [A] $\leftarrow$ [A] XOR [[HL]]<br>Exclusive-OR between register A with implied addressing by HL and store the result in register A     |  |
| ORA       | M        | 0                    | 0  | x | x | x | [A] $\leftarrow$ [A] OR [[HL]]<br>OR between register A with implied addressing by HL and store the result in register A                |  |

|                                                                |                                                                                                                     |  |  |  |  |  |  |                         |                    |
|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|-------------------------|--------------------|
| P.PORTO<br><br>ESCOLA<br>SUPERIOR<br>DE TECNOLOGIA<br>E GESTÃO | Tipo de Prova<br>Teste 2                                                                                            |  |  |  |  |  |  | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança<br>Informática em Redes de Computadores |  |  |  |  |  |  | Hora<br>14H00           |                    |
|                                                                | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                               |  |  |  |  |  |  | Duração<br>00:30 horas  |                    |

|     |      |   |   |   |   |   |                         |                                                                                                                                                                                                                                         |  |
|-----|------|---|---|---|---|---|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CMP | M    | x | x | x | x | x | [A] - [[HL]]            | Compare register A with implied addressing by HL<br>If register A < [[HL]] than the carry flag is set (1)<br>If register A = [[HL]] than the zero flag is set (1)<br>If register A > [[HL]] than the carry and zero flags are reset (0) |  |
| INR | M    | x | x | x | x | x | [[HL]] ← [[HL]] + 1     | Increment memory                                                                                                                                                                                                                        |  |
| DCR | M    | x | x | x | x | x | [[HL]] ← [[HL]] - 1     | Decrement memory                                                                                                                                                                                                                        |  |
| ADI | byte | x | x | x | x | x | [A] ← [A] + byte        | Add register A with 8 bit immediate data and store the result in register A                                                                                                                                                             |  |
| ACI | byte | x | x | x | x | x | [A] ← [A] + byte + [CS] | Add register A with 8 bit immediate data with carry and store the result in register A                                                                                                                                                  |  |
| SUI | byte | x | x | x | x | x | [A] ← [A] - byte        | Subtract register A with 8 bit immediate data and store the result in register A                                                                                                                                                        |  |
| SBI | byte | x | x | x | x | x | [A] ← [A] - byte - [CS] | Subtract register A with 8 bit immediate data with carry and store the result in register A                                                                                                                                             |  |
| ANI | byte | 0 | 1 | x | x | x | [A] ← [A] AND byte      | AND between register A with 8 bit immediate data and store the result in register A                                                                                                                                                     |  |
| XRI | byte | 0 | 0 | x | x | x | [A] ← [A] XOR byte      | Exclusive-OR between register A with 8 bit immediate data and store the result in register A                                                                                                                                            |  |
| ORI | byte | 0 | 0 | x | x | x | [A] ← [A] OR byte       | OR between register A with 8 bit immediate data and store the result in register A                                                                                                                                                      |  |
| CPI | byte | x | x | x | x | x | [A] - byte              | Compare register A with 8 bit immediate data<br>If register A < byte than the carry flag is set (1)<br>If register A = byte than the zero flag is set (1)<br>If register A > byte than the carry and zero flags are reset (0)           |  |
| ADD | r    | x | x | x | x | x | [A] ← [A] + [r]         | Add register A with any register and store the result in register A                                                                                                                                                                     |  |
| ADC | r    | x | x | x | x | x | [A] ← [A] + [r] + [CS]  | Add register A with any register with carry and store the result in register A                                                                                                                                                          |  |
| SUB | r    | x | x | x | x | x | [A] ← [A] - [r]         | Subtract register A with any register and store the result in register A                                                                                                                                                                |  |
| SBB | r    | x | x | x | x | x | [A] ← [A] - [r] - [CS]  | Subtract register A with any register with carry and store the result in register A                                                                                                                                                     |  |
| ANA | r    | 0 | 1 | x | x | x | [A] ← [A] AND [r]       | AND between register A with any register and store the result in register A                                                                                                                                                             |  |
| XRA | r    | 0 | 0 | x | x | x | [A] ← [A] XOR [r]       | Exclusive-OR between register A with any register and store the result in register A                                                                                                                                                    |  |

|                                                                                     |                                                                                                                     |  |  |  |  |  |                         |                    |
|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|-------------------------|--------------------|
| <b>P.PORTO</b><br><small>ESCOLA<br/>SUPERIOR<br/>DE TECNOLOGIA<br/>E GESTÃO</small> | Tipo de Prova<br>Teste 2                                                                                            |  |  |  |  |  | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                                     | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança<br>Informática em Redes de Computadores |  |  |  |  |  | Hora<br>14H00           |                    |
|                                                                                     | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                               |  |  |  |  |  | Duração<br>00:30 horas  |                    |
|                                                                                     |                                                                                                                     |  |  |  |  |  |                         |                    |

|     |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                              |
|-----|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ORA | r | 0 | 0 | x | x | x | $[A] \leftarrow [A] \text{ OR } [r]$                                                                                                                                                                                                                                                                                           | OR between register A with any register and store the result in register A                                                                                                                                   |
| CMP | r | x | x | x | x | x | $[A] - [r]$                                                                                                                                                                                                                                                                                                                    | Compare register A with any register<br>If register A < r than the carry flag is set (1)<br>If register A = r than the zero flag is set (1)<br>If register A > r than the carry and zero flags are reset (0) |
| INR | r | x | x | x | x | x | $[r] \leftarrow [r] + 1$                                                                                                                                                                                                                                                                                                       | Increment any register                                                                                                                                                                                       |
| DCR | r | x | x | x | x | x | $[r] \leftarrow [r] - 1$                                                                                                                                                                                                                                                                                                       | Decrement any register                                                                                                                                                                                       |
| CMA |   |   |   |   |   |   | $[A] \leftarrow [\bar{A}]$                                                                                                                                                                                                                                                                                                     | Complement register A                                                                                                                                                                                        |
| DAA |   | x | x | x | x | x | The contents of the accumulator are changed from a binary value to two 4-bit binary coded decimal (BCD) digits.<br>This is the only instruction that uses the auxiliary flag (AC) to perform the binary to BCD conversion, and the conversion procedure is described below.                                                    |                                                                                                                                                                                                              |
|     |   |   |   |   |   |   | If the value of the low-order 4-bits in the accumulator is greater than 9 or if AC flag is set (1), the instruction adds 6 to the low-order four bits.<br>If the value of the high-order 4-bits in the accumulator is greater than 9 or if the Carry flag (CS) is set (1), the instruction adds 6 to the high-order four bits. |                                                                                                                                                                                                              |
| RLC |   | x |   |   |   |   | Each binary bit of the register accumulator is rotated left by one position.<br>Bit D7 is placed in the position of D0 as well as in the Carry flag.<br>The carry flag (CS) is modified according to bit D7.                                                                                                                   |                                                                                                                                                                                                              |
|     |   |   |   |   |   |   |                                                                                                                                                                                                                                            |                                                                                                                                                                                                              |
| RRC |   | x |   |   |   |   | Each binary bit of the register accumulator is rotated right by one position.<br>Bit D0 is placed in the position of D7 as well as in the Carry flag.<br>The carry flag (CS) is modified according to bit D0.                                                                                                                  |                                                                                                                                                                                                              |
|     |   |   |   |   |   |   |                                                                                                                                                                                                                                            |                                                                                                                                                                                                              |
| RAL |   | x |   |   |   |   | Each binary bit of the register accumulator is rotated left by one position through the carry flag.<br>Bit D7 is placed in the carry flag, and the carry flag is placed in the least significant position D0.<br>The carry flag (CS) is modified according to bit D7.                                                          |                                                                                                                                                                                                              |
|     |   |   |   |   |   |   |                                                                                                                                                                                                                                            |                                                                                                                                                                                                              |
| RAR |   | x |   |   |   |   | Each binary bit of the register accumulator is rotated right by one position through the carry flag.                                                                                                                                                                                                                           |                                                                                                                                                                                                              |

|                                                                                     |                                                                                                                     |  |                         |                    |
|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--|-------------------------|--------------------|
| <b>P.PORTO</b><br><small>ESCOLA<br/>SUPERIOR<br/>DE TECNOLOGIA<br/>E GESTÃO</small> | Tipo de Prova<br>Teste 2                                                                                            |  | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                                     | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança<br>Informática em Redes de Computadores |  | Hora<br>14H00           |                    |
|                                                                                     | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                               |  | Duração<br>00:30 horas  |                    |
|                                                                                     |                                                                                                                     |  |                         |                    |

Bit D<sub>0</sub> is placed in the carry flag, and the carry flag is placed in the least significant position D<sub>7</sub>.

The carry flag (CS) is modified according to bit D<sub>0</sub>.



|     |    |   |                                                                                                                                                                            |
|-----|----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DAD | pr | x | [HL] ← [HL] + [pr]<br>Add HL to a register pair BC (pr=B), DE (pr=D), HL (pr=H), SP (pr=SP) and store the result in HL                                                     |
| INX | pr |   | [pr] ← [pr] + 1<br>Increment register pair BC (pr=B), DE (pr=D), HL (pr=H), SP (pr=SP) and store the result in a register pair BC (pr=B), DE (pr=D), HL (pr=H), SP (pr=SP) |
| DCX | pr |   | [pr] ← [pr] - 1<br>Decrement register pair BC (pr=B), DE (pr=D), HL (pr=H), SP (pr=SP) and store the result in a register pair BC (pr=B), DE (pr=D), HL (pr=H), SP (pr=SP) |

## Grupo de controlo e de salto

| INSTRUÇÃO | OPERANDOS | STATUS DO REGISTO DE<br>FLAGS | OPERAÇÃO REALIZADA                                                                                                             |
|-----------|-----------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
|           |           | CS AC Z S P                   |                                                                                                                                |
| JMP       | label     |                               | [PC] ← label<br>Jump to instruction at address label                                                                           |
| PCHL      |           |                               | [PC] ← [HL]<br>Jump to instruction at address contained in HL                                                                  |
| CALL      | label     |                               | [[SP]] ← [PC], [PC] ← label, [SP] ← [SP] - 2<br>Jump to subroutine starting at address label                                   |
| CC        | label     |                               | [[SP]] ← [PC], [PC] ← label, [SP] ← [SP] - 2<br>Jump to subroutine starting at address label if the carry flag (CS) equal to 1 |
| CNC       | label     |                               | [[SP]] ← [PC], [PC] ← label, [SP] ← [SP] - 2<br>Jump to subroutine starting at address label if the carry flag (CS) equal to 0 |
| CZ        | label     |                               | [[SP]] ← [PC], [PC] ← label, [SP] ← [SP] - 2<br>Jump to subroutine starting at address label if the zero flag (Z) equal to 1   |
| CNZ       | label     |                               | [[SP]] ← [PC], [PC] ← label, [SP] ← [SP] - 2<br>Jump to subroutine starting at address label if the zero flag (Z) equal to 0   |
| CP        | label     |                               | [[SP]] ← [PC], [PC] ← label, [SP] ← [SP] - 2<br>Jump to subroutine starting at address label if the sign flag (S) equal to 0   |
| CM        | label     |                               | [[SP]] ← [PC], [PC] ← label, [SP] ← [SP] - 2<br>Jump to subroutine starting at address label if the sign flag (S) equal to 1   |
| CPE       | label     |                               | [[SP]] ← [PC], [PC] ← label, [SP] ← [SP] - 2<br>Jump to subroutine starting at address label if the parity flag (P) equal to 1 |
| CPO       | label     |                               | [[SP]] ← [PC], [PC] ← label, [SP] ← [SP] - 2<br>Jump to subroutine starting at address label if the parity flag (P) equal to 0 |

|                                                                                     |                                                                                                                     |                         |                    |
|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------|
| <b>P.PORTO</b><br><small>ESCOLA<br/>SUPERIOR<br/>DE TECNOLOGIA<br/>E GESTÃO</small> | Tipo de Prova<br>Teste 2                                                                                            | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                                     | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança<br>Informática em Redes de Computadores | Hora<br>14H00           |                    |
|                                                                                     | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                               | Duração<br>00:30 horas  |                    |

|     |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RET |       | $[PC] \leftarrow [[SP]], [SP] \leftarrow [SP] + 2$<br>Return from subroutine                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RC  |       | $[PC] \leftarrow [[SP]], [SP] \leftarrow [SP] + 2$<br>Return from subroutine if the carry flag (CS) equal to 1                                                                                                                                                                                                                                                                                                                                                                                                   |
| RNC |       | $[PC] \leftarrow [[SP]], [SP] \leftarrow [SP] + 2$<br>Return from subroutine if the carry flag (CS) equal to 0                                                                                                                                                                                                                                                                                                                                                                                                   |
| RZ  |       | $[PC] \leftarrow [[SP]], [SP] \leftarrow [SP] + 2$<br>Return from subroutine if the zero flag (Z) equal to 1                                                                                                                                                                                                                                                                                                                                                                                                     |
| RNZ |       | $[PC] \leftarrow [[SP]], [SP] \leftarrow [SP] + 2$<br>Return from subroutine if the zero flag (Z) equal to 0                                                                                                                                                                                                                                                                                                                                                                                                     |
| RM  |       | $[PC] \leftarrow [[SP]], [SP] \leftarrow [SP] + 2$<br>Return from subroutine if the sign flag (S) equal to 0                                                                                                                                                                                                                                                                                                                                                                                                     |
| RP  |       | $[PC] \leftarrow [[SP]], [SP] \leftarrow [SP] + 2$<br>Return from subroutine if the sign flag (S) equal to 1                                                                                                                                                                                                                                                                                                                                                                                                     |
| RPE |       | $[PC] \leftarrow [[SP]], [SP] \leftarrow [SP] + 2$<br>Return from subroutine if the parity flag (P) equal to 1                                                                                                                                                                                                                                                                                                                                                                                                   |
| RPO |       | $[PC] \leftarrow [[SP]], [SP] \leftarrow [SP] + 2$<br>Return from subroutine if the parity flag (P) equal to 0                                                                                                                                                                                                                                                                                                                                                                                                   |
| JC  | label | $[PC] \leftarrow \text{label}$<br>Jump to instruction at address label if the carry flag (CS) equal to 1                                                                                                                                                                                                                                                                                                                                                                                                         |
| JNC | label | $[PC] \leftarrow \text{label}$<br>Jump to instruction at address label if the carry flag (CS) equal to 0                                                                                                                                                                                                                                                                                                                                                                                                         |
| JZ  | label | $[PC] \leftarrow \text{label}$<br>Jump to instruction at address label if the zero flag (Z) equal to 1                                                                                                                                                                                                                                                                                                                                                                                                           |
| JNZ | label | $[PC] \leftarrow \text{label}$<br>Jump to instruction at address label if the zero flag (Z) equal to 0                                                                                                                                                                                                                                                                                                                                                                                                           |
| JP  | label | $[PC] \leftarrow \text{label}$<br>Jump to instruction at address label if the sign flag (S) equal to 0                                                                                                                                                                                                                                                                                                                                                                                                           |
| JM  | label | $[PC] \leftarrow \text{label}$<br>Jump to instruction at address label if the sign flag (S) equal to 1                                                                                                                                                                                                                                                                                                                                                                                                           |
| JPE | label | $[PC] \leftarrow \text{label}$<br>Jump to instruction at address label if the parity flag (P) equal to 1                                                                                                                                                                                                                                                                                                                                                                                                         |
| JPO | label | $[PC] \leftarrow \text{label}$<br>Jump to instruction at address label if the parity flag (P) equal to 0                                                                                                                                                                                                                                                                                                                                                                                                         |
| RST | n     | The RST instruction is equivalent to a 1-byte call instruction to one of eight memory locations depending upon the number. The instructions are generally used in conjunction with interrupts and inserted using external hardware. However these can be used as software instructions in a program to transfer program execution to one of the eight locations. The addresses are:<br><br>Instruction Restart Address<br>RST 0 0000H<br>RST 1 0008H<br>RST 2 0010H<br>RST 3 0018H<br>RST 4 0020H<br>RST 5 0028H |

|                                                                                                                                    |                                                                                                                  |                         |                    |
|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------|
| <br><b>ESCOLA SUPERIOR DE TECNOLOGIA E GESTÃO</b> | Tipo de Prova<br>Teste 2                                                                                         | Ano letivo<br>2024/2025 | Data<br>19-05-2025 |
|                                                                                                                                    | Curso<br>Licenciatura em Engenharia Informática / Licenciatura em Segurança Informática em Redes de Computadores | Hora<br>14H00           |                    |
|                                                                                                                                    | Unidade Curricular<br>Sistemas digitais e arquitetura de computadores                                            | Duração<br>00:30 horas  |                    |
|                                                                                                                                    |                                                                                                                  |                         |                    |

RST      6  0030H  
RST      7  0038H

### Grupo de controlo do CPU, I/O e da Pilha

| INSTRUÇÃO | OPERANDOS | STATUS DO REGISTO DE<br>FLAGS | OPERAÇÃO REALIZADA                                                                                                     |
|-----------|-----------|-------------------------------|------------------------------------------------------------------------------------------------------------------------|
|           |           | CS AC Z S P                   |                                                                                                                        |
| IN        | port      |                               | [A] ← [port]<br>Input to register accumulator (A) from I/O port                                                        |
| OUT       | port      |                               | [port] ← [A]<br>Output from register accumulator (A) to I/O port                                                       |
| PUSH      | pr        |                               | [[SP]] ← [pr], [SP] ← [SP] – 2<br>Push register pair BC (pr=B), DE (pr=D), H (pr=HL), PSW (pr=PSW) contents onto stack |
| POP       | pr        |                               | [pr] ← [[SP]], [SP] ← [SP] + 2<br>Pop stack into register pair BC (pr=B), DE (pr=D), H (pr=HL), PSW (pr=PSW)           |
| XTHL      |           |                               | [HL] ← [[SP]]<br>Exchange HL with top of stack                                                                         |
| EI        |           |                               | Enable interrupts following execution of next instruction                                                              |
| DI        |           |                               | Disable interrupts                                                                                                     |
| SIM       |           |                               | Set interrupt mask                                                                                                     |
| RIM       |           |                               | Read interrupt mask                                                                                                    |
| NOP       |           |                               | [PC] ← [PC] + 1<br>No operation but program counter (PC) is incremented                                                |
| HLT       |           |                               | HALT<br>Stop CPU operation                                                                                             |