Mpi Lab Manual
Mpi Lab Manual
                        MICROPROCESSORS
                       LABORATORY MANUAL
                        DEPARTMENT
                            OF
         ELECTRONICS & COMMUNICATION ENGINEERING
                        MARCH - 2006
                        MICROPCROCESSORS
                       LABORATORY MANUAL
                        DEPARTMENT
                            OF
         ELECTRONICS & COMMUNICATION ENGINEERING
                        MARCH - 2006
Lab incharge                                                 HOD
                         G.N.I.T.S-ECE DEPARTMENT:MPI LAB
Exercise No:M.1.1                                            Page No: 3
                           Class:3/4 ECE,ETM,ICE –2nd sem & 4/4 EEE – 1st sem
TABLE OF CONTENTS
I. MICROPROCESSOR 8086
   M.1
   1. Introduction                                              5
   2. Using Turbo – Assembler-Linker-Debugger                   8
       (TASM,TLINK,TD)
   3. Introduction to the trainer & Instructions to user        10
   M.2
   1.a).       8bit addition                                    18
     b).       16bit addition                                   20
   2.a).       8bit subtraction                                 22
     b).       16bit subtraction                                23
   3.a).       8bit multiplication                              24
     b).       16bit multiplication                             25
   4.a).       8bit division                                    26
     b).       16bit division                                   28
   5.          Multi byte addition                              29
   6.          Multi byte subtraction                           31
   7.          Signed multiplication                            33
   8.          Signed division                                  34
   9.          ASCII addition                                   35
   10.         ASCII subtraction                                36
   11.         ASCII multiplication                             37
   12.         ASCII division                                   38
   M.3
   1.          Packed to unpacked BCD                           39
   2.          BCD to ASCII conversion                          41
   M.4
   1.          Block Transfer                                   42
   2.          String Reversal                                  43
   3.          String insertion                                 44
   4.          String deletion                                  45
   5.          Length of string                                 46
   6.          String comparison                                47
   M.5
   1.          Program design example (calculator)              48
   M.6
   1.          DOS interrupts                                   56
II. INTERFACING
INTRODUCTION
EDITOR
         An editor is a program, which allows you to create a file containing the assembly language
statements for your program. As you type in your program, the editor stores the ASCII codes for the
letters and numbers in successive RAM locations. When you have typed in all of your programs, you
then save the file on a floppy of hard disk. This file is called source file. The next step is to process
the source file with an assembler. In the TASM assembler, you should give your source file name the
extension, .ASM
ASSEMBLER
         An assembler program is used to translate the assembly language mnemonics for instructions
to the corresponding binary codes. When you run the assembler, it reads the source file of your
program the disk, where you saved it after editing on the first pass through the source program the
assembler determines the displacement of named data items, the offset of labels and pails this
information in a symbol table. On the second pass through the source program, the assembler
produces the binary code for each instruction and inserts the offset etc that is calculated during the
first pass. The assembler generates two files on floppy or hard disk. The first file called the object
file is given the extension. OBJ. The object file contains the binary codes for the instructions and
information about the addresses of the instructions. The second file generated by the assembler is
called assembler list file. The list file contains your assembly language statements, the binary codes
for each instructions and the offset for each instruction. In TASM assembler, TASM source file
name ASM is used to assemble the file. Edit source file name LST is used to view the list file, which
is           generated,            when             you           assemble           the          file.
LINKER
       A linker is a program used to join several object files into one large object file and convert to
an exe file. The linker produces a link file, which contains the binary codes for all the combined
modules. The linker however doesn’t assign absolute addresses to the program, it assigns is said to
be relocatable because it can be put anywhere in memory to be run. In TASM, TLINK source
filename is used to link the file.
DEBUGGER
        A debugger is a program which allows you to load your object code program into system
memory, execute the program and troubleshoot are debug it the debugger allows you to look at the
contents of registers and memory locations after your program runs. It allows you to change the
contents of register and memory locations after your program runs. It allows you to change the
contents of register and memory locations and return the program. A debugger also allows you to set
a break point at any point in the program. If you inset a breakpoint the debugger will run the program
upto the instruction where the breakpoint is set and stop execution. You can then examine register
and memory contents to see whether the results are correct at that point. In TASM, td filename is
issued to debug the file.
DEBUGGER FUNCTIONS:
DEBUGGER COMMANDS
5. Run Linker TLINK.EXE- generate .EXE file from the .OBJ file
tlink/v proj
o Trace into (can use F7 key): executes one instruction; traces "into" procedures.
o Step over (can use F8 key): executes one instruction; skips (does not trace into) procedures.
Hitting either of these executes the instruction, and moves the arrow to the next instruction. As each
instruction executes, the effects might be visible in the Registers Window and Watches Window
3. Examining Registers
Another window, the Registers Window, can be opened to examine the current value of the CPU
registers and flags. The View menu can be used to open this Registers Window. The registers and
flags might change as each instruction is executed.
4. Examining Memory
To examine memory, you will need to open an Inspector window. An Inspector window shows the
contents of a data structure (or simple variable) in the program you are debugging. It also allows you
to modify the contents of the data structure or variable. To open an Inspector window, place the
cursor on what you want to inspect and press CTRL-I. After you've examined the data item, press the
ESC key to remove the Inspector window.
The 8086 and 8088 are third generation CPU is from INTEL that differ primarily in their external
data paths. 8088 uses and 8-bit wide data bus while 8086 uses a 16-bit wide bus. ESA86/88-2 can be
operated with either CPU and the only possible difference would be in the speed of execution (with
8088 CPU, a small speed degradation occurs because of the 8-bit wide data bus). In either case, the
CPU is operated in the maximum mode.
   •   Examine and optionally modify the contents of memory (byte or word format)
   •   Examine and optionally modify the processor registers.
   •   Assemble and Disassemble 8086/8088 instructions (via line assembler, disassembler).
   •   Perform fast numerical computations using the optional 8087 Numeric data processor.
   •   Execute the user program at full speed.
   •   Debug user program through single step and Breakpoint facilities.
   •   Write or read data to or from I/O ports (byte or word format).
   •   Move a block of data or program within the memory
   •   Download user programs into ESA 86/88-2 from a host computer system.
SPECIFICATIONS:
Central processor
       8086 CPU, operating at 8MHz in maximum mode. (Supplied with 8086 CPU). (Memory
       cycles have zero wait states and I/O cycles have one wait state).
Co-Processor
       On-board 8087 Numeric Data processor (optional)
Memory
       EPROM: 4 JEDEC compatible slots offer the following options:
       64K bytes using 27128s or,
       128K bytes using 27256s or,
       256K bytes using 27512s
       (System firmware is supplied in 2x27256s. The other two sockets are for user   expansion).
      128K bytes using 6255s (64K bytes supplied using 2x62556s. The other two sockets are for
      user expansion). RAM has battery backup facility.
   Interrupts
       External: NMI for INTR Keyboard.
       INTER controlled through 8259A, on-board Interrupt Controller: provides interrupt vectors
       for eight sources. Complete flexibility in selecting off-board or on-board interrupt sources.
Interface Signals
       CPU Bus:       Demultiplexed and fully buffered, TTL compatible, Address, Data & Control
   signals are available on two 50-pin ribbon cable connectors.
   Parallel I/O:      48 Programmable parallel I/O lines (TTL compatible) through two 26 pin
   ribbon cable connectors. (Connector details compatible to our other microcomputer trainers).
   Serial I/O:        RS 232 C through on-board 9pin D-type female connector.
   Power supply (optional): +5V @ 3.0Amp
   Printer Enable/Disable
   ESA 86/88-2 firmware includes the driver program fro centronics compatible parallel printer
   interface. This driver can be enabled/disabled as shown below:
           Asynchronous mode
           8-bit character length
           2 stop bits
           No parity
           Baud rate factor of 16X
           Timers 0 of an 8253 provide the Transmit and receive baud clocks for the USART. (Refer to
   chapter 5 for a detailed discussion of the Hardware).This timer is initialized by the system firmware
   to provide proper baud clock based on the settings of the DIP Switch as shown below.
               DIP SWITCH
   SW3              SW2             SW1            Baud rate
   OFF              OFF             ON             9,600*
Memory selection:
ESA 86/88-2 has four sockets, labeled U9, U8, U7, U6 for RAM. These sockets are configured for
62256(32X 4) devices. Two of these sockets are populated (providing 64K Bytes of RAM) and two
are for user expansion.
1
ER/BX               ER          Examine Register     BX            Base Register
2
GO/CX               GO          Go                   CX            Count Register
3
ST/DX               ST          Single Step          DX            Data Register
4
IB/SP               IB          Input Byte           SP            Stack Pointer
5
OB/BP               OB          Output Byte          BP            Base Pointer
6
MV/SI               MV          Move                 SI            Source Index
7
EW/DI               EW          Examine Word         DI            Destination index
8                                                                  Code Segment
IW/CS               IW          Input word           CS
9                                                                  Data Segment
OW/DS               OW          Output Word          DS
A                                                                  Stack Segment
/SS                 None        N/A                  SS
B                                                                  Extra Segment
/ES                 None        N/A                  ES
C                                                                  Instruction Pointer
/IP                 None        N/A                  IP
                                                                   Flag Register
D
/FL                 None        N/A                  FL            N/A
Function Key
               Operation
RESET          The RESET key allows you to terminate any present activity and to return your
               ESA 86/88-2 to an initialize state. When pressed, the sign-on message appears in
               the display and the monitor is ready for command entry.
KB INT         The INTR (interrupt) key is used to generate an immediate non-maskable type 2
               interrupt (NM). The NMI interrupt vector is initialized on power up or system
               reset to point to a routine within the monitor which causes all of the 8086/8088’s
               registers to be saved. Control is returned to the monitor for subsequent command
               entry.
+              The + (plus) key allows you to add two hexadecimal values. This function
               simplifies relative addressing by allowing you to readily calculate an address
               location relative to a base address.
- The – (minus) key allows you to subtract one hexadecimal value from another.
               The : (colon) key is used to separate an address to be entered into two parts; a
:              segment value and an offset value.
REG            The REG (register) key allows you to use the contents of any of the 8086/8088’s
               registers as an address or data value.
               The PREV key is used to decrement the address field to previous memory
PREV           location.
 Input/Output           Input Byter     Displays the data byte at the input port.
                        IB <port address> NEXT [NEXT].
Format
       EB <address> NEXT [[<data>] PREV/NEXT].
       EW <address> NEXT [[<data>] PREV/NEXT].
Operation
   1. Both the commands operate in a similar fashion. To use these commands, press the EB key or
      EW key when prompted for a command.
   2. When either key is pressed, a dot appears at the right edge of the address field indicating that
      an address entry is required.
   3. Enter the memory address of the byte (for EB) of word (for EW) to be examined. (The entry
      of address values is discussed in detail in section 3.2)
   4. After entering the address value, press the “,” key. (i.e. the NEXT key).
   5. The data byte of word contents of the addressed memory location will be displayed in the
      data field and a decimal point (a dot) appears at the right edge of data field indicating that the
      data can be updated. Note that when using the Examine word command, the byte contents of
      the displayed updated memory location appear in the two least-significant digits of the field
      and the byte contents of the next consecutive memory location (i.e. entered memory address
      + 1) appear in the two most significant digits of the data field.
   6. If the contents of the memory location addressed are only to be examined, press the ‘’.’’ Key
      to terminate the command, of press the ‘’,’’ (NEXT) key to examine the next consecutive
      memory location (Examine Byte Command) or the next two consecutive memory locations
      (Examine Word Command) or press the ‘’PREV’’ key to examine previous byte or word
      location.
   7. To modify the contents of an addressed memory location, enter the new data from the
      hexadecimal keyboard (entering the data values is discussed in detail in section 3.2).
   8. The data displayed is not updated in memory until either the ‘’,’’ or ‘’.’’ Key is pressed.
Format
      EB <address> NEXT [[<data>] PREV/NEXT].
INPUT/OUTPUT COMMANDS
There are 4 commands available for Input/Output of Byte/Word data form/to a specified port. In
entering the port address (in any of these four commands), it should be noted that 8086/8088 I/O
addressing is limited to 64K (maximum address is FFFFH). Thus no segment value is permitted with
the port address.
Function
The Input Byte (IB) and Input Word (IW) commands are used to input (accept) an 8-bit byte or 16-
bit word from an input port.
Format
      IB <port address > , [,].
      IW <port address> , [,].
STEP COMMAND
Function
This command is used for single step execution of a program. In other words, this step (ST)
command permits program instructions in memory to be executed individually. With each instruction
executed, control is returned to the monitor from the program being executed,
Format
               ST [< start address>], [[<start address>,.
GO COMMAND
Function
 The GO command is used to transfer control of the 8086/8088 from the keyboard monitor program
to user’s program.
Format
               GO [<address>] [, <breakpoint address>]
MOVE COMMAND
Function
This command (MV) can be used to move a block of data from one portion of the memory to another
potion of the memory.
Format
      MV <Start address> NEXT <end address> NEXT <destination address>.
.model tiny
.stack 32h
.code
org 2000h
start:
               mov ax,cs
               mov ds,ax
               mov ax,00
               mov al,num1
               mov bl,num2
               add al,bl
               mov result,al
               int 3
               mov ah,4ch
               int 21h
org 20f0h
               num1 db 03
               num2 db 08
               result db 00
end start
Result: 03h
        08h
        0Bh
Exercise:
3. What is a directive?
8. What is the purpose of MOV AH, 4CH, INT 21H in the program?.
.model tiny
.stack 32h
.code
org 2000h
start:
               mov ax,cs
               mov ds,ax
               mov ax,00
               mov ax,num1
               mov bx,num2
               add ax,bx
               mov result,ax
               int 3
               mov ah,4ch
               int 21h
org 20f0h
               num1 dw 0ffffh
               num2 dw 0ffffh
               result dw 00
end start
Carry
Exercise:
6. What happens if the result is greater than 16bit when result is declared an DW.?
.model tiny
.stack 32h
.code
org 2000h
start:
               mov ax,cs
               mov ds,ax
               mov ax,00
               mov al,num1
               mov bl,num2
               sub al,bl
               mov result,al
               int 3
               mov ah,4ch
               int 21h
org 20f0h
               num1 db 0ffh
               num2 db 0aah
               result db 00
end start
Result:        0ffh
               0aah
               055h
Exercise:
.model tiny
.stack 32h
.code
org 2000h
start:
               mov ax,cs
               mov ds,ax
               mov ax,00
               mov ax,num1
               mov bx,num2
               sub ax,bx
               mov result,ax
               int 3
               mov ah,4ch
               int 21h
org 20f0h
               num1 dw 0ffffh
               num2 dw 0eabch
               result dw 00
end start
Result:        0ffffh
               0eabch
               01543h
Exercise:
.model tiny
.stack 32h
.code
org 2000h
start:
               mov ax,cs
               mov ds,ax
               mov ax,00
               mov al,num1
               mov bl,num2
               mul bl
               mov result,al
               mov result1,ah
               int 3
               mov ah,4ch
Org 20f0h
               num1 db 0ffh
               num2 db 0aah
               result db 00
               result1 db 00
end start
Result:       0ffh
              0aah
            a956h
Exercise:
.model tiny
.stack 32h
.code
org 2000h
start:
               mov ax,cs
               mov ds,ax
               mov ax,00
               mov ax,num1
               mov bx,num2
               mul bx
               mov result,ax
               mov result1,dx
               int 3
               mov ah,4ch
               int 21h
org 20f0h
               num1 dw 0ffffh
               num2 dw 0ffffh
               result dw 00
               result1 dw 00
end start
Result:        0ffffh
               0ffffh
          fffe0001h
Exercise:
.model  tiny
.stack 32h
.code
org 2000h
start:
               mov ax,cs
               mov ds,ax
               mov ax,00
               mov dx,00
               mov al,num1
               mov bl,num2
               div bl
               mov Quotient,al
               mov remainder,ah
               int 3
               mov ah,4ch
               int 21h
org 20f0h
               num1 db 0ffh
               num2 db 0aah
               Quotient db 00
               remainder db 00
end start
Result:      0ffh
             0aah
            5501h         Quotient: 01h
                          Remainder r: 55h
Exercise:
.model tiny
.stack 32h
.code
org 2000h
start:
               mov ax,cs
               mov ds,ax
               mov ax,00
               mov dx,00
               mov ax,num1
               mov bx,num2
               div bx
               mov Quotient,ax
               mov remainder,dx
               int 3
               mov ah,4ch
               int 21h
org 20f0h
               num1 dw 0ffffh
               num2 dw 0aaaah
               Quotient dw 00
               remainder dw 00
end start
Result:        0ffffh
               0aaaah
            55550001h              Quotient: 0001h
                                   Remainder: 5555h
Exercise:
.model tiny
               data segment
                     dp1 dd    11223344h
                     dp2 dd    55667788h
                     res dd    00000000h
               data ends
               code segment
                     assume cs:code,ds:data
EXERCISE:
4. What is the other instruction which can be used instead of MOV SI,offset dp1.?
                    data segment
                          dp2 dd     55667788h
                          dp1 dd     11223344h
                          res dd     00000000h
                    data ends
                    code segment
                          assume cs:code,ds:data
EXERCISE:
.model tiny
                    data segment
                          dp1 db 0a5h
                          dp2 db 20h
                          res dw 00h
                    data ends
                    code segment
                          assume cs:code,ds:data
EXERCISE:
.model tiny
                    data segment
                          dp1 db 0d5h
                          dp2 db 20h
                          quo db 0h
                          rem db 0h
                    data ends
                    code segment
                          assume cs:code,ds:data
EXERCISE:
.model tiny
               data segment
                     ip1 db '9',0dh,0ah
                     ip2 db '6',0dh,0ah
                     res db 0
               data ends
               code segment
                     assume cs:code,ds:data
EXERCISE:
.model tiny
               data segment
                     ip1 db '9',0dh,0ah
                     ip2 db '6',0dh,0ah
                     res db 0
               data ends
               code segment
                     assume cs:code,ds:data
EXERCISE:
.model tiny
                    data segment
                          ip1 db 4
                          ip2 db 6
                          res db 0
                    data ends
                    code segment
                          assume cs:code,ds:data
EXERCISE:
   2. Why is ASCII adjust after multiply cab be called as 1 byte binary to bcd
      conversion?
.model tiny
                    data segment
                          ip1 db 6
                          ip2 db 4
                          res db 0
                    data ends
                    code segment
                          assume cs:code,ds:data
EXERCISE:
1. What is the ASCII instruction, which is used before the arithmetic operation?
.model tiny
                    data segment
                          bcdip db 56h
                          ubcdop dw 0
                    data ends
                    code segment
                           assume cs:code,ds:data
                    start: mov ax,data
                           mov ds,ax
                           xor ax,ax
                           mov al, bcdip
                           mov dl,al
                           and al,0f0h
                           mov cl,4
                           ror al,cl
                           mov bh,al
                           and dl,0fh
                           mov bl,dl
                           mov ubcdop,bx
                           mov ah,4ch
                           int 21h
                    code ends
                    end start
EXERCISE:
   2. What is the purpose of the instruction AND AL, 0FH & AND AL,0F0H in the
      program.?
.model tiny
                    data segment
                          bcdip db 56h
                          ubcdop dw 0
                    data ends
                    code segment
                           assume cs:code,ds:data
                    start: mov ax,data
                           mov ds,ax
                           xor ax,ax
                           mov al, bcdip
                           mov dl,al
                           and al,0f0h
                           mov cl,4
                           ror al,cl
                           mov bh,al
                           and dl,0fh
                           mov bl,dl
                           mov ubcdop,bx
                           add bx,3030h
                           mov ah,4ch
                           int 21h
                    code ends
                    end start
EXERCISE:
   1. What is the difference between adding 30h and OR 30H to a BCD number to
      conversion to ASCII?
;.model tiny
                    data segment
                          srcdata db 'Empty vessels make much noise',24h
                    data ends
                    extra segment
                    dstdata db 12 dup(0)
                    extra ends
                    code segment
                          assume cs:code,ds:data,es:extra
EXERCISE:
.model tiny
                    data segment
                          string1 db 'Empty'
                          strlen equ ($-string1)
                          string2 db 5 dup(0)
                    data ends
                    code segment
                          assume cs:code,ds:data,es:data
EXERCISE:
   1. Why BX register is added with ‘5’?
.model tiny
                    data segment
                          string1 db 'Empty vessels more noise$'
                          strlen equ ($-string1)
                    data ends
                    extra segment
                          string2 db strlen+5 dup(0)
                    extra ends
                    code segment
                          assume cs:code,ds:data,es:extra
.model tiny
                    data segment
                          string1 db 'Empty vessels make more noise$'
                          strlen equ ($-string1)
                    data ends
                    extra segment
                          string2 db strlen-5 dup(0)
                    extra ends
                    code segment
                          assume cs:code,ds:data,es:extra
EXERCISE:
   1. What is the purpose of string length?
                     .model tiny
                     data segment
                            string1 db 'Empty vessels make more noise$'
                            strlen equ ($-string1)
                            res db 0
                            cort db 'strlength found correct$'
                            incort db 'strlength found incorrect$'
                     data ends
                     code segment
                            assume cs:code,ds:data
                     start: mov ax,data
                            mov ds,ax
                            sub cl,cl
                            mov bl,strlen
                            mov si,offset string1
                            back:lodsb
                            inc cl
                            cmp al,'$'
                            jnz back
                            mov res,cl
                            cmp cl,bl
                            jz correct
                            mov dx,offset incort
                            mov ah,09
                            int 21h
                     correct:mov dx,offset cort
                            mov ah,09
                            int 21h
                            mov ah,4ch
                            int 21h
                     code ends
                     end start
EXERCISE:
   1. What is the operation performed by the instruction cmp al,$ ?
                    .model tiny
                    data segment
                           string1 db 'Empty'
                           strlen equ ($-string1)
                           notsful db 'strings are unequal$'
                           sful db 'strings are equal$'
                    data ends
                    extra segment
                           string2 db 'Empty'
                    extra ends
                    code segment
                           assume cs:code,ds:data,es:extra
                    start: mov ax,data
                           mov ds,ax
                           mov ax,extra
                           mov es,ax
                           mov si,offset string1
                           mov di,offset string2
                           cld
                           ;mov cx,length string1
                           mov cx,strlen
                           rep cmpsb
                           jz forw
                           mov ah,09h
                           mov dx,offset notsful
                           int 21h
                           jmp exitp
                           forw:mov ah,09h
                           mov dx,offset sful
                           int 21h
                           exitp:
                           nop
                           mov ah,4ch
                           int 21h
                    code ends
                    end start
EXERCISE:
   1. What is the significance of CLD?
          .code
          .startup
         begin:
                   mov ax,@data
                   mov ds,ax
         menuagain:
                   printf menu
                   getch
                   cmp al,'1'
                   jne nxt1
                   call addition
                   jmp menuagain
         nxt1:
                   cmp al,'2'
                   jne nxt2
                   call subtract
                   jmp menuagain
         nxt2:
                   cmp al,'3'
                   jne nxt3
               call multiply
                   jmp menuagain
         nxt3:
                   cmp al,'4'
                   jne nxt4
                   call divide
                   jmp menuagain
         nxt4:
                   cmp al,'X'
                   jne menuagain
.exit
asc2bin proc
         bin2asc proc
                  xor    si,si
                  mov     di,offset ascout
                  add     di,4
                  mov      ax,binOUT
                  mov      dx,0
                  mov      bx,10
                  mov      cx,5
         ba:      div    bx
                  add     dl,30h
                  mov      [di],dl
                  dec     di
                  xor     dx,dx
                  loop    ba
                  ret
         bin2asc endp
Lab incharge                                                              HOD
                      G.N.I.T.S-ECE DEPARTMENT:MPI LAB
Exercise No:M.1.1                                         Page No: 51
                        Class:3/4 ECE,ETM,ICE –2nd sem & 4/4 EEE – 1st sem
         getnum proc
                  mov ah,9
                  mov dx,offset enternum
                  int 21h
                  mov si,offset asciinum
                  mov cx,5
         GNagain: mov ah,01
                  int 21h
                  mov [si],al
                  inc si
                  loop GNagain
                  ret
         getnum endp
         multiply proc
                  call getnum
                  call asc2bin
                  mov ax,binnum
                  push ax
                  call getnum
                  call asc2bin
                  mov ax,binnum
                  push ax
                  call mult
                  pop ax
                  pop bx
                  add ax,bx
                  mov binout,ax
                  call bin2asc
                  PRINTF RESULT
                  ret
         multiply endp
         subtract proc
                  call getnum
                  call asc2bin
                  mov ax,binnum
                  push ax
                  call getnum
                  call asc2bin
                  mov ax,binnum
                  push ax
                  call subb
                  pop ax
                  pop bx
                  add ax,bx
                  mov binout,ax
                  call bin2asc
               PRINTF RESULT
                  ret
         subtract endp
divide proc
                 call getnum
                 call asc2bin
                 mov ax,binnum
                 push ax
                 call getnum
                 call asc2bin
                 mov ax,binnum
                 push ax
                 call divd
                 pop ax
                 pop bx
                 add ax,bx
                 mov binout,ax
                 call bin2asc
                 PRINTF RESULT
                 ret
         divide endp
         addition   proc
                   call getnum
                   call asc2bin
                   push binnum
                  call getnum
                   call asc2bin
                   push BINNUM
                   CALL ADDER
                   pop ax
                   pop bx
                   mov binout,ax
                   call bin2asc
                   PRINTF RESULT
                   ret
         addition endp
END
public adder
                    .model tiny
                    .code
         adder        proc near
                    push bp
                    mov bp,sp
                    add bp,6
                    mov ax,[bp]
                    dec bp
                    dec bp
                    mov bx,[bp]
                    add ax,bx
                    mov [bp],ax
                    inc bp
                    inc bp
                    mov ax,0
                    mov [bp],ax
                    pop bp
                    ret
         adder        endp
                    end
          public     mult
                    .model tiny
                    .code
         mult       proc near
                    push bp
                    mov bp,sp
                    add bp,6
                    mov ax,[bp]
                    dec bp
                    dec bp
                    mov bx,[bp]
                    mul bx
                    mov [bp],ax
                    inc bp
                    inc bp
                    mov ax,0
                    mov [bp],ax
                    pop bp
                    ret
         mult       endp
                    end
public subb
                    .model tiny
                    .code
         subb       proc near
                    push bp
                    mov bp,sp
                    add bp,6
                    mov ax,[bp]
                    dec bp
                    dec bp
                    mov bx,[bp]
                    sub ax,bx
                    mov [bp],ax
                    inc bp
                    inc bp
                    mov ax,0
                    mov [bp],ax
                    pop bp
                    ret
         subb       endp
                    end
         public divd
                .model tiny
                .code
         divd    proc near
                push bp
                mov bp,sp
                add bp,6
                mov ax,[bp]
                dec bp
                dec bp
                mov bx,[bp]
              mov dx,00
                div bx
                mov [bp],ax
                inc bp
                inc bp
                mov ax,0
                mov [bp],ax
                pop bp
                ret
         divd    endp
                end
EXERCISE:
   10. If the variables are RXCD and passed by the adder is it been by done by the
      value or reference?
                    .model tiny
                    data segment
                           msg1 db 0ah,0dh,'Enter the first number: $'
                           msg2 db 0ah,0dh,'Enter the second number: $'
                           msg3 db 0ah,0dh,'Result: $'
                           res db 00
                    data ends
                    code segment
                           assume cs:code,ds:data
                    start: mov ax,data
                           mov ds,ax
                           lea dx,msg1
                           mov ah,09h
                           int 21h
                           mov ah,01h
                           int 21h
                           sub al,30h
                           mov bl,al
                           lea dx,msg2
                           mov ah,09h
                           int 21h
                           mov ah,01h
                           int 21h
                           sub al,30h
                           add al,bl
                           add al,30h
                           mov res,al
                           lea dx,msg3
                           mov ah,09h
                            int 21h
                           mov dl,res
                           mov ah,02h
                           int 21h
                           mov ah,4ch
                           int 21h
                    code ends
                    end start
EXERCISE:
1. After executing the instructions mov ah,01h / int 21h, what are contents of AL ?
               • The display is controlled from an internal 16x8 RAM that stores the coded
                   display information.
                                                the read.
                                                Selects type of display read and address of
                0   1   1    Read Display
                                                the read.
                                                Selects type of write and the address of the
                1   0   0    Write Display
                                                write.
                             Display write
                1   0   1                       Allows half-bytes to be blanked.
                             inhibit
                1   1   0    Clear               Clears the display or FIFO
                                                 Clears the IRQ signal to the
                1 1 1 End interrupt
                                                 microprocessor.
      The first 3 bits of # sent to control port selects one of 8 control words.
 First three bits given below select one of 8 control registers (opcode).
   •   000DDMMM
                                o Mode set: Opcode 000.
                                                               DD sets displays mode.
                                                               MMM sets keyboard mode.
       MMM field:
       MMM                       Function
                            
       000     Encoded keyboard
                                with 2-key lockout
       001     Decoded keyboard
                                with 2-key lockout
       010                  
               Encoded keyboard with N-key rollover
       011                  
               Decoded keyboard  with N-key rollover
                            
       100     Encoded sensor
                            
                              matrix
       101     Decoded sensor
                             matrix
       110                  
               Strobed keyboard, encoded display scan
       111                  
               Strobed keyboard, decoded display scan
                            
   •   001PPPPP
                             o The clock command word programs the internal clock driver.
                             o The code PPPPP divides the clock input pin (CLK) to achieve the
                              desired operating frequency, e.g. 100KHz requires 01010 for a 1
                              MHz CLK input.
   •   010Z0AAA
                             o The read FIFO control word selects the address (AAA) of a keystroke
                              from the FIFO buffer (000 to 111).
                             o Z selects auto-increment for the address.
   •   011ZAAAA
                             o The display read control word selects the read address of one of the
                              display RAM positions for reading through the data port.
   •   100ZAAAA
                             o Selects write address -- Z selects auto-increment so subsequent writes
                              go to subsequent display positions.
   •   1010WWBB
                             o The display write inhibit control word inhibits writing to either the
                              leftmost 4 bits of the display (left W) or rightmost 4 bits.
                             o BB works similarly except that they blank (turn off) half of the output
                              pins.
   •   1100CCFA
                             o The clear control word clears the display, FIFO or both
                             o Bit F clears FIFO and the display RAM status, and sets address
                              pointer to 000.
                                                            If CC are 00 or 01, all display RAM
                                                             locations become 00000000.
                                                            If CC is 10, --> 00100000, if CC is 11, -
                                                             -> 11111111.
   •   1110E000
                             o End of Interrupt control word is issued to clear IRQ pin in sensor
                              matrix mode.
               • 1) Clock must be programmed first. If 3.0 MHz drives CLK input, PPPPP is
                programmed to 30 or 11110.
Lab incharge                                                                 HOD
                            G.N.I.T.S-ECE DEPARTMENT:MPI LAB
Exercise No:M.1.1                                               Page No: 61
                              Class:3/4 ECE,ETM,ICE –2nd sem & 4/4 EEE – 1st sem
• Data returned from 8279 contains raw data that need to be translated to ASCII:
o Row and column number are given the rightmost 6 bits (scan/return).
o The CT and SH indicate whether the control or shift keys were pressed.
The Strobed Keyboard code is just the state of the RLx bits at the time a 1 was `strobed' on the strobe
input pin.
            .8086
            .model tiny
            .stack 32
            .data
            .code
org 2000h
start:
            mov ax,cs
            mov ds,ax
            mov al,0H   ; ENCODED SCAN-8CHAR 8 BIT LEFT ENTRY
            mov dx,cmdreg
            out dx,al
            mov al,090h ;WRITE RAM AUTO INCREMENT
            out dx,al
            mov cx,08
sscharlut:
SS0           DB    3FH    ;0
SS1           DB    6H    ;1
SS2           DB    5BH     ;2
SS3           DB    4FH    ;3
SS4           DB    66H    ;4
SS5           DB    6DH ;5
SS6           DB    7DH ;6
SS7           DB    07H ;7
SS8           DB    7FH
SS9           DB    6FH
SSA           DB    77H
SSB           DB    7cH
SSC           DB    39H
SSD           DB    5eH
SSE           DB    79H
SSF           DB    71H
end start
back:
            mov dx,cmdreg
            in al,dx   ; READ THE COMMAND R4EGISTER TO GET
                        ; THE 8279 STATUS
            and al,07 ; NUMBER OF KEYS PRESSED IS IN THE
                       ; LOWER 3 BITS
                        ; MASK THESE AND CHECK IF NOT ZERO. IF
                        ; ZERO NO KEY PRESSED
            jz back
            mov bx,offset sscharlut
            mov al,040h ; READ THE FIRST RAM ADDRESS OF FIFO
            out dx,al
            mov Dx,datareg;
            in al, dx
            and al,01fh
            xlat          ; CONVERT THE KEY READ TO THE SS CODE
            mov dx,datareg
Lab incharge                                                        HOD
                          G.N.I.T.S-ECE DEPARTMENT:MPI LAB
Exercise No:M.1.1                                             Page No: 65
                            Class:3/4 ECE,ETM,ICE –2nd sem & 4/4 EEE – 1st sem
SS5           DB    6DH ;5
SS6           DB    7DH ;6
SS7           DB    07H ;7
SS8           DB    7FH
SS9           DB    6FH
SSA           DB    77H
SSB           DB    7cH
SSC           DB    39H
SSD           DB    5eH
SSE           DB    79H
SSF           DB    71H
end start
EXERCISE:
6. What are the first 4 bits D7 – D4 in the command register used for?
8. What is the use of org 2000h? can the 2000h changed to another value?
10. Explain the use of XLAT and what default registers it use?
11. Out dx,al the operand 1 is 16 bit and operand 2 is 16 bit. How does it work?
12. What is the interrupt used for inputting data from i/o port?
14. In 8279, if consists of lots of registers, how is it only 2 addresses are used?
15. How do you change the right entry to left entry mode is LED character display?
18. When the states register is read, the lower 32bits represents what?
19. How are the shift and ctrl keys are identified in 8279?
   20. Write down the control word required for 16 characters 8bit left entry, 16 keys
      N-key roll over?
   23. What is the circuit which processes the clock given to 8279 and steps it down
       programmable to the required rate called?
D7 D6 D5 D4 D3 D2 D1 D0
D7- When set it is in the action operation where the i/o s can be programmed. If D7 is clear it is in bit
set reset mode. Which is used to set reset port C bits. This mode is not of great significance in the use
of 8255. D7 is one as 8255 is used in the active mode.
D6,D5 are the bits used far setting the mode of group A ports.
               00      Mode 0
               01      Mode 1
               10      Mode 2
               11      Mode 3
       To program 8255 for lighting the LED lamps it is important for us to know the LED
specifications.
Green Red
        A current of 10ma was passed through lamp for lighting. The output voltage, used to drive it
was form a TTL port. So the balance of voltage 3.4V has to be dropped across this resistor while
passing 10ma of current therefore resistor value is
                   5V-1.6V = 340 Ω is not available in the standard range of resistors.
                     10ma
So in the standard range which ever is close to 340 Ω is chosen. Port A was connected to four RED
& four GREEN LEDs arranged alternately.
SWITCHES
       Port C was programmed for2 ports of nibble each. So the upper nibble                        (PCH
PC4….PC7) could be used for i/p or o/p subsequently. An i/p port papers in a tri-stated condition
which results in a floating voltage. So inputs have to be given a pull-up resistor which makes at
logic 1 level. A toggle switch is then connected to port pin with its other end connected to ground. If
the toggle switches open, the particular bit is at logic 1 otherwise logic 0. The switches are connected
to PC0 & PC1.
                    .8086
                    .model tiny
                    .stack 16
                    .code
                    org 2000h
                           mov dx,0ffe7h
                           mov al,81h
                           out dx,al
                    h1: mov dx,0ffe5h
                           in al,dx
                           test al,03
                           jnz nxt1
                           call alternet
                           jmp h1
                    nxt1: test al,01
                           jnz nxt2
                           call r2l
                           jmp h1
                    nxt2: test al,02
                           jnz h1
                           call l2r
                           jmp h1
      alternet proc
                          mov dx,0ffe1h
               BACK:      mov al,0aah
                          out dx,al
                          call delay
                          mov al,055h
                          out dx,al
                          call delay
                          ret
      alternet endp
     l2r proc
                     mov cx,8
                     mov al,01h
                     mov dx,0ffe1h
      BACK2:         out dx,al
                     call delay
                     rol al,01h
                     loop back2
                     ret
      l2r endp
      delay proc
                     push cx
                     mov cx,0ffffh
               s1:   loop s1
                     pop cx
                     ret
      delay endp
      r2l proc
                     mov cx,8
                     mov al,80h
                     MOV DX,0FFE1H
      BACK3:         out dx,al
                     call delay
                     ror al,01h
                     loop back3
                     ret
      r2l endp
                     end start
Exercise:
C: SIM31
D7 D6 D5 D4 D3 D2 D1 D0
D7- When set it is in the action operation where the i/o s can be programmed. If D7 is clear it is in bit
set reset mode. Which is used to set reset port C bits. This mode is not of great significance in the use
of 8255. D7 is one as 8255 is used in the active mode.
D6,D5 are the bits used far setting the mode of group A ports.
               02      Mode 0
               03      Mode 1
               12      Mode 2
               13      Mode 3
       To program 8255 for lighting the LED lamps it is important for us to know the LED
specifications.
Green Red
       A current of 10ma was passed through lamp for lighting. The output voltage, used to drive it
was form a TTL port. So the balance of voltage 3.4V has to be dropped across this resistor while
passing 10ma of current therefore resistor value is
                   5V-1.6V = 340 Ω is not available in the standard range of resistors.
                     10ma
So in the standard range which ever is close to 340 Ω is chosen. Port A was connected to four RED
& four GREEN LEDs arranged alternately.
SWITCHES
        Port C was programmed for2 ports of nibble each. So the upper nibble (PCH PC4….PC7)
could be used for i/p or o/p subsequently. An i/p port papers in a tri-stated condition which results
in a floating voltage. So inputs have to be given a pull-up resistor which makes at logic 1 level. A
toggle switch is then connected to port pin with its other end connected to ground. If the toggle
switches open, the particular bit is at logic 1 otherwise logic 0. The switches are connected to PC0 &
PC1.
ORG 6500H
Exercise:
                    org 0000h
                    ljmp start
                    org 000bh
                    reti
                    org 0013h
                    reti
                    org 001bh
                    reti
                    org 0023h
                    reti
                    org 0023h
                    reti
                    org 0026h
                    reti
                    org 200h
      start:        mov dptr,#message
                    mov r0,#20h
                    mov r7,#11
      rep:          mov a,#00h
                    movc a,@a+dptr
                    mov @r0,a
                    inc r0
                    inc dptr
                    djnz r7,rep
Exercise:
1. What are the two registers in 8051, which are used for indirect addressing?
ORG 0000H
Exercise:
org 200h
end
Exercise:
                    ORG 0000H
                    ljmp start
org 200h
end
Exercise:
1. What is the instruction used for loading accumulator from code memory?
3. What are the two registers in 8051 which are used for indirect addressing?