Assembly Lang Programming
Assembly Lang Programming
Assembly Lang Programming
programming
Outline
•
Program Development Steps
•
Representing program operations
•
Finding the right instructions
•
Writing a program
•
Writing programs for the use with assemblers
•
Program format
•
Assembler Directives
•
Types of numbers used in data statements
•
Assembly Language Program development Tools
Representing program operations
•
Formula or sequence of operations used to solve a programming
problem is called as the algorithm.
•
There are two ways of representing algorithms:
•
Flowchart
•
Structured programming and pseudo code
Flowchart
•
It uses graphical shapes to represent different types of programming
operations.
•
Flow chart symbols
Structured programming and
pseudo
• code
Programs should be understandable to other programmers
•
Two approaches top-down and bottom up approach
•
Top-down: divide the program in to major modules and divide theses major
modules in to sub modules and so on.
•
Bottom-up: each programmer writes the low level module code and hopes
that all pieces will eventually fit together.
•
Use set of three to seven standard structures.
•
Main structures are only three viz. IF-THEN-ELSE, SEQUENCE &
WHILE-DO.
•
The others are IF-THEN, CASE & REPEAT-UNTIL.
Finding the right instructions
•
Instructions in 8086 are mainly divided into following categories
•
Data Transfer Instructions
•
Arithmetic Instruction
•
Bit manipulation Instruction
•
String Instruction
•
Program execution transfer Instruction
•
Processor control Instruction
Writing a program
•
You need to do the following to write the program effectively:
•
INITIALIZATION INSTRUCTIONS: used to initialize various parts of the program
like segment registers, flags and programmable port devices.
•
STANDARD PROGRAM FORMAT: it’s a tabular format containing ADDRESS,
DATA OR CODE, LABELS, MNEM, OPERAND(S) and COMMENTS as the
columns.
•
DOCUMENTATION: you should document the program. E.g. each page of the
document contains page number and name of the program, heading block
containing the abstract about the program, comments should be added
wherever necessary.
Constructing the machine codes for
8086 instructions
•
Each instruction in 8086 is associated with the binary code.
•
You need to locate the codes appropriately.
•
Most of the time this work will be done by assembler
•
The things needed to keep in mind is:
•
Instruction templates and coding formats
•
MOD and R/M Bit patterns for particular instruction
Instruction template
•
The Intel literature shows two different formats for coding 8086
instructions.
•
Instruction templates helps you to code the instruction properly.
•
MOV CX, [437AH]: copy the contents of the two memory locations to
the register CX.
Tips for Hand Coding 8086 Programs
•
Check your algorithm very carefully to make sure that it really does
what it supposed to do.
•
Initially write down assembly language statements and comments for
your program.
•
Recheck each statement to make sure that you have right instructions
to implement your algorithm.
•
Finally work out the binary code needed by each instruction and
execute you program.
Writing programs for use with and
assembler
•
Allows you to refer the data items by names rather than their offsets.
•
How to write the programs so that it can be used by the assemblers.
Program Format
•
There are assembler level directives available to the programmer so
that he can write programs which are compatible with the assembler.
Sample
formatted
program
Assembler Directives(contd.)
•
There are different directives available for assembler each with their
unique purpose.
•
SEGMENT and ENDS Directives
•
Naming data and Addresses – EQU, DB, DW and DD Directives
•
The ASSUME Directive
•
The END Directive
Assembler Directives(contd.)
•
SEGMENT and ENDS Directive:
•
The SEGMENT and ENDS directives are used to identify a group of data items
or group of instructions that you want to be put together in a particular
segment.
•
A logical segment is not usually given starting address when it is declared.
•
EQU Directive: used to assign names to constants.
•
DB, DW and DD Directives: used to assign names to variables.
Assembler Directives(contd.)
•
The ASSUME Directive
•
4 physical segments: code, data, stack and extra segment
•
tells which logical segment to use for each of the physical segment at a given
time.
•
The END Directive
•
Tells the assembler to stop reading
•
instruction or statements that are written after END will be ignored.
Assembly Program•
The native language is machine language (using0,1 to
represent the operation)•
A single machine instruction can take up one ormore
bytes of code•
Assembly language is used to write the
programusingalphanumeric symbols(or mnemonic),
eg ADD, MOV, PUSH etc.
•The program will then beassembled(similar to compiled)
and linked into an executable program.
•The executable program could be.com,.exe, or.bin files
Assembly Program
•Each instruction is represented by one assembly
language statement
•The statement must specify which operation(opcode) is
to be performed and the operands
•Eg ADD AX,BX
•ADD is the operation
•AX is called thedestination operand
•BX is called thesource operand
•The result is AX = AX + BX
•When writing assembly language program, you needto
think in the instruction level
Example•In c++, you can do A =(B+C)*100
•In assembly language, only one instruction
per statement
31/12/13
Assembly Language Program
Development Tools
•
There are several tools available to support the programmer of
assembly language for better experience of programming. They are
discussed in brief here:
•
Editor
•
Assembler
•
Linker
•
Locators
•
Debuggers
•
Emulators
Editor
•
It is the program which allows you to create a file containing the
assembly language statements for your program.
•
Examples are PC Write, Word stars and the editors that comes with
assemblers.
•
Creates Source file to be processed by the assembler
Assembler
•
It is the program which is used to transfer the assembly language
mnemonics to corresponding binary codes. It works in passes.
•
In the first pass, it determines the displacement of the named data
items, the offset of labels etc. and puts this information to in a symbol
table.
•
In the second pass, it produces the binary codes for each instructions
and inserts the offsets etc. that it calculated in the first pass.
•
It generates two files namely object file (.OBJ) and assembler list file
(.LST).
Linker
•
It is a program used to join several object files into large object files.
•
While writing large programs it is good to divide them into modules
so that each modules can be written, tested, debugged independently
and then use linker to combine the modules to form the actual
program.
•
It produces two files link file which contains the binary codes of all the
combined modules and a link map file which contains the address
information about the linked files.
Locators
•
A locator is the program used to assign the specific addresses of
where the segments of object code are to be loaded in to main
memory.
•
Examples include EXE2BIN which comes with the IBM PC DOS.
•
Converts .exe to .bin files which has physical addresses
Debugger
•
A debugger is the program which allows you to load your object code
program in to system memory.
•
It allows you to look at the contents of the registers and memory
locations after your program runs.
•
It also allows you to set breakpoints at any points in the program.
•
It simply allows you to find the source of the problem into the
program.
•
There are lots of debuggers available like Borland Turbo Debugger,
Microsoft’s Code view debugger etc.
Emulators
•
One way to run your program
•
It is mixture of hardware and software.
•
Generally used to test the hardware and software of an external
system such as microprocessor based instruments.
Applied Microsystems ES 1800
16-bit emulator
data segment
a db 1,2,3,4,5,6,7,8,9,10
data ends
code segment
assume ds:data,cs:code
start:
mov ax,data
mov ds,ax
mov cl,10
lea bx,a
mov ah,00
mov al,00
l1:
add al,byte ptr[bx]
inc bx
dec cl
cmp cl,00
jnz l1
mov ah,4ch
int 21h
code ends