CHAPTER 2
8051 ASSEMBLY LANGUAGE
PROGRAMMING
Prima Dewi Purnamasari & Boma A. Adhi
1
OBJECTIVES
List the registers of the 8051 microcontroller
Manipulate data using the registers and MOV instructions
Code simple 8051 Assembly language instructions
Assemble and run an 8051 program
Describe the sequence of events that occur upon 8051 power-up
Examine programs in ROM code of the 8051
Explain the ROM memory map of the 8051
Detail the execution of 8051 Assembly language instructions
Describe 8051 data types
Explain the purpose of the PSW (program status word) register
Discuss RAM memory space allocation in the 8051
Diagram the use of the stack in the 8051
2
SECTION 2.1: INSIDE THE 8051
Registers
8 Bit Registers
Figure 21a
Some 8-bit Registers of the 8051
3
16 Bit Registers
Figure 21b Some 8051 16-bit Registers
4
Most widely used registers are A, B, R0, R1, R2, R3, R4, R5,
R6, R7, DPTR and PC
All registers are 8-bits, except DPTR and the program
counter which are 16 bit
Register A is used for all arithmetic and logic instructions
Two simple instructions MOV and ADD
5
MOV instruction
MOV destination, source
MOV instruction is used to copy source to
destination
MOV A,#55H ;load value 55H into reg A
MOV R0,A ;copy contents of A into R0 (A=R0=55H)
MOV R1,A ;copy contents of A into R1 (A=R0=R1=55H)
MOV R2,A ;copy contents of A into R2 (A=R0=R1=R2=55H)
MOV R3,#95H ;load value 95H into R3 (R3=95H)
MOV A,R3 ;copy contents of R3 into A (A=R3=95H)
6
MOV notes
Values can be loaded directly into any of register A, B, or R0-
R7
To indicate immediate value it must be preceded with a pound
sign (#)
MOV R0,#23H
If values 0 to F are moved into any of 8 bit register, the rest of
the bits are assumed to be zero
In MOV A,#5, result will be A=05 or 00000101 in binary
Moving a value that is too large into a register will cause an
error
MOV A,#7F2H ; Illegal
When a value without pound sign is loaded to register, it
means the value is loaded from a memory location (RAM)
MOV A,17H ;load a value from memory location (address) 17H
7
ADD instruction
ADD A, source
ADD instruction is used to add the value inside
source operand to the accumulator
The source operand can be either a register or
immediate data.
The destination should be accumulator
MOV A,#25H ;load 25H into A
MOV R2,#34H ;load 34H into R2
ADD A,R2 ;add R2 to accumulator (A=25H + 34H)
Executing the program above results in A = 59H
8
Can also be written:
MOV A,#25H ;load 25H into A
ADD A,#34H ;add R2 to accumulator (A=25H + 34H)
9
SECTION 2.2: INTRODUCTION TO 8051 ASSEMBLY
PROGRAMMING
Structure of Assembly language
ORG 0H ;start (origin) at 0
MOV R5,#25H ;load 25H into R5
MOV R7,#34H ;load 34H into R7
MOV A,#0 ;load 0 into A
ADD A,R5 ;add contents of R5 to A
;now A = A + R5
ADD A,R7 ;add contents of R7 to A
;now A = A + R7
ADD A, #12H ;add to A value 12H
;now A = A + 12H
HERE: SJMP HERE ;stay in this loop
END ;end of asm source file
Program 2-1: Sample of an Assembly Language Program
10
Assembly language instructions
An Assembly language instruction consists of four
fields:
[label : ] mnemonic [operands] [;comment]
11
SECTION 2.3: ASSEMBLING AND RUNNING
AN 8051 PROGRAM
Figure 22 Steps to Create a Program
12
Steps to create an executable Assembly
program
1. "asm" file is source file and for this reason some
assemblers require that this file have the a51" extension.
This file is created with an editor such as Windows
Notepad
2. The asm file is fed to an 8051 assembler. The assembler
converts the instructions into machine code. The
assembler will produce an object file (.obj)and a list file.
(.lst)
3. Link program takes one or more object files and produces
an absolute object file .abs
4. The abs file is fed into a program called OH (object to
hex converter which creates a file .hex that is ready to
burn into ROM
13
SECTION 2.4: THE PROGRAM COUNTER
AND ROM SPACE IN THE 8051
Program counter (PC)
Points to the address of the next instruction to be executed
Automatically incremented
16 bits wide can access program addresses 0000 to FFFFH total of
64K bytes of code
Where the 8051 wakes up when it is powered up?
wakes up at memory address 0000 when it is powered up (put Vcc at
RESET pin)
Thus, first opcode must be stored at ROM address 0000H
Placing code in program ROM
the opcode and operand should be placed in ROM locations starting at
memory 0000
Using instruction: ORG 0H
14
Example of ROM contents
Pg 47
15
ROM memory map in the 8051 family
Different size of ROM means different ending
address
16 Figure 23 8051 On-Chip ROM Address Range
SECTION 2.5: 8051 DATA TYPES AND
DIRECTIVES
8051 data type and directives
DB (define byte) to define data in byte size
ORG (origin) to define the address of the code (in
ROM)
EQU (equate) to define a constant
END directive to end the program
17
Example: Make Data in ROM
See the effect in simulator CODE MEMORY
18
Example: Make constant data
Why do we need EQU?
19
SECTION 2.5: 8051 DATA TYPES AND
DIRECTIVES
Rules for labels in Assembly language
each label name must be unique
first character must be alphabetic
reserved words must not be used as labels
20
SECTION 2.6: 8051 FLAG BITS AND THE
PSW REGISTER
PSW (program status word) register
21
Figure 24 Bits of the PSW Register
ADD instruction and the PSW
Table 21
Instructions That
Affect Flag Bits
22
Example
23
24
25
SECTION 2.7: 8051 REGISTER BANKS AND
STACK
RAM memory space allocation in the 8051
128 bytes: address 00H-7FH
Figure 25
RAM Allocation in the 8051
26
SECTION 2.7: 8051 REGISTER BANKS AND
STACK
Register banks in the 8051
Figure 26 8051 Register Banks and their RAM Addresses
27
SECTION 2.7: 8051 REGISTER BANKS AND
STACK
How to switch register banks
Table 22 PSW Bits Bank Selection
28
Example 2.6 and 2.7
29
30
SECTION 2.7: 8051 REGISTER BANKS AND
STACK
Stack in the 8051
section of RAM used to store information temporarily
could be data or an address
CPU needs this storage area since there are only a
limited number of registers
PUSH put into stack
SP points to last address used
SP is incremented
POP getting out from stack
SP is decremented
31
PUSH operation
32
POP operation
33
34
Reference
The 8051 Microcontroller and Embedded Systems Using
Assembly and C, 2nd ed., Mazidi, Prentice Hall, 2006
35