# TE2023 Microcontrollers Computer Architectures and Instructions

Luis Alfonso Maeda Núñez, PhD

Professor

## Contents

- ► Types of Instructions
- ► Types of Computer Architectures
- ► ARMv6 ISA
- ► Lifecycle of an Instruction



# Types of Instructions

- Arithmetic Operation Type
- Logic Operation Type
- Shift Operation Type
- Memory Access Type
- Input/Output Access Type
- Control Transfer Type
- Floating-Point Calculation Type
- System Control Type



# Types of Computer Architectures

- Stack Architecture
  - ► (Java Virtual Machine Bytecode)
- Accumulator Architecture
  - ► (Z80 and 6502 ISAs)
- Register memory Architecture
  - ► (Intel x86)
- Register Register Architecture
  - ► (Most RISC processors, including ARM)



(a) Stack architecture



(c) Register memory architecture



(b) Accumulator architecture



(d) Register register architecture

## ARMv6 ISA

https://developer.arm.com/ipproducts/processors/cortex-m/cortex-m0-plus

Table 5.1: 16-bit Thumb<sup>®</sup> instructions supported on the Cortex<sup>®</sup>-M0 and Cortex-M0+ processor

| 16-bit Thumb instructions supported on Cortex-M0/M0+ processors |       |      |      |     |      |      |       |      |       |  |  |  |  |
|-----------------------------------------------------------------|-------|------|------|-----|------|------|-------|------|-------|--|--|--|--|
| ADC                                                             | ADD   | ADR  | AND  | ASR | В    | BIC  | BLX   | BKPT | BX    |  |  |  |  |
| CMN                                                             | CMP   | CPS  | EOR  | LDM | LDR  | LDRH | LDRSH | LDRB | LDRSB |  |  |  |  |
| LSL                                                             | LSR   | MOV  | MVN  | MUL | NOP  | ORR  | POP   | PUSH | REV   |  |  |  |  |
| REV16                                                           | REVSH | ROR  | RSB  | SBC | SEV  | STM  | STR   | STRH | STRB  |  |  |  |  |
| SUB                                                             | SVC   | SXTB | SXTH | TST | UXTB | UXTH | WFE   | WFI  | YIELD |  |  |  |  |

Table 5.2: 32-bit Thumb<sup>®</sup> instructions supported on the Cortex<sup>®</sup>-M0 and Cortex-M0+ processor

| 32-bit Thumb instructions supported on Cortex-M0/M0+ processors |     |     |     |     |     |  |  |  |  |  |  |
|-----------------------------------------------------------------|-----|-----|-----|-----|-----|--|--|--|--|--|--|
| BL                                                              | DSB | DMB | ISB | MRS | MSR |  |  |  |  |  |  |



# Lifecycle of an instruction





| NON-<br>PIPELINED | <br> | cycle<br>1 1 |   |    |    | <br> <br>   |    | cycle<br>2 |    | <br>   | cycle<br>I 3 |    |   |    |      |  |
|-------------------|------|--------------|---|----|----|-------------|----|------------|----|--------|--------------|----|---|----|------|--|
| Instruction 1     | IF   | RF           | Α | DM | WB | <br>        |    |            |    | i<br>! |              |    |   |    |      |  |
| Instruction 2     |      |              |   |    |    | I<br>I<br>I | RF | Α          | DM | WB     |              |    |   |    |      |  |
| Instruction 3     | <br> |              |   |    |    | <br> <br>   |    |            |    | i<br>1 | IF           | RF | Α | DM | WB i |  |



|    |                | 2          | 2 <sup>nd</sup> flip-flop 3 <sup>rd</sup> flip-flop |            |                |                       |            | 4 <sup>th</sup> flip-flop |             |            |                      |                       |             |               |             |             |           |
|----|----------------|------------|-----------------------------------------------------|------------|----------------|-----------------------|------------|---------------------------|-------------|------------|----------------------|-----------------------|-------------|---------------|-------------|-------------|-----------|
|    | PIPELINED      | cycle      | cycle                                               | cycle      | cycle          | cycle<br>5            | cycle<br>6 | cycle<br>7                | cycle<br>8  | cycle<br>9 | cycle<br>10          | cycle<br>11           | cycle<br>12 | cycle<br>13   | cycle<br>14 | cycle<br>15 |           |
|    | Instruction 1  | I IF       | RF                                                  | l A        | DM             | WB                    | <br>       | <br>                      | <br>        |            | l<br>I               | l<br>I                | <br>        | <br>          |             | <br>        | i<br>I    |
|    | Instruction 2  | <br>       | l<br>I IF                                           | l<br>  RF  | <br>  <b>A</b> | l<br>I DM             | l<br>  WB  | <br>                      | <br>        |            | <br>                 | <br>                  | <br>        | <br>          |             | <br>        | <br> <br> |
|    | Instruction 3  | <br> <br>  | <br> <br>                                           | l<br>I IF  | l<br>RF        | <br>  <b>A</b><br>    | DM         | l WB                      | <br> <br>   |            | <br> <br>            | '<br> <br>            | <br> <br>   | <br> <br>     | <br>        | <br> <br>   | <br> <br> |
| PC | Instruction 4  | <br>       | <br>                                                | <br>       | I IF           | RF                    | I A        | l DM                      | WB          |            | <br>                 | <br>                  | <br>        | <br>          |             | <br>        | <br>      |
|    | Instruction 5  | <br> <br>  | <br> <br>                                           | <br> <br>  | <br> <br>      | l<br>I <b>IF</b><br>I | l<br>I RF  | I<br>I <b>A</b><br>I      | I<br>I DM I | WB         | <br> <br>            | <br> <br>             | <br> <br>   | <br> <br>     |             | <br> <br>   | <br>      |
|    | Instruction 6  | <br>       | <br>                                                | <br>       | <br>           | <br>                  | I IF       | RF                        | Α           | DM         | w <sub>B</sub>       | <br>                  | <br>        | <br> <br>     |             | <br> <br>   | <br> <br> |
|    | Instruction 7  | <br>       | <br>                                                | <br>       | <br>           | <br>                  | <br>       | I IF                      | RF          | Α          | DM                   | WB                    | <br>        | <br>          |             | <br>        | <br>      |
|    | Instruction 8  | 1<br> <br> | 1<br> <br>                                          | 1<br> <br> | I<br>I<br>I    | <br> <br>             | 1<br>      | I<br>I<br>I               | l IF        | RF         | I<br>I <b>A</b><br>I | I<br>I <b>DM</b><br>I | l WB        | <br> <br>     | <br>        | <br> <br>   | <br> <br> |
| I  | Instruction 9  | I<br>I     | l<br>I                                              | l<br>I     | l<br>I         | <br>                  | I<br>I     | l<br>I                    | l           | IF         | RF                   | A                     | DM          | WB            |             | l           | <br>      |
|    | Instruction 10 | <br>       | <br>                                                | <br>       | <br>           | <br>                  | <br>       | <br>                      | <br>        |            | I<br>I IF            | RF                    | <br>  A     | DM            | WB          | <br>        |           |
|    | Instruction 11 | <br> <br>  | <br> <br>                                           | <br> <br>  | <br> <br>      | <br> <br>             | <br> <br>  | <br> <br>                 | <br> <br>   |            | <br> <br>            | l<br>I IF             | l<br>RF     | <br>  A  <br> | DM          | WB          | <br> <br> |
|    | Instruction 12 | !          | l                                                   | l          | l              | l                     | !          | l                         | l .         |            | l                    | l                     | IF          | RF            | Α           | DM          | WB        |



# Topics to cover in the Exam

#### **CONCEPTS**

- Main Components of the Computer
  - ▶ CPU
  - Memory (volatile, non volatile)
  - Buses (Address, Data, Control)
  - **I/0**
  - Peripherals
- Components of the CPU
  - ▶ ALU, Register Set, Instruction decoder, Timing and Control Unit
- CISC vs RISC (Homework this week)
- ► Harvard vs Von Neumann vs Modified Harvard (Homework this week)
- What is pipelining

#### **PRACTICE**

Lifecycle of an instruction (Homework this week)

