## Summary Micro-Controller FS18

Alex Neher

July 1, 2018

# Contents

| 1        |              | Microcontroller                        |   |  |  |  |  |
|----------|--------------|----------------------------------------|---|--|--|--|--|
|          | 1.1          | Components                             | 1 |  |  |  |  |
|          | 1.2          | Numerical systems                      | 2 |  |  |  |  |
|          |              | 1.2.1 Example                          | 2 |  |  |  |  |
|          |              | 1.2.2 Two's Complement                 | 2 |  |  |  |  |
|          | 1.3          | Logic Gates                            | 2 |  |  |  |  |
|          | 1.4          | Instruction Set Cycle                  | 2 |  |  |  |  |
|          | 1.5          | Assembler                              | 4 |  |  |  |  |
|          |              | 1.5.1 Directives                       | 4 |  |  |  |  |
|          |              | 1.5.2 Addressing modes                 | 4 |  |  |  |  |
|          |              | 1.5.3 Assembler Programming Operations | 7 |  |  |  |  |
|          |              | 1.5.3.1 Data Transport                 |   |  |  |  |  |
| <b>2</b> | $\mathbf{C}$ |                                        | 9 |  |  |  |  |

## Chapter 1

### Microcontroller

#### 1.1 Components

Micro controllers are so called **Single Chip** Computer, meaning everything is on a single PCB, as opposed to e.g. a 'normal' PC.

MC consist of at least four components:

CPU: Central Processing Unit

**Memory:** Where programs and data are stored

**IO/Input-Output:** Communication with Peripherals

Bus-System: Connects the components



Fig. 1.1.1: Von-Neumann Architecture

There are two different architectures:

**Von-Neumann:** One shared bus for program and data. Program and data are in the same memory. Often found in low-cost MCs

**Harvard:** Two separate bus systems for program and data. Often found in high-performance MCs

Usually, a read/write-operation goes through four steps:

- 1. CPU puts the address on the address bus
- 2. Either the memory or the IO claim the address as their
- 3. CPU tells the component via the control bus whether the operation is read or write
- 4. read: The memory or IO places the data of the requested address on the data bus write: The CPU writes the data on the mentioned address via data bus

#### 1.2 Numerical systems

In MC, variables and constants are seldom stored as decimal value. Rather they're either stored as a binary or a hexadecimal value.

In general, mathematical terms an n-digit integer to the base B can be expressed as:

$$\sum_{i=0}^{n-1} x_i * B^i = X_0 * B^0 + x_1 * B^2 + [\dots] + x_{n-1} * B^{n-1}$$

Or easier: Multiply the n-th digit of the integer with  $B^{n-1}$  starting from the right with n=0

#### 1.2.1 Example

1100'0101<sub>2</sub> (binary) to decimal 
$$= 1*2^0 + 0*2^1 + 1*2^2 + 0*2^3 + 0*2^4 + 0*2^5 + 1*2^6 + 1*2^7 \\ = 1+0+4+0+0+0+64+128 \\ = 197_{10}$$

If you have to convert a number between two 'exotic' systems, say base 8 to base 3, it's usually easier to convert it to decimal first and then convert it to the desired system again ( $x_8 \to x_{10} \to x_3$ ). An exception to that is binary to hexadecimal and vice versa. One digit in hexadecimal represents four digits in binary, so you can directly convert blocks of four:  $1100'0101_2$  to hexadecimal:

$$1100 = 0 * 2^{0} + 0 * 2^{1} + 1 * 2^{2} + 1 * 2^{3} = 0 + 0 + 4 + 8 = 12_{10} = C_{16}$$
  

$$0101 = 1 * 2^{0} + 0 * 2^{1} + 1 * 2^{2} + 0 * 2^{3} = 1 + 0 + 4 + 0 = 5_{10} = 5_{16}$$
  

$$\rightarrow 1100'0101_{2} = C5_{16}$$

#### 1.2.2 Two's Complement

Especially in MC-technology, signed numbers (that can also be negative) are mostly stored as two's complement. You basically take the binary number, invert every digit and add one. So -28 would be stored as

$$28_{10} = 16 + 8 + 4 = 2^2 + 2^3 + 2^4 = 0001'1100_2$$
 invert  $0001'1100 \rightarrow 1110'0011$  add one  $1110'0011 + 1 = \underline{1110'0100}$ 

#### 1.3 Logic Gates

**Multiplexer:** The multiplexer is a combinational logic circuit, which allows us to select one of many input lines and route it to the single, common output line. The demultiplier does the exact opposite: it takes one input and you can select to which output line it is routed

FlipFlop: Idunno

#### 1.4 Instruction Set Cycle

| Logic Gates |           |                                                                               |                                           |                |  |  |  |
|-------------|-----------|-------------------------------------------------------------------------------|-------------------------------------------|----------------|--|--|--|
| Function    | Symbol    | Equation                                                                      | Table                                     | Switch Setup   |  |  |  |
| AND         | a & Q     | Q = a • b                                                                     | b a Q<br>0 0 0<br>0 1 0<br>1 0 0<br>1 1 1 | a              |  |  |  |
| OR          | a≥1Q      | Q = a + b                                                                     | b a Q<br>0 0 0<br>0 1 1<br>1 0 1<br>1 1 1 | a b            |  |  |  |
| NAND        | a &Q      | Q = a • b                                                                     | b a Q<br>0 0 1<br>0 1 1<br>1 0 1<br>1 1 0 | ₹ā ₹Б          |  |  |  |
| NOR         | a≥1       | $Q = \overline{a + b}$                                                        | b a Q<br>0 0 1<br>0 1 0<br>1 0 0<br>1 1 0 | Tā<br>Tō       |  |  |  |
| NOT         | a _ 1 Q   | Q = ā                                                                         | a Q<br>0 1<br>1 0                         | \(\bar{a}\)    |  |  |  |
| XOR         | a         | $Q = \overline{a} \cdot b + a \cdot \overline{b}$ $Q = a \oplus b$            | b a Q<br>0 0 0<br>0 1 1<br>1 0 1<br>1 1 0 | a $\sqrt{a}$   |  |  |  |
| XNOR        | a — = — Q | $Q = a \cdot b + \overline{a} \cdot \overline{b}$ $Q = \overline{a \oplus b}$ | b a Q<br>0 0 1<br>0 1 0<br>1 0 0<br>1 1 1 | †ā ∖a<br>†Б ∖b |  |  |  |

Fig.. 1.3.1: Fundamental logic-Gates used in MCs



Fig. 1.4.1: Visualisation of the Instruction Set Cycle

.5The way a CPU executes instructions can be shortened to **FDE**. It stands for **F**etch, **D**ecode **E**xecute. S As can be seen in fig.

1.4.1, the CPU first fetches the instruction from the memory, then it decodes it and decides if it has to fetch a second operand (e.g. for an addition). Afterwards it executes said



Fig. 1.3.2: Visualisation of the (de)multiplexer and the flipflop

#### 1.5 Assembler

#### 1.5.1 Directives

Put simply, Assembler directives are instructions that direct the assembler to do something:

| Directive | Description                    | Example            | Explanation                    |
|-----------|--------------------------------|--------------------|--------------------------------|
| SECTION   | Defines the beginning of a re- | ConstSec: SECTION  | Puts the whole ConstSec-       |
|           | locatable section              |                    | Section in the same RAM-       |
|           |                                |                    | section                        |
| EQU       | Assign an expression to a      | MaxElement: EQU 20 | search-and-replace every       |
|           | name. Not redefinable          |                    | MaxElement in the code with    |
|           |                                |                    | 20                             |
| DC        | Defines one or more constants  | DC B \$AA          | Pointer to address \$AA at ev- |
|           | and theirnames                 |                    | ery Alarm                      |
| DS        | Allocates memory to variables  | DS W 3             | Reserves 3 words of RAM. 1     |
|           |                                |                    | Word = 2 Bytes                 |

#### 1.5.2 Addressing modes

There are six different addressing modes that are supported by our CPU:

Immediate: 1 Byte operand in the instruction



**Inherent:** No operand required



Direct: Operands must be stored in the Direct Page (From 0x0000 to 0x00AF)



Extended: Operand can be stored in the whole 64k Memory



Indexed: Operand is stored in Stack Pointer or H:X Register



Relative: Only used with BRANCH-Instructions. Depending on outcome of the Branch



#### 1.5.3 Assembler Programming Operations

There are three main assembler instruction types:

• Data Transport

Load

Store

Transfer

Move

• Operations

Arithmetic

Logic

Bit-Manipulation/Masking

Shift and Rotation

• Branching

#### 1.5.3.1 Data Transport

Data Transport instructions are again divided into four subtypes



Fig. 1.5.1: Visualisation of the different data transfers

Load: Data is moved from the memory to the CPU-Register

Examples: LDA, LDX, LDHX, (PULA, PULX Stack-operations)

Store: Data is moved from the CPU-Register to the memory

Examples: STA, STX, STHX, (PSHA, PSHA Stack-operations)

Transfer: Very fast Data Transfer between CPU registers Examples: TAP, TPA, TAX, TSX

Move: Data is moved within the memory

# Chapter 2

 $\mathbf{C}$