# CT1 Zusammenfassung

Joël Plambeck - plambjoe@students.zhaw.ch - Version 0.1, 02.11.2020

#### Table of Contents

Computer Technik

From C to executable

Cortex-M

Object File Sections

**Data Transfer** 

Flags

**Arithmetic Operations** 

Unsigned / Signed Integers

Addition / Subtraction

Multiword Addidtion / Subtraction

Integer Casting

Loops

**Branches** 

Compare and Test

Unconditional

Conditional

Parameterübergabe

Subroutine

Calling Assembly Subroutine from C

Stack

Linking

**Exceptions** 

**Exceptional Control Flow** 

**Exceptions Cortex-M3/M4** 

Interrupts

**Pipeline** 

**SEP Handout** 

Dokumentation: Moodle

## Computer Technik

| Neumann Architecture | Hardware Components | Computers System & Executable |
|----------------------|---------------------|-------------------------------|
|                      |                     |                               |
|                      |                     |                               |

Main memory central memory, via System-Bus, access to individual bytes,

volatile

**Secondary** long-term storage, via I/O, access to data blocks, non-volatile,

storage slow but cheap

# From C to executable Pre-• Kopiert inhalt von #includes **Processor** • Kopirt Makros (#define) in Quelltext • Übersetzt Computer unabhängigen C Compiler code in Assemblercode Assembler • Übersetzt in Maschineninstruktionen • Resultat: Binary File (nicht lesbar) Linker • Merge Object files • Löst Abhängigkeiten auf Erzeugt executable Cortex-M **Cortex-M Architecture Program Execution** Code structure Cortex-M Architecture Program Execution C to Assembly **Instruction Types Memory Allocation** Big endian A muli-byte representation where the MSByte is at the lower address Little endian A muli-byte representation where the **LSByte** is at the lower address Alignment • Half-word aligned Variables aligned on even addresses • Word aligned Variables aligned on addresses that are divisible by four Object File Sections **Object File Sections Assembly Program Structure** Variables in Object sections

#### **Data Transfer**

| Arrays                                                               | Loading Literals | Literals variations |
|----------------------------------------------------------------------|------------------|---------------------|
|                                                                      |                  |                     |
| byte_array DCB 0xAA, 0xBB, 0xCC<br>halfword_array DCW 0x0011, 0x2233 |                  |                     |

# Flags

| Flag     | Meaning    | Action | Operands         |
|----------|------------|--------|------------------|
| Negative | MSB = 1    | N = 1  | signed           |
| Zero     | Result = 0 | Z=1    | signed, unsigned |
| Carry    | Carry      | C = 1  | unsigned         |
| Overflow | Overflow   | V=1    | signed           |

## **Arithmetic Operations**

| Bitwise operations | Shift / Rotate |
|--------------------|----------------|
|                    |                |
|                    |                |

# Unsigned / Signed Integers

#### Addition / Subtraction

**Unsigned** • Addition:  $C = 1 \rightarrow Carry$ . Result too large for available bits

• **Subtraction**: C = 0 → Borrow. Result less than Zero (no negative numbers)

• Addition: potential overflow with equally signed operands

• **Subtraction**: potential **overlfow** with oppositely signed operands

#### Multiword Addidtion / Subtraction

| Multi-Word Addition | Multi-Word Subtraction |
|---------------------|------------------------|
|                     |                        |

| Multing word Attidition | Multing word Stimeraction |
|-------------------------|---------------------------|
|-------------------------|---------------------------|

### **Integer Casting**

|            | Unsigned (Carry)                    | Signed (Overflow)                   |
|------------|-------------------------------------|-------------------------------------|
| Extension  | <b>0000</b><br>1011 → □ 1011        | <b>1111 1</b> 011 → □ 1011          |
|            | $0000$ $0011 \rightarrow \Box 0011$ | $0000$ $0011 \rightarrow \Box 0011$ |
| Truncation | Modulo Operation                    | possible change of sign             |
|            |                                     |                                     |

## Loops

| if | do-while | while | switch |
|----|----------|-------|--------|
|    |          |       |        |

### **Branches**

• Type

• Unconditional: jump always

• Conditional: jump only if condition is met

• Address hand-over

• Direct: target address part of instruction

• Indirect: target address in register

• Address of target

• Relative: target address relative to PC

• Absolute: absolute target address

#### Compare and Test

**CMP** • SUBS without storing result but setting flags

**TST** • AND without storing result but setting flags

#### Unconditional

| Symbol | Properties       |
|--------|------------------|
| В      | direct, relative |

| Symbol | Properties indirect, absolute |
|--------|-------------------------------|
|        |                               |

### Conditional

Conditional branch limit Limited range of -256..254 Bytes for label/pointer of conditional branch

### Flags

| Symbol | Condition        | Flag  |
|--------|------------------|-------|
| BEQ    | Equal            | Z=1   |
| BNE    | Not equal        | Z=0   |
| BCS    | Carry set        | C=1   |
| BCC    | Carry clear      | C = 0 |
| BMI    | Negative         | N=1   |
| BPL    | Positive or Zero | N = 0 |
| BVS    | Overflow         | V=1   |
| BVC    | No overflow      | V=0   |

#### Unsigned

| Symbol      | Condition (Unsigned)     | Flag              |
|-------------|--------------------------|-------------------|
| BEQ         | Equal                    | Z=1               |
| BNE         | Not equal                | Z=0               |
| BHS (= BCS) | >= greater than or equal | C = 1             |
| BLO (= BCC) | < less than              | C = 0             |
| ВНІ         | > greater than           | C = 1 and $Z = 0$ |
| BLS         | ☐ less than or equal     | C = 0 or $Z = 1$  |

### Signed

| Symbol | Condition (Signed) | Flag  |
|--------|--------------------|-------|
| BEQ    | Equal              | Z=1   |
| BNE    | Not equal          | Z=0   |
| BMI    | Negative           | N=1   |
| BPL    | Positive or Zero   | N = 0 |
| BVS    | Overflow           | V=1   |
| BVC    | No overflow        | V=0   |

| Symbol<br>BGE                             |                   | Condition (Signed)<br>>= greater than or ed | qual            | Flag<br>N = V |                   |  |
|-------------------------------------------|-------------------|---------------------------------------------|-----------------|---------------|-------------------|--|
| BLT                                       |                   | < less than                                 |                 | N != V        |                   |  |
| BGT                                       |                   | > greater than                              |                 | Z = 0 as      | Z = 0 and $N = V$ |  |
| BLE                                       |                   | ☐ less than or equal                        |                 | Z=1 or        | Z == 1 or N != V  |  |
|                                           |                   |                                             |                 |               |                   |  |
| Parameterüber                             | gabe              |                                             |                 |               |                   |  |
|                                           | Register          |                                             | Globales Memory |               | Stack             |  |
| Effizient                                 | ++                |                                             | _               |               | /                 |  |
| Reentry                                   | /                 |                                             | _               |               | ++                |  |
| Subroutine                                |                   |                                             |                 |               |                   |  |
| Caller                                    |                   |                                             | Callee          | Callee        |                   |  |
|                                           |                   |                                             |                 |               |                   |  |
| Calling Assembly S                        | Subroutine f      | rom C                                       | 1               |               |                   |  |
| Assembly Subroutine from                  |                   | 10111 0                                     |                 |               |                   |  |
| ,                                         |                   |                                             |                 |               |                   |  |
| Stack                                     |                   |                                             |                 |               |                   |  |
| • ONLY 32bit (Word)                       |                   | Stack Frame                                 |                 |               |                   |  |
| • Pushing and Poping                      | of halfword and b | bytes not possible                          |                 |               |                   |  |
| • SP $\%$ $4 = 0 \rightarrow \text{word}$ | aligned           |                                             |                 |               |                   |  |
| • Stack-limit < SP < S                    | tack-base         |                                             |                 |               |                   |  |
|                                           |                   |                                             |                 |               |                   |  |
|                                           |                   |                                             |                 |               |                   |  |
|                                           |                   | l                                           |                 | 1             |                   |  |
|                                           |                   |                                             |                 |               |                   |  |
| Linking                                   |                   |                                             |                 |               |                   |  |
| Linking                                   |                   |                                             |                 |               |                   |  |

# Exceptions

-Acceptional Control ion

| Polling                                               | Interrupt-Driven I/O                                                     |  |
|-------------------------------------------------------|--------------------------------------------------------------------------|--|
| Reading of status registers in loop Exception Polling | Interrupting program execution when Exception interrupt the error occurs |  |
| Advantages                                            |                                                                          |  |
| Simle and straightforward                             | 1. Initializes peripherals                                               |  |
| • Implicit synchronization                            | 2. Execute other tasks                                                   |  |
| • Deterministic                                       | 3. Peripherals signal when they require attention                        |  |
| No additional interrupt logic required                | 4. Events interrupt program execution                                    |  |
|                                                       | Advantages                                                               |  |
| Disadvantages                                         | <ul> <li>No busy wait → better use of CPU time</li> </ul>                |  |
| <ul> <li>Busy wait → wastes CPU time</li> </ul>       | <ul> <li>short reaction times</li> <li>Disadvantages</li> </ul>          |  |
| <ul> <li>Long reaction times</li> </ul>               |                                                                          |  |
| Reduzierter Durchsatz                                 |                                                                          |  |
|                                                       | <ul> <li>No synchronization</li> </ul>                                   |  |
|                                                       | <ul> <li>difficult debugging</li> </ul>                                  |  |
|                                                       |                                                                          |  |

## Exceptions Cortex-M3/M4

|                                                                                                                                                                                       |                                                                                                                                                                                                                   | I                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| Interrupt sources: IRQ0 - IRQ239                                                                                                                                                      | System exceptions                                                                                                                                                                                                 | Vector Table & NVIC     |
| <ul> <li>Peripherals singal to CPU of event requiring attention</li> <li>Can alternatively be generated by software request</li> <li>Asynchronous to instruction execution</li> </ul> | <ul> <li>Reset: Restart of processor</li> <li>NMI: Non-maskable Interrup<br/>Can't be ingored</li> <li>Faults: Eg. undefined instruct<br/>analigned access, etc.</li> <li>System Level Calls: OS calls</li> </ul> | ions,                   |
| Initialization                                                                                                                                                                        | ISR Call                                                                                                                                                                                                          | <b>Exception States</b> |
|                                                                                                                                                                                       |                                                                                                                                                                                                                   |                         |
|                                                                                                                                                                                       |                                                                                                                                                                                                                   |                         |
| nterrupts                                                                                                                                                                             |                                                                                                                                                                                                                   |                         |
| Trigger hardware interrupt via Software                                                                                                                                               | Interrupt Ac                                                                                                                                                                                                      | tive Status Registers   |
|                                                                                                                                                                                       |                                                                                                                                                                                                                   |                         |

Priority

# Pipeline

Enable Registers

| SEPH | andout |
|------|--------|
|      |        |

Version 0.1 Last updated 2021-01-07 14:45:54 +0100