

## MICROPROCESSOR

A microprocessor, is a general-purpose digital computer central processing unit (CPU). Although popularly known as a "computer on a chip". The prime use of microprocessor is to read data, perform extensive calculations on that data, and store those calculations in a mass storage device or display the results for human use.

### Block diagram of Microprocessor



## MICROCONTROLLERS

A microcontroller is a general-purpose device, but one that is meant to read data, perform limited calculations on that data, perform limited calculations on that data and control its environment based on those calculations. Its main use is

to control the operation of a machine using a fixed program that is stored in ROM and that doesn't change over the lifetime of the system.

## MICROCONTROLLER (Block diagram)



## Comparison of microprocessor and Microcontrollers

### Microprocessors

- They have many operational nodes for moving data from internal memory to the CPU.
- They have one or two bit handling instructions.

### Microcontrollers

They have one or two off nodes for moving data from internal memory to CPU.

They have many.

iii) It is concerned with rapid movement of code and data from external addresses to the chip.

It is concerned with rapid movements of bits within the chip.

iv) It can function as a computer with addition of no external digital parts.

It must have many additional parts to be operational.

### 8051 Basic Components

- 4KB ROM
- 128 B RAM
- four 8-BIT I/O ports
- 2 16-BIT timers/counters
- One serial interface
- 6 interrupt sources

### Block diagram

external interrupt



# 8051 flag bits and PSW register

|     |       |                              |
|-----|-------|------------------------------|
| CY  | PSW.0 | carry flag                   |
| AC  | PSW.1 | ALX carry flag               |
| F0  | PSW.2 | general purpose              |
| RS1 | PSW.3 | register bank selector bit 1 |
| RS0 | PSW.4 | register bank selector bit 0 |
| OV  | PSW.5 | overflow flag                |
| -   | PSW.6 | user defined                 |
| P   | PSW.7 | parity bit.                  |

## Basic operation of processor

- i) Fetch - Bring the next instruction from memory into the processor.
- ii) Decode - To translate data from a code into the original language or form.
- iii) Execute - Do it.

## Microcontroller architecture and programming codes

### Microcontrollers

| Bits      | memory            | instructions | memory architecture |
|-----------|-------------------|--------------|---------------------|
| 4 8 16 32 | embedded external | cisc RISC    | frinton Harvard     |

family

8051 motorola PIC tiexas national ATM others

Intel Almel Dallas Phillips siemens

RISC - Reduced instruction set computer architecture.

CISC - Complexed instruction set computer architecture.

Harvard - there is a different block of memory for code and data



Princeton → Have common block for code and data



In case of Harvard, 2 things can be done parallelly in Princeton one has to wait for the completion of the other. Harvard required more space on ROM but Princeton requires less space.

### MCS-51 family of MC

- 8 bit processor (8051) → basic version.
- 4k bytes of on-chip ROM instruction memory.
- Data storage and the stack
- 2 times, one serial port, four 8 bit, parallel I/O ports
- speeds (frequency) starting from 12 MHz.

### Architectural needs of a microcontroller

- Lets consider what architectural features could be needed in a microcontroller.
  - What are expected applications?
- sensing the environment
  - I/O
- The response may be displayed
  - Timer / counter
- prioritized response
  - Interrupts (disturbs processing)

- these are used to distract the processes which went wrong.
- software to control the process
  - non-volatile memory (ROM)
- temporary data
  - RAM

Registers → A proper formatted memory. It has different sizes but for a particular microcontroller they are fixed.

### The processor

#### Registers

- general purpose → used as programmer requires
- special purpose → can only be used for specific function
  - stack pointer, - accumulator - pointers



interrupt → by storing some address  
of previous process in stack  
in it. Jumps to process (interrupted)

stack - Data structures following mechanisms of, st in last out  
stack is used for arithmetic operators.

until this it shows error.



search in stack is impossible.

pointers - pointing



### ALU

→ Made up of functional blocks that perform different arithmetic and logical operations on the operand.

→ flag → indicate something  
eg- sign, carry, zero.

→ PSW - (program status word)  
flags register are collectively known

### Memory

RAM - Dynamic and static temporary memory.

Dynamic - set of box in home when switched off it again sets up (same channel will not play).

ROM - Erasable : EEPROM hard disc

Electrically erasable - EEPROM

MCS - 51 variants

More no. of interrupts, better is controller.

Read about flash memory

- It is an electronic non-volatile computer storage medium that can be electrically erased and reprogrammed.

when pointer is pointing at first address stack will be empty.

GUI - graphical user interface. 1 bit at a time can be sent through "serial interface".

### RISC

Reduced Instruction set computing / architecture has a ~~data~~ set of attributes that allows it to leave a lower cycles per instruction than CISC.

### CISC

Complex instruction set computing / architecture is a focused design where single instructions can execute several low-level operations load from memory, an arithmetic or are capable of multi-step operations or addressing modes within single instructions.

### CISC

#### RISC

i) Reduced instruction set architecture

Complex instruction set architecture

ii) Only few instructions are present

Many instructions are present.

- iii) Only few instruction addresses memory.
  - iv) fixed length instructions
  - v) highly pipelined
  - vi) many register sets are present
- Most of the instructions address the memory.
- variable length instructions
- less pipelined
- few register sets are present

### Harvard architecture

- i) Has separate data and instruction busses allowing transfers to be performed simultaneously on both busses
- ii) It is possible to have two separate memory systems.

### Princeton architecture

- Has only one bus which is used for both data transfers and instruction fetches must be scheduled.
- They can't be performed at the same time.

Processor has controlling unit.

### Note on pins of 8051

- 8051 consists of I/O ports ( $P_0 - P_3$ )
- Port 0 (pins 32-39):  $P_0 (P_0, 0 - P_0, 7)$
- 8 bit R/W general purpose I/O.
- OR acts as a multiplexed (same pin can act as address, data and general purpose) low byte address, and data bus for external memory design.

- Part 1 (pins 1-8) :  $P_1 (P_{1.0} - P_{1.7})$
- only 8 bit I/O - general purpose I/O.
- Part 2 (pins 21-28) :  $P_2 (P_{2.0} - P_{2.7})$
- 8 bits I/O - general purpose I/O or high bytes of address bus for internal memory design.
- Part 3 (pins 10-17) :  $P_3 (P_{3.00} - P_{3.7})$
- General purpose I/O
- Each port can be used as I/O or output. (bi-directional)
- It's not using only one of the internal peripherals (timer) or internal interrupts.

### On chip RAM

- There are 4 BANK's (are group of registers)
- if there are 4 banks, then each bank has 8 registers, 32 registers totally in 4 banks.

locations → addresses

$$16 \text{ locations} \times 8 \text{ bits} = 128 \text{ bits}$$

Accumulator - holds the value of our operator.

2-16 bit register.

- 1) program counter → points to the next instruction in ROM.
- 2) DPH → data pointer high byte  
DPL → data pointer low byte

Data pointer contains address of internal and external.

- Hardware can exist without software.
- ACC and B registers → 8 bit each stack pointer → 8 bit
- Nibble - 4 bit.
- carry generated from 4<sup>th</sup> bit to 5<sup>th</sup> bit is called auxiliary carry.
- If both R50, R50 are present then bank "zero" is selected.
- parity : Pair of one's.  
f is represented in 4 bits.  
∴ f f is 8 bits.

Buffers - to communicate these are necessary.

"128 bytes" bytes RAM consists

Microcontroller is CISC architecture

We can connect "External ROM"  
"RAM" has 128 bytes.

There are no instructions which has 1 byte, we have only "1, 2, 3". 8051 microcontroller can use both internal and external memory. All addresses are hexadcial in nature.  
Software is embedded in hardware or vice versa.

"Counter" makes "Timers".

We can design counter and timer.

8051 Instruction Set

- 8051 has 255 instructions
- It is optimized for 8-bit control applications
- It is having 1 bit op-codes.

It is having 3 bit op-nodes.

$139 \rightarrow 1$  byte,  $92 \rightarrow 2$  bytes and  $24 \rightarrow 3$  bytes.

→ 2 times together form a state



$$T = 1/f$$

if  $f = 11.0592 \text{ MHz}$  of crystal oscillator

$$T = \frac{1}{11.0592} = 0.094 \text{ ms}$$

$$\rightarrow 1 \text{ state is as good as } 2 \times T = 2 \times 0.094 \text{ ms}$$
$$= \underline{\underline{0.18 \text{ ms}}}$$

$$1 \text{ Machine cycle (1 MC)} = 6 \times \text{state}$$

$$= 6 \times 0.18 \text{ ms}$$

$$1 \text{ MC} = \underline{\underline{1.08 \text{ ms}}}$$

How many machine cycle are there in 1 sec

Soln

$$\left( \frac{11.0592}{12} \right) \text{ MHz} = \underline{\underline{0.92 \times 10^6}}$$

$$T = \frac{( \times 12 )}{\text{frequency}}$$

## 8051 ADDRESSING MODES

i) Five addressing modes are available :-

- Immediate
- Register
- Direct
- Indirect
- Indexed

There are three more modes :-

- Relative
- absolute
- long

They are used with calls, branches, and jumps and are handled automatically by the assembly.

What is overflow? When does it occur?

- Overflow occurs when there are insufficient bits in a binary number representations

Exceptions - Can't move one register to another.

Not all combinations are valid.

Ex. MOV R<sub>2</sub>, R<sub>1</sub> (invalid)

→ only one bank can be accessed at a time controllable through bit R<sub>50</sub> and R<sub>51</sub> of the PSW.

MOV PSW, # 00011000B

Set R<sub>50</sub>:R<sub>51</sub> to 11, therefore accessing register bank 0.

### Direct Addressing

Either the source and destination is direct address value.

- It can access any on-chip hardware register by their address or access any memory location by its address.
- All on chip memory locations and registers have 8-bit address.

Can we use the 8-bit address in the instruction?

MOV A, 4H      A  $\leftarrow$  mem [04H] (memory location)

Note :- No '#' sign here.

"04H" coz we need to know the actual address to transfer data

Yes, hexaduimal can be represented using 3 bits.

We can write address on destination also.

### Indirect Addressing

- R<sub>0</sub> and R<sub>1</sub> may be used as pointer (we use to point to other location) registers where their contents indicate an address in internal RAM where the data is to be read and written.
- Indirect addressing is represented by a commercial 'at' sign (@) preceding R<sub>0</sub> or R<sub>1</sub>.
- MOV R<sub>1</sub>, #40H , 40H value is passing to R<sub>1</sub>.
- MOV A, @R<sub>0</sub>,
- MOV @R<sub>0</sub>, R<sub>1</sub>

## Limitations

We can't use other than R<sub>0</sub> and R<sub>1</sub> to point to other registers.

MOVx is used for internal memory.

MOV is for internal memory.

Write a program to copy value, 40H in register R<sub>0</sub>, R<sub>1</sub>, memory address 0FH or @ location 3FH using min instructions and using all memory address

## Immediate addressing

MOV R<sub>0</sub>, #40H

MOV R<sub>1</sub>, #40H

## Register addressing

MOV A, 40H

MOV R<sub>0</sub>, A

MOV R<sub>1</sub>, A

## Direct addressing

MOV R<sub>0</sub>, 40H

MOV R<sub>1</sub>, 40H

16 bit register points program counter is not present in ROM because it is the only register which doesn't have address/location.

Write the previous code in a single instruction with all addressing modes.

```
MOV R0, #60H,  
MOV A, R0  
MOV R1, A  
MOV 3FH, @R1
```

Can we use address location in destination?

Yes

Ex:- MOV @R0, R1. (This allows (shows) address can be destination)

We use op-code to perform.

Operations on operands → are registers

To perform operation, we need op-codes and operands.

Why do we need address?

Immediate Addressing

MOV A, @R1; Move contents to external memory not internal

Instruction types

The instructions are grouped into 5 groups

- arithmetic
- logic
- Data transfer
- Boolean
- Branching

## Steps :-

Kill Mission 3 → double click

IDE → integrated Development Environment

Project → give name → save → choose target device → atmel  
(+ sign) → AT89C51ED2 → OK → NO → file → text → textfile opens  
(start program).

Registers → ORG, end

program has to start from its memory location

## Program :-

org 0000h

mov a, #12h

mov r0, a

end

Now go to file → save → file name mord1.asm → save (after saving it, name in dark black or bold letters). Right click on source group → add files to group source group 1 → change file type to asm → click on mord1 → click only once or add not double click.

## To check for error :-

right click on file mord1.asm → click on build target. If there are errors it shows a blue arrow mark, near the error.

## To execute

Debug → start debug session → OK.

Yellow arrow is PC (program counter)

To run - F11

NOP → no operation.

Window is called disassembly window

To step → debugging → press step

To view memory window :-

view → memory window (where we can see any memory location)

Write an ALP to transfer a block of data from internal  
memory location 30h to 34h to 30h-44h.

```
org 0000h
mov 30h, #0aah
mov 31h, #0bbh
mov 32h, #0cch
mov 33h, #0ddh
mov 34h, #0eeh
mov 30h, 40h
mov 31h, 41h
mov 32h, 42h
mov 33h, 43h
mov 34h, 44h
end
```

dptr is a register which is used to point to the external memory  
(16 bit)

```
mov dptr, #4050h  
mov a, #12h  
mov x @dptr, a  
movx a, @dptr  
mov R7, a  
end.
```

Write an ALP to transfer a block of data from internal memory  
location 4000h to 4004h to internal memory 30h to 34h

```
org 0000h  
mov dptr, #4000h  
mov a, #0aah  
movx @dptr, a  
movx a, @dptr  
mov 30h, a  
mov dptr, #4001h  
mov a, #0bbh  
mov @dptr, a  
mov a, @dptr  
mov 31h, a  
mov dptr, #4002h  
mov a, #0cch  
mov @dptr, a  
mov a, @dptr  
mov 32h, a
```

```
mov dptr, #4003h  
mov a, #00h  
movx @dptr, a  
movx a, @dptr  
mov 33h, a  
mov dptr, #4006h  
mov a, #00h  
movx @dptr, a  
movx a, @dptr  
mov 34h, a  
end.
```

Write an ALI to exchange a block of data from 4000 h to 4004 h to external memory location internal memory location

```
org 0000h  
mov dptr, #4000h  
movx a, @dptr  
mov r0, a  
mov a, 50h  
mov 50h, r0  
movx @dptr, a  
mov dptr, #4001h  
movx a, @dptr  
mov r0, a  
mov a, 51h  
mov 51h, r0  
movx @dptr, a
```

```
org 0000h  
mov dptr, #4000h  
movx a, @dptr  
mov r0, a  
mov 50h, r0  
movx @dptr, a
```

```
    mov dptr, #4002h  
    mov a, @dptr  
    mov r0, a  
    mov a, 52h  
    mov 52h, r0  
    movx @dptr, a  
    mov dptr, #4003h  
    mov a, @dptr  
    mov r0, a  
    mov a, 53h  
    mov 53h, r0  
    movx @dptr, a  
    mov dptr, #4004h  
    mov a, @dptr  
    mov r0, a  
    mov a, 54h  
    mov 54h, r0  
    movx @dptr, a  
end
```

Write an ALI to add two 1 bit numbers

```
org 0000h  
    mov a, #0FBh  
    mov r0, #022h  
    ADD a, r0.  
end
```

Write an ALP to add 16 bit numbers

```
org 0000h  
mov R0, #0F8h  
mov A, #022h  
ADD A, R0  
mov 51h, A  
mov R2, #0AAh  
mov A, #0BBh  
ADDC A, R2  
mov 50h, A  
end
```

Write an ALP to multiply and divide two 8 bit numbers

```
org 0000h  
mov A, #12h  
mov B, #30h  
mul AB  
end
```

```
org 0000h  
mov A, #20h  
mov B, #30h  
div AB  
end
```

Write an ALP to add 5 numbers present in 50-54 memory location

~~```
org 0000h  
mov A, #50h  
mov R0, #51h  
add A, R0
```~~

```
org 0000h  
mov 50h, #11h  
mov 51h, #22h  
mov 52h, #33h  
mov 53h, #44h  
mov 54h, #55h
```

```
    mov a, #10h  
    add a, 50h  
    add a, 51h  
    add a, 52h  
    add a, 53h  
    add a, 54h  
    end
```

### Addition of 32-bit numbers

```
.org 0000h  
mov r0, #13h  
mov a, #16h  
add c a, r0  
mov 50h, a  
mov r0, #12h  
mov a, #15h  
add c a, r0  
mov ah, a  
mov r0, #11h  
mov a, #10h  
add c a, r0  
mov 48h, a  
mov a, #11h  
add c a, r0  
mov 47h, a  
end
```

Subtract two 16 bit numbers (let no.s be ab17 & 123a

```
    sub b a, #17h  
    mov a, #03ah  
    sub b a, 10  
    mov 51h, a  
    mov a, #0abh  
    mov 10, #012h  
    sub b a, 10  
    mov 50h, a  
end.
```

## Block transfer using increment function

sig 0000h inc 10  
mov 50h, #0aah mov a, 10  
mov 51h, #0bbh inc a  
mov 52h, #0cch inc 10  
mov 53h, #0ddh mov a, 10  
mov 54h, #0ech end  
mov 60h, 50h  
mov a, 60h  
mov 10, 50h  
inc a  
inc 10  
mov a, 10  
inc a  
inc 10  
mov a, 10

# Block transfer data using document operation

org 0000h  
mov 54h, # 0aah  
mov 53h, # 0bbh  
mov 52h, # 0cch  
mov 51h, # 0ddh  
mov 50h, # 0eeh  
mov a, 55h  
mov 10, 64h  
mov 10, a  
dec a  
dec 10

mov 10, a  
dec a  
dec 10  
mov 10, a  
end.



subtraction

$54h$  and  $35h$  and operation logical operation on 8 bit.

$$\begin{array}{r} 54h \\ 35h \\ \hline \end{array}$$

$$\begin{array}{r} 35h \\ \hline 18-1 \\ 8-1 \\ 5-0 \\ 2-0 \\ 10 \end{array}$$

$$35h = 100011h$$

$$\begin{array}{r} 54 \\ \hline 27-0 \\ 13-1 \\ 6-1 \\ 3-0 \\ 1-1 \end{array}$$

$$54h = 110110h$$

$$\begin{array}{r} 110110h \\ 100011h \\ \hline 100010 \end{array}$$

RL - rot

ANL - and

ORL - or

CLR - clear

CPL A - complement

RL A      How many time you rotate left it changes by  $\alpha^n$  when  $n$  times, its will rotate left.

RLC A      Rotate left through carry



MJ8-0      +ve

MJ8-1      -ve

RRA



RRC



LJB = 1 odd

LSB = 0 even

XCH exchange 8 bit of memory.

XCH a, 1n

XCH A, direct

XCH A, @ 1i

XCHD - exchange lower nibbles of two values.

Boolean algebra

OR, XOR operate on single bit

SETB C (make C=1)

SETB bit (make bit<sub>-1</sub>=1)



bit level      byte level

$JC$  (jump if carry is true)

By giving label to instruction, it jumps  
carry is 1, it jumps down

$JNC$  - jump on no carry.

$JB$  - jump on bit

$JB \_\_, back$        $TB = 1$  (true condition)  
 $FB = 0$  (false condition)

$JNB \_\_, back$        $TB = 0$   
 $FB = 1$

$JBL \_\_, back$       It jumps if the condition is true,  
before jumping it does anything.

$JBC$  (jump on bit, clear)

### Byte level

$\oplus JNZ R_0, back$

↓    ↓    ↓  
 One | not | jump zero

Write an ALP to add 5 8 bit numbers stored in  $\text{20-24h}$ .  
if moved by  $10h$ , we will get 16 numbers

sample one

org  $0000h$

mov a,  $20h$

add a,  $21h$

add a,  $22h$

add a,  $23h$

add a,  $24h$

end

org  $0000h$

mov  $15, \#05h$

CLRC

mov  $10, \#20h$

back: ADDC A, @  $10$

INC  $10$

DJNZ  $15, \text{back}$

end

1) Write an ALP to find average of  $n$  numbers

2) Write an ALP to find GCD and LCM.

3) to find count no. of positive no. in an array of  $10$  numbers

- 4) no. of negative no.s
- 5) no. of even no.s
- 6) no. of odd no.s
- 7) no. of zero in a given 8-bit number
- 8) no. of ones in a given 8-bit number
- 9) to find average of all +ve no.s
- 10) " " " all -ve no.s
- 11) " " " all even "
- 12) " " " all odd "

- 12) To check greater no. among two nos  
 " " smaller " "
- 13) To check the greatest no. in an array of 5 nos
- 14) To " smallest no. "
- 15) To arrange array in ascending
- 16) To arrange array in ascending  
descending

Write an ALP to find factorial of 5 numbers

\* org 0000h  
 mov r0, #20h  
 shr c  
 mov b, r0  
 mov r5, #05h  
 back; mul ab  
 INC r0  
 DJNZ r5, back  
 end

eg 0000h  
 mov r0, c  
 mov r0, #05h  
 mov a, #01h  
 : mov b, r0  
 mul ab  
 djnz r0, x  
 end

\* org 0000h  
 mov r0, #40h  
 mov r1, #44h  
 shr c  
 go: add a, @r0  
 inc r0  
 djnz r4, go  
 mov b, #5h  
 shr ab  
 end

a) org 0000h  
 mov r0, #40h  
 mov r1, #10h  
 mov r2, #00h  
 go: RLC a  
 inc r0  
 mov a, r0  
 INC r0  
 inc r2  
 next: djnz r1, go  
 end