Microcontroller Architecture - 8051
Microcontroller Architecture - 8051
Introduction
Block Diagram and Pin Description of the
8051
Registers
Memory mapping in 8051
I/O Port Programming
Addressing modes
Instruction set
1
Why do we need to learn
Microprocessors/controllers?
2
Different aspects of a
microprocessor/controller
3
The necessary tools for a
microprocessor/controller
CPU: Central Processing Unit
I/O: Input /Output
Bus: Address bus & Data bus
Memory: RAM & ROM
Timer
Interrupt
Serial Port
Parallel Port
4
Microprocessors:
General-purpose microprocessor
CPU for Computers
No RAM, ROM, I/O on CPU chip itself
Example:Intel’s x86, Motorola’s 680x0
6
Microprocessor vs. Microcontroller
Microprocessor Microcontroller
CPU is stand-alone, RAM, • CPU, RAM, ROM, I/O and
ROM, I/O, timer are separate timer are all on a single chip
designer can decide on the • fix amount of on-chip ROM,
amount of ROM, RAM and RAM, I/O ports
I/O ports.
• for applications in which cost,
expansive power and space are critical
versatility • single-purpose
general-purpose
7
Embedded System
8
Three criteria in Choosing a Microcontroller
9
Block Diagram
External interrupts
On-chip Timer/Counter
CPU
Bus Serial
4 I/O Ports
OSC Control Port
P0 P1 P2 P3 TxD RxD
Address/Data
10
11
Pin Description of the 8051
P1.0 1 40 Vcc
P1.1 2 39 P0.0(AD0)
P1.2 3 38 P0.1(AD1)
P1.3
P1.4
4
5
8051 37
36
P0.2(AD2)
P0.3(AD3)
P1.5 6 (8031) 35 P0.4(AD4)
P1.6 7 34 P0.5(AD5)
P1.7 8 33 P0.6(AD6)
RST 9 32 P0.7(AD7)
(RXD)P3.0 10 31 EA/VPP
(TXD)P3.1 11 30 ALE/PROG
(INT0)P3.2 12 29 PSEN
(INT1)P3.3 13 28 P2.7(A15)
(T0)P3.4 14 27 P2.6(A14)
(T1)P3.5 15 26 P2.5(A13)
(WR)P3.6 16 25 P2.4(A12)
(RD)P3.7 17 24 P2.3(A11)
XTAL2 18 23 P2.2(A10)
XTAL1 19 22 P2.1(A9)
GND 20 21 P2.0(A8)
12
Pins of 8051
13
XTAL Connection to 8051
C2
XTAL2
30pF
C1
XTAL1
30pF
GND
14
Pins of 8051
RST (pin 9): reset
It is an input pin and is active high, normally low.
The high pulse must be high at least 2 machine cycles.
It is a power-on reset.
Upon applying a high pulse to RST, the
microcontroller will reset and all values in registers
will be lost.
Reset values of some 8051 registers
ACC, B, DPTR, and Most of the registers having 0
SP=07H, Port pins are logic 1
15
Power-On RESET Circuit
Vcc
10 uF 31
EA/VPP
30 pF X1
19
11.0592 MHz
8.2 K
X2
18
30 pF
9 RST
16
Pins of 8051
17
Pins of 8051
ALE(pin 30): address latch enable
It is an output pin and is active high.
8051 port 0 provides both address and data.
The ALE pin is used for de-multiplexing the address
and data by connecting to the G pin of the 74LS373
latch.
I/O port pins
The four ports P0, P1, P2, and P3.
Each port uses 8 pins.
All I/O pins are bi-directional.
18
Pins of I/O Port
The 8051 has four I/O ports
Port 0 (pins 32-39):P0(P0.0~P0.7)
Port 1(pins 1-8) :P1(P1.0~P1.7)
Port 2(pins 21-28):P2(P2.0~P2.7)
Port 3(pins 10-17):P3(P3.0~P3.7)
Each port has 8 pins.
Named P0.X (X=0,1,...,7), P1.X, P2.X, P3.X
Ex:P0.0 is the bit 0(LSB)of P0
Ex:P0.7 is the bit 7(MSB)of P0
These 8 bits form a byte.
Each port can be used as input or output (bi-direction).
19
Hardware Structure of I/O Pin
Each pin of I/O ports
Internal CPU bus:communicate with CPU
A D latch store the value of this pin
D latch is controlled by “Write to latch”
Write to latch=1:write data into the D latch
2 Tri-state buffer:
TB1: controlled by “Read pin”
Read pin=1:really read the data present at the pin
TB2: controlled by “Read latch”
Read latch=1:read value from internal latch
A transistor M1 gate
Gate=0: open
20
Gate=1: close
D Latch:
21
A Pin of Port 1
Read latch Vcc
TB2
Load(L1)
TB1
Read pin
8051 IC 22
Writing “1” to Output Pin P1.X
Read latch Vcc
TB2
Load(L1) 2. output pin is
1. write a 1 to the pin Vcc
D Q
1 P1.X
Internal CPU
bus P1.X pin
0 output 1
Write to latch Clk Q M1
TB1
Read pin
8051 IC 23
Writing “0” to Output Pin P1.X
Read latch Vcc
TB2
Load(L1) 2. output pin is
1. write a 0 to the pin ground
D Q
0 P1.X
Internal CPU
bus P1.X pin
1 output 0
Write to latch Clk Q M1
TB1
Read pin
24
Reading “High” at Input Pin
Read latch Vcc 2. MOV A,P1
TB2 external pin=High
1. write a 1 to the pin MOV Load(L1)
P1,#0FFH
1 1 P1.X pin
Internal CPU bus D Q
P1.X
0 M1
Write to latch Clk Q
TB1
Read pin
3. Read pin=1 Read latch=0
Write to latch=1
25
Reading “Low” at Input Pin
Read latch Vcc 2. MOV A,P1
TB2
1. write a 1 to the pin Load(L1) external pin=Low
MOV P1,#0FFH
1 0 P1.X pin
Internal CPU bus D Q
P1.X
0 M1
Write to latch Clk Q
TB1
Read pin
3. Read pin=1 Read latch=0
Write to latch=1
26
Port 3 Alternate Functions
P3.0 RxD 10
P3.1 TxD 11
P3.2 INT0 12
P3.3 INT1 13
P3.4 T0 14
P3.5 T1 15
P3.6 WR 16
P3.7 RD 17
27
Registers
A
R0
DPTR DPH DPL
R1
R2 PC PC
R3
R5
R6
R7
28
Memory mapping in 8051
4k 8k 32k
0000H 0000H 0000H
0FFFH
DS5000-32
1FFFH
8751
AT89C51
8752
AT89C52 7FFFH
29
RAM memory space allocation in the 8051
7FH
30H
2FH
Bit-Addressable RAM
20H
1FH Register Bank 3
18H
17H
Register Bank 2
10H
0FH (Stack) Register Bank 1
08H
07H
Register Bank 0
00H
30
Memory Space
31
Bit Addressable RAM
Summary
of the 8051
on-chip
data
memory
(RAM)
32
Bit Addressable RAM
Summary
of the 8051
on-chip
data
memory
(Special
Function
Registers)
33
Register Banks
34
Address Multiplexing for External Memory
Multiplexing
the address
(low-byte)
and data
bus
35
Accessing External Code Memory
Accessing
external
code
memory
36
37
Accessing External
Data Memory
Figure
2-11
Interface
to 1K
RAM
38
Assembler Directives
39
Assembler Directives
DATA
Used to define a name for memory locations
SP DATA 0x81 ;special function registers
MY_VAL DATA 0x44 ;RAM location
Address
EQU
Used to create symbols that can be used to
represent registers, numbers, and addresses
LIMIT EQU 2000
VALUE EQU LIMIT – 200 + 'A'
SERIAL EQU SBUF
COUNT EQU R5
MY_VAL EQU 0x44 Registers, numbers, addresses
40
Addressing Modes
41
Immediate addressing mode
42
Register addressing mode
43
ACCESSING MEMORY USING VARIOUS
ADDRESSING MODES
44
Direct addressing mode
45
Direct addressing mode
46
Special Function Registers
47
SFR
48
ACCESSING MEMORY USING VARIOUS
ADDRESSING MODES
50
Register indirect addressing mode
51
Register indirect addressing mode
52
Advantage of register indirect addressing mode
53
Advantage of register indirect addressing mode
54
Limitation of register indirect addressing mode in the 8051
R0 and R1 are the only registers that can be used for pointers
in register indirect addressing mode.
55
Indexed addressing mode and on-chip ROM access
56
Indexed addressing mode and MOVX instruction
The 8051 has another 64K bytes of memory space set aside
exclusively for data storage.
This data memory space is referred to as external memory
and it is accessed by the MOVX instruction.
The 8051 has a total of 128K bytes of memory space since
64K bytes of code added to 64K bytes of data space gives us
128K bytes.
One major difference between the code space and data space
is that, unlike code space, the data space cannot be shared
between code and data.
57
BIT ADDRESSES FOR I/O AND RAM
58
BIT ADDRESSES FOR I/O AND RAM
59
Instruction set
Arithmetic Instructions
Logical Instruction
Data Transfer
Boolean Variable Manipulation
Program Branching
60
Arithmetic Instructions
61
Logical Instructions
62
Data Transfers
63
Data Transfers
64
Boolean Manipulation Instructions
65
Program Branching Instructions
66