8051 Microcontroller Basics by Er. Swapnil V. Kaware

Download as pptx, pdf, or txt
Download as pptx, pdf, or txt
You are on page 1of 39

8051 Microcontroller

For More Contents, do subscribe to my channel


on you tube as,

”Tech_Guru Swapnil Kaware”


Microcontroller Notes by Er. Swapnil V. Kaware ([email protected])
8051 Microcontroller

Presented By,
Er. Swapnil V. Kaware,
B.E. (Electronics), M.E. (Electronics)
[email protected]
Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 2
Salient Features
(1). 8 bit microcontroller originally developed by Intel in
1980.

(2). High-performance CMOS Technology.

(3). Contains Total 40 pins.

(4). Address bus is of 16 bit & data bus is of 8 bit.

(5). 4K bytes internal ROM (program).


Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 3
Salient Features
(6). 128 bytes internal RAM (data).

(7). Four 8-bit I/O ports.

(8). Two 16-bit timers.

(9). Serial interface Communication.

(10). 64K external code & data memory space.

Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 4


Salient Features
(11). 210 bit-addressable locations.

(12). Internal memory consists of on-chip ROM and on-


chip data RAM.

(13). 8051 implements a separate memory space for


programs (code) and data.

(14). Operating frequency is 24MHz-33MHz.

(15). +5V Regulated DC power supply is required to


operate.

5
(16). It has four 8 bit ports, total 32 I/O lines.
Salient Features
(17). RAM, ROM, I/O ports, one serial port and timers are
all on-chip.

(18). 6-interrupts (2 are external with 2 priority levels).

(19). Low-power Idle and Power-down Modes.

(20). Full duplex UART.

(21). 8051 has 21 special function registers (SFRs).


Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 6
8051 Block Diagram

7
Internal Architecture
Oscillator Circuit:-

(1). The 8051 requires an external oscillator circuit.

(2). The oscillator circuit usually runs around 12MHz.

(3). The crystal generates 12M pulses in one second.

(4). The pulse is used to synchronize the system operation


in a controlled pace.

Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 8


Internal Architecture
(5). An 8051 machine cycle consists of 12 crystal pulses
(clock cycle).

(6). Used for synchronizing internal operations.

(7). Pins XTAL1 & XTAL2 have been used.

(8). The length of machine cycle depends on the frequency


of the crystal oscillator connected to 8051.

Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 9


Internal Memory

(1). 8051 implements a separate memory space for


programs (code) and data.

(2). Both code and data may be internal, however, both


expand using external components to a maximum of
64K code memory and 64K data memory.

(3). Internal memory consists of on-chip ROM and on-chip


data RAM.
Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 10
Internal Memory
(4). On-chip RAM contains a rich arrangement of general
purpose storage, bit addressable storage, register
banks, and special function registers.

(5). In the 8051, the registers and input/output ports are


memory mapped and accessible like any other memory
location.

(6). In the 8051, the stack resides within the internal RAM,
rather than in external RAM.

Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 11


Registers RAM memory space allocation in the
8051 Microcontroller

12
Register banks in the 8051 Microcontroller

13
Special Function Registers
(1). ACC
(2). B
(3). PSW
(4). SP
(5). DPTR
(5). IP
(6). PMODE
(7). PCON
(8). TMODE
(9). TCON etc. 14
Special Function Registers
(1). 8051 has 21 special function registers (SFRs) at the top of internal
RAM from address 80H to FFH.

(2). Most of the addresses from 80H to FFH are not defined, except for 21
of them.

(3). Some SFR’s are both bit-addressable and byte addressable, depending
on the instruction accessing the register.

(4). This area consists of a series of memory-mapped ports and registers.

(5). All 8051 CPU registers, I/O ports, timers and other architecture
components are accessible in 8051 C through SFRs
15
Microcontroller Notes by Er. Swapnil V. Kaware ([email protected])
B Register
(1). B register or accumulator B is used along with the accumulator
for multiply and divide operations.

(2). MUL AB: multiplies 8 bit unsigned values in A and B. and leaves
the 16 bit result in A (low byte) and B (high byte).

(3). DIV AB: divided A by B, leaving the integer result in A and


remainder in B.

(4). B register is bit-addressable.

Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 16


PSW (Program Status word) / Flag Register

17
Stack Pointer
(1). Stack pointer (SP) is an 8-bit register at address 81H.

(2). It contains the address of the data item currently on


top of the stack.

(3). Stack operations include pushing data on the stack


andpopping data off the stack.

(4). Pushing increments SP before writing the data.

(5). Popping from the stack reads the data and


18
decrements the SP
Stack Pointer
(6). 8051 stack is kept in the internal RAM.

(7). Depending on the initial value of the SP, stack can


have different sizes.

(8). Example: MOV SP,#5FH.

(9). On 8051 this would limit the stack to 32 bytes


since the uppermost address of on chip RAM is 7FH.
Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 19
Data pointer (DPTR)
(1). Data pointer (DPTR): is used to access external data or code.

(2). DPTR is a 16 bit register at addresses 82H (low byte) and 83H
(high byte).

(3). The data pointer is used in operations regarding external RAM


and some instructions involving code memory.

(4). Example: the following instructions write 55H into external


RAM location 1000H:
• MOV A,#55H
• MOV DPTR,#1000H
• MOVX @DPTR,A
20
I/O Ports
(1). One of the major features of a microcontroller is the versatility
built into the I/O circuits that connect the microcontroller to the
outside world .

(2). To be commercially viable, the 8051 had to incorporate as many


I/O functions as were technically and economically possible.

(3). One of the most useful features of the 8051 is four bidirectional
I/O ports.

(4). Each port has an 8-bit latch in the SFR space as mentioned
earlier.
21
I/O Ports
(5). To reduce the overall package pin count, the 8051
employs multiple functions for each port.

(6). Each port also has an output drive and an input buffer.

(7). These ports can be used to general purpose I/O, as an


address and data lines.

(8). The four 8-bit I/O ports P0, P1, P2 and P3 each uses 8
pins.

Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 22


I/O Ports

23
PORT 0
(1). Port 0 is 8-bitbidirectional I/O port.

(2). Port 0 pins can be used as high-impedance inputs.

(3). Port 0 is also the multiplexed low-order address and data


bus during accesses to external program and data memory.

(4). We r using pins no. from 32 to 39.

(5). When used as an output the pin latches are programmed


to 0.

(5). When used as an input the pin latches are programmed to


1. 24
PORT 1
(1). Port 1 is an 8-bit bidirectional I/0 port.

(2). We r using pins no. from 1 to 9.

(3). Port 1 have no dual functions.

(4). When used as an output the pin latches are


programmed to 0.

(5). When used as an input the pin latches are


programmed to 1.
Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 25
PORT 2
(1). Port 2 is an 8-bit bidirectional I/O port.

(2). Port 2 emits the high-order address byte during fetches from
external program memory and during accesses to external data
memory that use 16-bit addresses (MOVX @DPTR).

(3). When used as an output the pin latches are programmed to 0.

(4). When used as an input the pin latches are programmed to 1.

(5). We r using pins no. from 21 to 28.


Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 26
PORT 3
(1). Port 3 is an 8-bit bi-directional I/0 port.
(2). We r using pins no. from 10 to 17.

• RXD (P3.0): Serial input port,


• TXD (P3.1): Serial output port,
• INT0 (P3.2): External interrupt,
• INT1 (P3.3): External interrupt,
• T0 T0 (P3.4): Timer 0 external input,
• T1 (P3.5): Timer 1 external input,
• WR (P3.6): External data memory write strobe,
• RD (P3.7): External data memory read strobe,
Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 27
Timers and Counters

(1). Many microcontroller applications require the counting of


external events, such as frequency of a pulse train, or the
generation of precise internal time delays between actions.

(2). Both of these tasks can be accomplished using software


techniques.

(3). The 8051 has two 16-bit registers that can be used as either
timers or counters.

Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 28


Timers and Counters
(4). These two up counters are name T0 and T1 and are
provided for general use of the programmer.

(5). Each counter may be programmed to count internal


clock pulses, act as a timer, or programmed to count
external events as a counter.

(6). The counters are divided into two 8-bit registers


called the timer low (TL0, TL1) and timer high (TH0,
TH1) bytes.

Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 29


TCON (Timer/Counter Control Register)

30
TMOD (Timer/Counter Control Register)

31
SCON (Serial Port Control Register)

32
PCON (Power Mode Control Register)

33
Interrupts
• An interrupt is a special feature which Allows the 8051 to
provide the illusion of "multitasking,“ although in reality the
8051 is only doing one thing at a time. The word "interrupt" can
often be substituted with the word "event.“

• An interrupt is triggered whenever corresponding event occurs.


When the event occurs, the 8051 temporarily puts "on hold" the
normal execution of the program and executes a special section
of code referred to as an interrupt handler.

Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 34


Interrupts
• Whenever any device needs its service, the device
notifies the microcontroller by sending it an interrupt
signal.

• There are total 5 interrupt sources in 8051


Microprocessor as follows.
(1). Timer Flag 0, (2). Timer Flag 1, (TF1 & TF2 are
Timer Flag Interrupts).
(3). INT 0, (4). INT 1, (INT 0 & INT 1 are external
interrupts).
(5). Serial Port Interrupt (RI or TI).
Microcontroller Notes by Er. Swapnil V. Kaware ([email protected]) 35
Interrupts Priorities
Interrupt Destinations
Interrupt Address
(Hex)
1 IE0 0003H

2 TF0 000BH

3 IE1 0013H

4 TF1 001BH

5 SERIAL 0023H
36
Interrupt Priority (IP) SFR

37
Interrupt Enable (IE) SFR

38
For More Contents, do subscribe
to my channel on you tube as,

”Tech_Guru Swapnil
Kaware”
(Thanks For Watching)
Microcontroller Notes by Er. Swapnil V. Kaware ([email protected])

You might also like