The 8051 Microcontroller and Embedded Systems

Slides:



Advertisements
Similar presentations
EE/CS-352: Embedded Microcontroller Systems The 8051 Assembly Language.
Advertisements

Class Addressing modes
Chapter Addressing Modes
Suranaree University Of Technology มทส  2002 Anant Oonsivilai 2002/4/8 Microcomputers and Microprocessors 1 Chapter 5 Addressing Modes.
The 8051 Microcontroller and Embedded Systems
There are two types of addressing schemes:
Chapter 2 HARDWARE SUMMARY
8051 Core Specification.
The 8051 Microcontroller and Embedded Systems
Room: Timbalan Pengarah Pusat Komputer Phone: Dr Masri Ayob TK 2633 Microprocessor & Interfacing Lecture 4: Introduction.
TK 2633 Microprocessor & Interfacing
ICS312 Set 3 Pentium Registers. Intel 8086 Family of Microprocessors All of the Intel chips from the 8086 to the latest pentium, have similar architectures.
8051 ASSEMBLY LANGUAGE PROGRAMMING
EET 2261 Unit 2 HCS12 Architecture
Microcontroller Intel 8051
1 The 8051 Microcontroller and Embedded Systems CHAPTER INTERFACING TO EXTERNAL MEMORY.
UNDERSTANDING ASSEMBLY LANGUAGE.
MICROCONTROLLER INSTRUCTION SET
Lecture 18 Last Lecture Today’s Topic Instruction formats
Microcontroller Intel 8051 [Architecture]. The Microcontroller Microcontrollers can be considered as self-contained systems with a processor, memory and.
1 EKT 225 MICROCONTROLLER I CHAPTER 3 I/O PORT PROGRAMMING.
The 8051 Microcontroller and Embedded Systems
CoE3DJ4 Digital Systems Design Chapter 3: instruction set summary.
NATIONAL TAIWAN OCEAN UNIVERSITY 國立台灣海洋大學 2002/4/8 Microcomputers and Microprocessors Chapter 5 Addressing Modes.
The 8051 Microcontroller and Embedded Systems
Embedded System Spring, 2011 Lecture 4: The PIC Microcontrollers Eng. Wazen M. Shbair.
Types of Registers (8086 Microprocessor Based)
1 The /27/ Today over fifty companies produce variations of the Several of these companies have over fifty versions of the 8051.
8051 Micro controller. Architecture of 8051 Features of 8051.
Embedded System Spring, 2011 Lecture 11: Bank Switching Eng. Wazen M. Shbair.
The 8051 Microcontroller and Embedded Systems
Lecture Set 4 Programming the 8051.
Intel 8051 Another family of microcontroller is the Intel 8051 family. The basic 8051 microcontroller has four parallel input/output ports, port 0, 1,
The 8051 Assembly Language. Overview Data transfer instructions Addressing modes Data processing (arithmetic and logic) Program flow instructions.
Presented by Sadhish Prabhu
1 EKT 225 MICROCONTROLLER I CHAPTER ASSEMBLY LANGUAGE PROGRAMMING.
Embedded System Spring, 2011 Lecture 11: Bank Switching Eng. Wazen M. Shbair.
8051 Micro Controller. Microcontroller versus general-purpose microprocessor.
Internal Programming Architecture or Model
DEPARTMENT OF ELECTRONICS ENGINEERING V-SEMESTER MICROPROCESSOR & MICROCONTROLLER 1 CHAPTER NO microcontroller & programming.
I NTEL 8086 M icroprocessor بسم الله الرحمن الرحيم 1.
1 Contents: 3.1 Instruction format and Addressing Modes 3.2 Instruction Introduction Chapter 3 Instruction system.
Microprocessors I 8051 Addressing Modes CS Prof. Msc. Ivan A. Escobar
Design methodology for Implementing a Microcontroller in a FPGA. Phillip Southard Ohio University EE 690 Reconfigurable Design.
Index What is an Interface Pins of 8085 used in Interfacing Memory – Microprocessor Interface I/O – Microprocessor Interface Basic RAM Cells Stack Memory.
Programmable System on Chip
CHAPTER ADDRESSING MODES.
Classification of Instruction Set of 8051
Memory Organisation Source: under
The 8051 Microcontroller and Embedded Systems
Lecture Set 5 The 8051 Instruction Set.
A Closer Look at Instruction Set Architectures
8051 Addressing Modes The way, using which the data source or destination addresses are specified in the instruction mnemonic for moving the data, is.
Computer Organization and Assembly Language (COAL)
Microcontroller Intel 8051
Processor Organization and Architecture
SCHOOL OF ELECTRONICS ENGINEERING Electronics and Communication
Memory organization On- chip memory Off-chip memory
Introduction to Micro Controllers & Embedded System Design Addressing Mode Department of Electrical & Computer Engineering Missouri University of Science.
Data Transfer Operations
Memory Organisation Source: under
Unit – Microcontroller Tutorial Class - 2 ANITS College
Under Address Modes Source: under
DMT 245 Introduction to Microcontroller
Introduction to Micro Controllers & Embedded System Design
Important 8051 Features On chip oscillator 4K bytes ROM 128 bytes RAM
UNIT-VIII 8051 Microcontroller Architecture Register set of 8051
Memory Organisation Source: under
8051 ASSEMBLY LANGUAGE PROGRAMMING
Addressing Modes in 8051 MC S. Lourduraj Asst. Prof. of Physics
Presentation transcript:

The 8051 Microcontroller and Embedded Systems CHAPTER 5 8051 ADDRESSING MODES

OBJECTIVES List the five addressing modes of the 8051 microcontroller Contrast and compare the addressing modes Code 8051 Assemblv language instructions using each addressing mode Access RAM using various addressing modes List the SFR (special function registers) addresses Discuss how to access the SFR Manipulate the stack using direct addressing mode Code 8051 instructions to manipulate a look-up table Access RAM, I/O, and ports using bit addresses Discuss how to access the extra 128 bytes of RAM space in the 8052

Addressing Modes The various addressing modes of a microprocessor are determined when it is designed, and therefore cannot be changed by the programmer. The 8051 provides a total of five distinct addressing modes. (1) immediate (2) register (3) direct (4) register indirect (5) indexed

Immediate addressing mode The operand comes immediately after the op-code. The immediate data must be preceded by the pound sign, "#".

Register addressing mode Register addressing mode involves the use of registers to hold the data to be manipulated.

SECTION 5.2: ACCESSING MEMORY USING VARIOUS ADDRESSING MODES Direct addressing mode There are 128 bytes of RAM in the 8051. The RAM has been assigned addresses 00 to 7FH. 1. RAM locations 00 - 1 FH are assigned to the register banks and stack. 2. RAM locations 20 - 2FH are set aside as bit-addressable space to save single­bit data. 3. RAM locations 30 - 7FH are available as a place to save byte-sized data.

Direct addressing mode It is most often used to access RAM locations 30 - 7FH. This is due to the fact that register bank locations are accessed by the register names of R0 - R7. There is no such name for other RAM locations so must use direct addressing.

Direct addressing mode In the direct addressing mode, the data is in a RAM memory location whose address is known, and this address is given as a part of the instruction.

Special Function Registers In the 8051, registers A, B, PSW, and DPTR are part of the group of registers commonly referred to as SFR. The SFR can be accessed by their names or by their addresses. For example, register A has address E0H and register B has been designated the address F0H.

SFR

SECTION 5.2: ACCESSING MEMORY USING VARIOUS ADDRESSING MODES SFR registers and their addresses Table 5–1 8051 Special Function Register (SFR) Addresses

Stack and direct addressing mode Another major use of direct addressing mode is the stack. In the 8051 family, only direct addressing mode is allowed for pushing onto the stack. An instruction such as "PUSH A" is invalid. Pushing the accumulator onto the stack must be coded as "PUSH 0E0H. Direct addressing mode must be used for the POP instruction as well. "POP 04" will pop the top of the stack into R4 of bank 0.

Register indirect addressing mode A register is used as a pointer to the data. If the data is inside the CPU, only registers R0 and R 1 are used for this purpose. R2 - R7 cannot be used to hold the address of an operand located in RAM when using indirect addressing mode. When RO and R 1 are used as pointers they must be preceded by the @ sign.

Register indirect addressing mode

Advantage of register indirect addressing mode One of the advantages of register indirect addressing mode is that it makes accessing data dynamic rather than static as in the case of direct addressing mode. Looping is not possible in direct addressing mode. This is the main difference between the direct and register indirect addressing modes.

Advantage of register indirect addressing mode

Limitation of register indirect addressing mode in the 8051 R0 and R 1 are the only registers that can be used for pointers in register indirect addressing mode. Since R0 and R l are 8 bits wide, their use is limited to accessing any information in the internal RAM (scratch pad memory of 30H - 7FH, or SFR). To access data stored in external RAM or in the code space of on-chip ROM, we need a 16-bit pointer, the DPTR.

Indexed addressing mode and on-chip ROM access Indexed addressing mode is widely used in accessing data elements of look-up table entries located in the program ROM space of the 8051. The instruction used for this purpose is : MOVC A, @ A+DPTR The 16-bit register DPTR and register A are used to form the address of the data element stored in on-chip ROM. Because the data elements are stored in the program (code) space ROM of the 8051, the instruction MOVC is used instead of MOV. The "C" means code. In this instruction the contents of A are added to the 16-bit register DPTR to form the 16­bit address of the needed data.

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.

SECTION 5.3: BIT ADDRESSES FOR I/O AND RAM Many microprocessors such as the 386 or Pentium allow programs to access registers and I/0 ports in byte size only. If you need to check a single bit of an I/0 port, you must read the entire byte first and then manipulate the whole byte with some logic instructions to get hold of the desired single bit. This is not the case with the 8051. One of the most important features of the 8051 is the ability to access the registers, RAM, and I/0 ports in bits instead of bytes. This is a very unique and powerful feature for a microprocessor made in the early 1980s.

SECTION 5.3: BIT ADDRESSES FOR I/O AND RAM Bit-addressable RAM Figure 5–1 16 Bytes of Internal RAM. Note: They are both bit- and byte-accessible.

SECTION 5.3: BIT ADDRESSES FOR I/O AND RAM Bit-addressable RAM Table 5–2 Single-Bit Instructions

SECTION 5.3: BIT ADDRESSES FOR I/O AND RAM I/O port bit addresses Figure 5–2 SFR RAM Address (Byte and Bit)

SECTION 5.3: BIT ADDRESSES FOR I/O AND RAM Bit memory map Table 5–3 Bit Addresses for All Ports

SECTION 5.3: BIT ADDRESSES FOR I/O AND RAM Registers bit-addressability Figure 5–3 Bits of the PSW Register

Using BIT directive The BIT directive is a widely used directive to assign the bit-addressable I/0 and RAM locations. The BIT directive allows a program to assign the I/0 or RAM bit at the beginning of the program, making it easier to modify them.

Using EQU directive We can also use the EQU directive to assign addresses.

Next … Lecture Problems Textbook Chapter 5 Answer as many questions as you can and submit via MeL before the end of the lecture. Proteus Exercise Textbook Chapter 5 Do as much of the Proteus exercise as you can and submit via MeL before the end of the lecture.