PART A
; to generate FIBONACCI series(11A)
.model small
.stack 200
.data
n dw 6
fib db 30 dup(?)
.code
mov ax,@data
mov ds,ax
lea si,fib
mov [si],0
mov [si+1],1
mov cx,n
sub cx,2
back:
mov al,[si]
add al,[si+1]
mov [si+2],al
inc si
loop back
int 3
; initialization of data segment
; inside the code segment
;initializing first number
;initializing second number
; adding first & second number
; storing at as third number
; break point interrupt
end
BNMIT/CSE/Mp Lab Manual
; sort the no using bubble sort(3A)
.model small
.stack 200
.data
a db 23h,43h,12h,55h,11h
len dw ($-a)
.code
mov ax,@data
; initialization of data segment
mov ds,ax
; inside code segment
mov bx,len
dec bx
outl:
mov cx,bx
mov si,0
inl:
mov al,a[si]
inc si
cmp al,a[si]
jb next
xchg al,a[si]
mov a[si-1],al
next:
loop inl
; outer loop from 0 to n-1
; inner loop from 0 to outer loop
; comparison of 2 elements
; if greater exchange
dec bx
jnz outl
mov ah,4ch
int 21h
; interrupt to end the code segment
end
BNMIT/CSE/Mp Lab Manual
;Binary Search-1A
.model small
.stack 200
.data
a dw 1111h,3333h,5555h,7777h,9999h
len dw ($-a)/2
key dw 2333h
msg1 db 10,13,'successful search','$'
msg2 db 10,13,'Unsuccessful search','$'
.code
mov ax,@data
mov ds,ax
mov ax,key
mov si,0
mov di,len
dec di
again:
cmp si,di
ja notfound
mov bx,si
add bx,di
shr bx,01
mov bp,bx
shl bx,01
cmp ax,a[bx]
je found
jc midbig
inc bp
mov si,bp
jmp again
midbig:
dec bp
mov di,bp
jmp again
; Initialization of Data Segment
; Inside Code Segment
; ax = Search key
; si = low
; di = high
; low > high
; bx = low + high
; bx = mid
; pointer adjustment
; Searching for key element
; mid = key
; si(low) = mid + 1
; di (high) = mid - 1
found:
lea dx,msg1
jmp exit
BNMIT/CSE/Mp Lab Manual
notfound:
lea dx,msg2
exit:
mov ah,09h
int 21h
mov ah,4ch
int 21h
; interrupt to display the
; message
; interrupt to end the
; program
end
BNMIT/CSE/Mp Lab Manual
; linking of 2 macros which are (2A) included as library files with
include c:\masm\jalaja\2a1.mac
include c:\masm\jalaja\2a2.mac
.model small
.stack 200
.data
msg db 10,13,"enter the data end with enter key",'$'
a db 10 dup(?)
.code
mov ax,@data
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
; initialization of data segment
; inside code segment
; interrupt to print
; the message
mov si,0
again:
read
cmp al,13
je disp
; macro to accept i/p
; till ENTER key is pressed
mov a[si],al
inc si
jmp again
disp:
mov dl,0ah
mov ah,02
int 21h
; interrupt to move the
; cursor to next line
mov cx,si
mov si,0
begin:
mov dl,a[si]
writ
inc si
loop begin
mov ah,4ch
int 21h
end
; macro to print a character
BNMIT/CSE/Mp Lab Manual
;------2a1.mac-----read macro
mov ah,01
int 21h
; interrupt to accept i/p
endm
;-----2a2.mac-----writ macro
mov ah,02
int 21h
; interrupt to print a character
endm
BNMIT/CSE/Mp Lab Manual
; Factorial of a number using(8a)
; recursive approach
.model small
.stack 200
.data
n dw 4
res dw ?
.code
mov ax,@data
mov ds,ax
; initialization of data segment
; inside code segment
mov ax,n
call fact
int 3
; procedure finding the factorial
; break point interrupt
;---factorial procedure--fact proc
cmp ax,00
je exit
push ax
dec ax
call fact
; procedure called recursively
pop ax
mul res
mov res,ax
ret
exit:
mov res,1
ret
fact endp
end
BNMIT/CSE/Mp Lab Manual
; 9A Write an ALP to compute NCR using recursive procedure
; nCr = (nC(r-1) * (n+1-r))/r
.model small
.stack 200
.data
n dw 4
r dw 2
n dw ?
.code
mov ax,@data
mov ds,ax
mov ax,n
mov bx,r
call ncrrec
RA1: mov ah,4ch
int 21h
ncrrec proc
cmp bx,0
je exit
push ax
push bx
dec bx
call ncrrec
RA2:
pop bx
pop ax
inc ax
sub ax,bx
mul ncr
div bx
mov ncr,ax
ret
; n+1
; n+1-r
;ax <- ax * ncr
; ax <- ax/bx
exit:
mov ncr,1
ret
ncrrec endp
; ncr <- 1
end
BNMIT/CSE/Mp Lab Manual
; program to create and to delete a file (15A)
print macro msg
lea dx,msg
mov ah,09h
int 21h
endm
.model small
.stack 200
.data
fname db 'c:\masm\jalaja\name.txt',0
m2 db 10,13,'enter 1) to create 2) to delete','$'
m3 db 10,13,'FILE CREATED','$'
m4 db 10,13,'FILE NOT CREATED','$'
m5 db 10,13,'FILE DELETED','$'
m6 db 10,13,'FILE NOT FOUND','$'
m7 db 10,13,'INVALID CHOICE','$'
op db ?
fhandle dw ?
.code
mov ax,@data
; initialization of data segment
mov ds,ax
; into code segment
mov ah,00
mov al,02
int 10h
; interrupt to clear the screen
print m2
mov ah,01
int 21h
mov op,al
; macro to print the message
; interrupt to accept the choice
cmp op,'1'
je create
cmp op,'2'
je delete
jmp invalid
create:
mov ah,3ch
xor cx,cx
lea dx, fname
int 21h
jc cerror
; interrupt to create the file
; initialization into specified seg
BNMIT/CSE/Mp Lab Manual
print m3
jmp ter
cerror:
print m4
jmp ter
delete:
mov ah,41h
lea dx,fname
int 21h
jc derror
; interrupt to delete the file
print m5
jmp ter
derror:
print m6
jmp ter
invalid:
print m7
ter:
mov ah,4ch
int 21h
end
BNMIT/CSE/Mp Lab Manual
10
; to reverse and check for PALINDROME(5A)
print macro msg
lea dx,msg
mov ah,09h
int 21h
endm
; interrupt to print the message
.model small
.stack 200
.data
msg1 db 10,13,'string is PALINDROME','$'
msg2 db 10,13,'string is NOT PALINDROME','$'
str1 db 'diddd$'
len dw ($-str1-1)
str2 db 20 dup(?)
.code
mov ax,@data
mov ds,ax
mov es,ax
; initializing data & extra segment
; inside code segment
lea si,str1
lea di,str2
mov cx,len
add si,len
dec si
back:
mov al,[si]
mov [di],al
inc di
dec si
loop back
cld
lea si,str1
lea di,str2
mov cx,len
repe cmpsb
jz pali
; reversing the string
; DF=0
; compare string byte by byte if equal
lea dx,msg2
jmp exit
BNMIT/CSE/Mp Lab Manual
11
pali:
lea dx,msg1
exit:
mov ah,09h
int 21h
; interrupt to print the message
mov ah,4ch
int 21h
; interrupt to end the program
end
BNMIT/CSE/Mp Lab Manual
12
; searching for sub-string in main string(10A)
.model small
.stack 200
.data
msg1 db 'this is a day'
len1 dw ($-msg1)
msg2 db 'ias'
len2 dw ($-msg2)
msg3 db 10,13,'SUBSTRING IS PRESENT','$'
msg4 db 10,13,'SUBSTRING IS NOT PRESENT','$'
.code
mov ax,@data
; initialization of data & extra segment
mov ds,ax
; inside code segment
mov es,ax
mov bx,len1
sub bx,len2
lea si,m1
lea di,m2
cld
;
;
;
; initialization
again:
push si
push di
mov cx,len2
repe cmpsb
pop di
pop si
jz found
; comparing string byte by byte
inc si
dec bx
jnz again
lea dx,msg4
jmp exit
found:
lea dx,msg3
exit:
mov ah,09h
int 21h
; interrupt to print the message
mov ah,4ch
int 21h
end
BNMIT/CSE/Mp Lab Manual
13
;string comparison and print its length(6a)
;---macro to print the message----print macro msg
lea dx,msg
mov ah,09h
int 21h
endm
.model small
.stack 200
.data
m1 db 10,13, enter 1st string :$
str1buf db 50.0
str1 db 50 dup(?)
m2 db 10,13, enter 1st string :$
str2buf db 50.0
str2 db 50 dup(?)
m3 db 10,13,the length of 1st string :
len1 db ?,?,$
m4 db 10,13,the length of 1st string :
len2 db ?,?,$
m5 db 10,13,strings are equal $
m6 db 10,13, strings are not equal $
.code
mov ax,@data
mov ds,ax
mov es,ax
print m1
lea dx,str1buf
mov ah,0ah
int 21h
mov al, str1buf+1
mov ah,00
aam
;
;
;accepting 1st string
;
;
;
; unpacking the data
or ax,3030h
mov len1,ah
mov len1+1,al
print m3
BNMIT/CSE/Mp Lab Manual
; getting ASCII equivalent of unpacked data
14
print m2
lea dx,str2buf
mov ah,0ah
int 21h
;
;
;accepting 2nd string
;
mov al, str2buf+1
mov ah,00
aam
;
;
; unpacking the data
or ax,3030h
mov len2,ah
mov len2+1,al
print m4
; getting ASCII equivalent of unpacked data
mov al,str1buf+1
cmp al,str2buf+1
jne notequal
cld
lea si,str1
lea di,str2
mov ch,00
mov cl,strbuf+1
repe cmpsb
je equal
notequal:
print m6
jmp exit
equal:
print m5
exit:
mov ah,4ch
int 21h
end
BNMIT/CSE/Mp Lab Manual
15
; to accept the name and display at(7a)
; specified position on the screen
.model small
.stack 200
.data
blank10 db '
$'
prompt db 'what is your name? :$'
rowpos db 10
colpos db 27
myname db 50,0,50 dup(?)
.code
mov ax,@data
; initialization of data segment
mov ds,ax
; inside code segment
mov cx,200
ag:
lea dx,blank10
mov ah,09
int 21h
loop ag
; interrupt filling
; entire screen with blank space
; placing cursor at bottom of the screen
mov dh,rowpos
mov dl,colpos
mov ah,02
mov bh,0
int 10h
; dh=row address
; dl=column address
lea dx,prompt
mov ah,09h
int 21h
lea dx,myname
mov ah,0ah
int 21h
; bh=page 0
; interrupt to place the cursor
; interrupt to print the message
; interrupt to accept the message
mov ah,4ch
int 21h
end
BNMIT/CSE/Mp Lab Manual
16
; to display SYSTEM TIME(12A)
.model small
.stack 200
.data
msg db ' hrs : min','$'
.code
mov ax,@data
mov ds,ax
mov ah,2ch
int 21h
; interrupt to
; accept system time
mov al,ch
mov si,02
l1:
mov ah,00
aam
or ax,3030h
push ax
mov dl,ah
mov ah,02h
int 21h
; converting to ascii
; printing on to screen
pop ax
mov dl,al
mov ah,02
int 21h
dec si
jz exit
lea dx,msg
mov ah,09h
int 21h
; interrupt to print the message
mov al,cl
jmp l1
exit:
mov ah,4ch
int 21h
; interrupt to end code segment
end
BNMIT/CSE/Mp Lab Manual
17
; to position the cursor (14A)
; at specified row and column
;----macro to read row and col---readnum macro num
mov ah,01h
; interrupt to read first number
int 21h
sub al,'0'
mov cl,4
ror al,cl
mov num,al
mov ah,01
int 21h
sub al,'0'
add num,al
endm
; convertion to decimal from ascii
; placing it to tens place from unit place
; accepting the second digit
; convertion to decimal from ascii
; adding to previous data placed at tens place
;----macro to print msg ----print macro msg
lea dx,msg
mov ah,09h
int 21h
endm
.model small
.stack 200
.data
row db ?
col db ?
m1 db 10,13,'enter the row:','$'
m2 db 10,13,'enter the col:','$'
m3 db cursor is here $
.code
mov ax,@data
; initialization of data segment
mov ds,ax
; into code segment
print m1
readnum row
; macro to print the message
;macro to read 2-digit number
print m2
readnum col
; macro to print the message
;macro to read 2-digit number
mov ah,00
mov al,02
BNMIT/CSE/Mp Lab Manual
; interrupt to clear the screen
18
int 10h
mov ah,02
mov dh,row
mov dl,col
mov bh,00
int 10h
; interrupt to position the cursor at specified
; row & column
print m3
mov ah,01
int 21h
mov ah,4ch
int 21h
end
BNMIT/CSE/Mp Lab Manual
19
; to accept alphanumeric character(4A)
; and display its ASCII EQUIVALENT
.model small
.stack 200
.data
ascii db 2 dup(?)
msg db "enter the alph or numeric data",'$'
.code
mov ax,@data
; initialization of data segment
mov ds,ax
; inside code segment
mov ah,00
mov al,02
int 10h
; to clear the screen
lea dx,msg
mov ah,09h
int 21h
; interrupt to print the message
mov ah,01h
int 21h
mov bl,al
; interrupt to accept an i/p
and al,0f0h
mov cl,4
shr al,cl
cmp al,09
jle ad30
; mask off LSB 4-bits & retain higher 4-bits
; conversion to its ascii value
add al,07
ad30:
add al,30h
mov ascii,al
mov al,bl
and al,0fh
cmp al,09h
jle sum30
add al,07
sum30:
add al,30h
mov ascii+1,al
mov dh,0ch
mov dl,28h
; retaining lower 4-bits
; conversion to its ascii value
; positioning row
; and column to centre
BNMIT/CSE/Mp Lab Manual
20
mov bh,00
mov ah,02h
int 10h
;of the screen in page 0
mov bl,2
mov si,0
ag:
mov dl,ascii[si]
mov ah,02
int 21h
; interrupt to print a character
inc si
dec bl
jnz ag
mov ah,4ch
int 21h
; interrupt to end the program
end
BNMIT/CSE/Mp Lab Manual
21
; to generate DECIMAL UP counter 00 99(13A)
.model small
.stack 200
.code
mov al,99h
mov cx,100
rpt:
add al,1
daa
push ax
push cx
call display
call delay
pop cx
pop ax
loop rpt
; initial value
; count =100
; conversion to BCD
; procedure to display the number
mov ah,4ch
int 21h
;------display procedure-----display proc
mov dh,15
mov dl,30
mov bh,00
mov ah,02
int 10h
mov ch,al
and al,0f0h
mov cl,4
shr al,cl
add al,30h
mov dl,al
mov ah,02
int 21h
mov al,ch
and al,0fh
add al,30h
mov dl,al
mov ah,02h
; extracting 1st MSB digit
; getting it to units place
; converting to its ascii value
; getting first 4-bits
; converting to ascii
; to display the data
BNMIT/CSE/Mp Lab Manual
22
int 21h
ret
display endp
delay proc
push bx
push cx
mov bx,2000h
loc1:
mov cx,0fffh
loc2:
loop loc2
dec bx
jnz loc1
pop cx
pop bx
ret
delay endp
end
BNMIT/CSE/Mp Lab Manual
23
PART B
; to check for odd or even(1B)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
msg db 'press any key to come to dos prompt','$'
.code
mov ax,@data
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
; interrupt to display the message
mov al,8ah
mov dx,ctrl
out dx,al
; control word decision
; pa=o/p
; pb=i/p
mov dx,pb
in al,dx
; accept the i/p
bg:
mov cx,8
mov bl,0
ag:
rol al,1
jnc noinbl
inc bl
noinbl:
loop ag
mov al,bl
mov dx,pc
out dx,al
; o/p through port c
mov dx,pa
ror bl,1
jc disp00
BNMIT/CSE/Mp Lab Manual
24
mov al,0ffh
jmp nxt
disp00:
mov al,00
nxt:
out dx,al
; o/p through port a
mov dl,0ffh
mov ah,06h
int 21h
jz bg
; interrupt that waits until any key
; or i/p is accepted
mov ah,4ch
int 21h
end
BNMIT/CSE/Mp Lab Manual
25
; BCD RING COUNTER(2B1)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
msg db 'press any key to come to dos prompt$'
.code
mov ax,@data
; initialization of data segment in CS
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
mov al,8ah
mov dx,ctrl
out dx,al
; interrupt to display the message
; control word decision
mov al,01
mov dx,pa
back:
push ax
push dx
out dx,al
call delay
mov dl,0ffh
mov ah,06h
int 21h
jnz exit
pop dx
pop ax
rol al,1
jmp back
; interrupt that waits until any key is pessed
exit:
mov ah,4ch
int 21h
BNMIT/CSE/Mp Lab Manual
26
;-----delay procedure-----delay proc
mov di,2000h
tere:mov cx,0ffffh
here:loop here
dec di
jnz tere
ret
delay endp
; procedure with suitable delay
end
BNMIT/CSE/Mp Lab Manual
27
; BCD UP(1)-DOWN(1) COUNTER(2B2)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
msg db 'press any key to come to dos prompt$'
.code
mov ax,@data
; initialization of data segment in CS
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
; interrupt to display the message
mov al,8ah
mov dx,ctrl
out dx,al
; control word decision
mov al,0
back:
push ax
mov dx,pa
out dx,al
call delay
mov dl,0ffh
mov ah,06h
int 21h
jnz exit
mov dx,pb
in al,dx
ror al,1
pop ax
jc up
down:
sub al,1
das
jmp back
up:
add al,1
daa
; interrupt that waits until any key is pessed
; accepting the i/p from port B
BNMIT/CSE/Mp Lab Manual
28
jmp back
exit:
mov ah,4ch
int 21h
;---delay procedure----delay proc
mov di,2000h
tere:mov cx,0ffffh
here:loop here
dec di
jnz tere
ret
delay endp
; procedure with suitable delay
end
BNMIT/CSE/Mp Lab Manual
29
; MULTIPLICATION OF 8 bit * 8 bit(3B)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
m1 db 10,13, enter 1st data from port B$
m2 db 10,13, enter 2nd data from port B$
msg db 'press any key to come to dos prompt$'
.code
mov ax,@data
; initialization of data segment in CS
mov ds,ax
mov al,8ah
mov dx,ctrl
out dx,al
; control word decision
lea dx,m1
mov ah,09h
int 21h
; interrupt to display the message
bg:
mov dx,pb
in al,dx
mov bl,al
; accepting the 1st i/p from port B
call delay
lea dx,m2
mov ah,09h
int 21h
mov dx,pb
in al,dx
; interrupt to display the message
; accepting the 2nd i/p from port B
mul bl
push ax
mov dx,pa
mov al,ah
out dx,al
BNMIT/CSE/Mp Lab Manual
30
call delay
pop ax
mov dx,pa
out dx,al
mov ah,4ch
int 21h
delay proc
mov di,2000h
tere:mov cx,0ffffh
here:loop here
dec di
jnz tere
ret
delay endp
; procedure with suitable delay
end
BNMIT/CSE/Mp Lab Manual
31
;TO DISPLAY FIRE AND HELP ALTERNATIVELY(4B)
.model small
.stack 200
.data
pa=0d880h
pb=0d881h
; port address assigned in order
pc=0d882h
ctrl=0d883h
msg db 'press any to come to dos prompt$'
fire db 86h,0ceh,0cfh,8eh
blnk db 0ffh,0ffh,0ffh,0ffh
help db 8ch,0c7h,86h,89h
.code
mov ax,@data
; initialization of data segment in CS
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
; interrupt to display the message
mov dx,ctrl
mov al,80h
out dx,al
start:
lea si,fire
call disp
call delay
; control word decision
lea si,blnk
call disp
call delay
lea si,help
call disp
call delay
mov ah,01
int 16h
jz start
; interrupt that waits until any key is pessed
mov ah,4ch
int 21h
;-----display procedure---disp proc
BNMIT/CSE/Mp Lab Manual
32
mov cx,4
nxtchr:
mov bl,8
mov al,[si]
nxtbit:
rol al,1
mov dx,pb
out dx,al
push ax
mov dx,pc
mov al,00
out dx,al
; giving the clock pulse
mov al,11h
out dx,al
pop ax
dec bl
jnz nxtbit
inc si
loop nxtchr
ret
disp endp
;-----delay procedure-----delay proc
mov di,0ffffh
tere:mov cx,2000h
here:loop here
dec di
jnz tere
ret
delay endp
; procedure with suitable delay
end
BNMIT/CSE/Mp Lab Manual
33
;TO DISPLAY 12 char in rolling fashion(5B)
.model small
.stack 200
.data
pa=0d880h
pb=0d881h
; port address assigned in order
pc=0d882h
ctrl=0d883h
msg db 'press any to come to dos prompt$'
table db 0c0h,0f9h,0a4h,0b0h,99h
db 92h,82h,0f8h,80h,98h
.code
mov ax,@data
mov ds,ax
; initialization of data segment in CS
lea dx,msg
mov ah,09h
int 21h
; interrupt to display the message
mov dx,ctrl
mov al,80h
out dx,al
start:
lea si,table
mov cx,10
nxtchr:
mov al,[si]
call disp
call delay
inc si
loop nxtchr
mov ah,01
int 21h
jz start
; control word decision
; interrupt that waits until any key is pessed
mov ah,4ch
int 21h
BNMIT/CSE/Mp Lab Manual
34
;-----display procedure---disp proc
mov bl,8
nxtbit:
rol al,1
mov dx,pb
out dx,al
push ax
mov dx,pc
mov al,00
out dx,al
; giving the clock pulse
mov al,11h
out dx,al
pop ax
dec bl
jnz nxtbit
ret
disp endp
;-----delay procedure-----delay proc
mov di,0ffffh
tere:mov bx,2000h
here:dec bx
jnz here
dec di
jnz tere
ret
delay endp
; procedure with suitable delay
end
BNMIT/CSE/Mp Lab Manual
35
;Convert a 16 bit binary or hexa value to BCD and display it from left to right and
right to left for specified number of times on a 7 seg display unit.
.model small
.stack 200
.data
pa=0d880h
pb=0d881h
; port address assigned in order
pc=0d882h
ctrl=0d883h
msg db 'press any to come to dos prompt$'
table db 0c0h,0f9h,0a4h,0b0h,99h
db 92h,82h,0f8h,80h,98h
msg db 0ffh,0ffh,0ffh,0ffh, ?,?,?,?,?,0ffh,0ffh,0ffh,0ffh
num dw 0ffffh
bcd db 5 dup(?)
.code
mov ax,@data
mov ds,ax
mov al,80h
mov dx,ctrl
out dx,al
lea dx,m1
mov ah,09
int 21h
mov cx,num
mov ax,0
mov bl,0
jcxz exit
ag:
add al,01
daa
jnc noinc
add ah,01
mov al,ah
daa
mov ah,al
mov al,00
jnc noinc
BNMIT/CSE/Mp Lab Manual
36
inc bl
noinc:
loop ag
exit:
mov bcd,bl
mov dx,ax
mov bl,10h
mov ah,0
mov al,dl
div bl
mov bcd+3,ah
mov bcd+4,al
mov ah,0
mov al,dh
div bl
mov bcd+1,ah
mov bcd+2,al
mov si,bcd
lea di,msg+8
lea bx,table
mov cx,5
next:
mov al,[si]
xlat
mov [di],al
dec di
inc si
loop next
start:
mov bh,10h
lea di,msg
back :
mov si,di
push bx
call disp
call delay
call kbhit
pop bx
inc di
dec bh
jnz back
BNMIT/CSE/Mp Lab Manual
37
mov bh,10
lea di,msg+9
back1:
mov si,di
push bx
call disp
call delay
pop bx
dec di
dec bh
jnz back1
jmp start
;-----display procedure---disp proc
mov cx,4
nxtchr:
mov bl,8
mov al,[si]
nxtbit:
rol al,1
mov dx,pb
out dx,al
push ax
mov dx,pc
mov al,00
out dx,al
; giving the clock pulse
mov al,0ffh
out dx,al
pop ax
dec bl
jnz nxtbit
inc si
loop nxtchr
ret
disp endp
BNMIT/CSE/Mp Lab Manual
38
/;------ for repetation and ending purpose------kbhit proc
mov ah,01
int 16h
jnz exit
ret
exit:
mov ah,4ch
int 21h
kbhit endp
;-----delay procedure-----delay proc
push di
push bx
mov di,0ffffh
tere:mov bx,2000h
here:dec bx
jnz here
dec di
jnz tere
; procedure with suitable delay
pop bx
pop di
ret
delay endp
end
BNMIT/CSE/Mp Lab Manual
39
; STEPPER MOTOR IN CLOCK WISE(7B)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
n dw 10
msg db 'rotation in clock wise','$'
.code
mov ax,@data
; initialization of data segment in CS
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
; interrupt to display the message
mov al,80h
mov dx,ctrl
out dx,al
; control word decision
mov cx,n
mov dx,pc
mov al,88h
ag:
out dx,al
push cx
call delay
pop cx
ror al,1
loop ag
; output the data through port
mov ah,4ch
int 21h
;---delay procedure--delay proc
mov di,2000h
tere:mov cx,0ffffh
here:loop here
dec di
jnz tere
ret
delay endp
end
BNMIT/CSE/Mp Lab Manual
; procedure with suitable delay
40
; STEPPER MOTOR IN ANTI-CLOCK WISE(8B)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
n dw 10
msg db 'rotation in anti-clock wise','$'
.code
mov ax,@data
; initialization of data segment
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
mov al,80h
mov dx,ctrl
out dx,al
; control word decision
mov cx,n
mov dx,pc
mov al,88h
ag:
out dx,al
push cx
call delay
pop cx
rol al,1
loop ag
; output the data through port
mov ah,4ch
int 21h
;---delay procedure--delay proc
mov di,2000h
tere:mov cx,0ffffh
here:loop here
dec di
jnz tere
ret
delay endp
end
BNMIT/CSE/Mp Lab Manual
; procedure with suitable delay
41
; STEPPER MOTOR IN CLOCK WISE(n steps)(9B)
; & ANTI-CLOCK WISE(n-steps)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
n dw 10
msg db 'rotation in clock & anti clock wise','$'
.code
mov ax,@data
; initialization of data segment
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
; interrupt to display the message
mov al,80h
mov dx,ctrl
out dx,al
; control word decision
mov cx,n
mov dx,pc
mov al,88h
ag:
out dx,al
push cx
call delay
pop cx
ror al,1
loop ag
; output the data through port
mov cx,n
mov dx,pc
mov al,88h
bg:
out dx,al
push cx
call delay
pop cx
rol al,1
loop bg
BNMIT/CSE/Mp Lab Manual
42
mov ah,4ch
int 21h
;---delay procedure--delay proc
mov di,2000h
tere:mov cx,0ffffh
here:loop here
dec di
jnz tere
ret
delay endp
end
BNMIT/CSE/Mp Lab Manual
; procedure with suitable delay
43
; GENERATION OF SINE WAVE(12B) value = 128 + 128 sine @
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
table db 128,150,171,192,210,226,238,248,254,254,248
db 238,226,210,192,171,150,128,105,84,64,45,29,17,7,1,0,
db 0,1,7,17,29,45,64,84,105
msg db 'press any key to come to dos prompt','$'
.code
mov ax,@data
; initialization of data segment
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
mov dx,ctrl
mov al,80h
out dx,al
start:
mov cx,36
lea si,table
back:
mov al,[si]
mov dx,pa
out dx,al
; interrupt to display the message
; control word decision
; output the data through port
mov dx,pb
out dx,al
inc si
loop back
mov ah,01
int 16h
jz start
mov ah,4ch
int 21h
end
BNMIT/CSE/Mp Lab Manual
44
; GENERATION OF HALF-RECTIFIED WAVE(13B)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
table db 128,150,171,192,210,226,238,248,254,254,248
db 238,226,210,192,171,150,128
msg db 'press any key to come to dos prompt','$'
.code
mov ax,@data
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
mov dx,ctrl
mov al,80h
out dx,al
start:
; initialization of data segment
; interrupt to display the message
; control word decision
mov cx,18
lea si,table
back:
mov al,[si]
mov dx,pa
out dx,al
; output the data through port
mov dx,pb
out dx,al
inc si
loop back
mov cx,18
mov al,128
back2:
mov dx,pa
out dx,al
BNMIT/CSE/Mp Lab Manual
; output the data through port
45
mov dx,pb
out dx,al
loop back2
mov ah,01
int 16h
jz start
mov ah,4ch
int 21h
end
BNMIT/CSE/Mp Lab Manual
46
; GENERATION OF FULL-RECTIFIED WAVE(14B)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
table db 128,150,171,192,210,226,238,248,254,254,248
db 238,226,210,192,171,150,128
msg db 'press any key to come to dos prompt','$'
.code
mov ax,@data
; initialization of data segment
mov ds,ax
lea dx,msg
mov ah,09h
int 21h
mov dx,ctrl
mov al,80h
out dx,al
start:
mov cx,18
lea si,table
back:
mov al,[si]
mov dx,pa
out dx,al
; interrupt to display the message
; control word decision
; output the data through port
mov dx,pb
out dx,al
inc si
loop back
mov ah,01
int 16h
jz start
mov ah,4ch
int 21h
end
mov ah,01
int 16h
BNMIT/CSE/Mp Lab Manual
47
jz start
mov ah,4ch
int 21h
end
mov ah,01
int 16h
jz start
mov ah,4ch
int 21h
end
BNMIT/CSE/Mp Lab Manual
48
; ELEVATOR INTERFACE(15B)
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
.code
mov ax,@data
; initialization of data segment
mov ds,ax
; inside the code segment
mov dx,ctrl
mov al,82h
out dx,al
; control word decision
mov dx,pa
mov al,0
out dx,al
; initializing all leds to 0 or OFF
mov al,0f0h
out dx,al
; 1st led is ON
mov dx,pb
scan:
in al,dx
and al,0fh
cmp al,0fh
jz scan
mov ch,0
findagn:
shr al,1
jnc firid
inc ch
jmp findagn
firid:
mov bh,ch
; accept the i/p
; servicing floor
rol ch,1
add ch,bh
add ch,0f0h
mov al,0f0h
again:
inc al
BNMIT/CSE/Mp Lab Manual
49
mov dx,pa
out dx,al
push cx
call delay
pop cx
cmp ch,al
jne again
down:
mov si,5
back:
push cx
call delay
pop cx
dec si
jnz back
; traversing down ward
; procedure with suitable delay
and al,0fh
out dx,al
or al,0f0h
dngain:
out dx,al
push cx
call delay
pop cx
dec al
cmp al,0efh
jne dngain
mov ah,4ch
int 21h
delay proc
mov di,0ffffh
there:
mov cx,2400h
here:
loop here
dec di
jnz there
ret
delay endp
end
BNMIT/CSE/Mp Lab Manual
; procedure with suitable delay
50
; ROW & COLUMN INFORMATION(10B)
; OF THE KEY PRESSED
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
prompt db 'press any key to come to dos prompt',10,13,'$'
m1 db 'the key pressed is :'
scancode db ?,10,13,'$'
msg db 'the row & col address :'
aski db ?,' ',?,10,13,'$'
table db '0123456789+-*/.%ce'
.code
mov ax,@data
; initialization of data segment
mov ds,ax
mov al,90h
mov dx,ctrl
out dx,al
; control word decision
mov ah,09h
lea dx,prompt
int 21h
; interrupt to display the message
ag:
mov ah,06
mov dl,0ffh
int 21h
jnz quit
; interrupt that waits until any key is pessed
call scan
cmp si,0
je ag
push ax
push bx
mov cl,3
rol bh,cl
add bh,ah
mov al,bh
BNMIT/CSE/Mp Lab Manual
51
lea dx,table
xlat
mov scancode,al
lea dx,m1
mov ah,09h
int 21h
pop bx
pop ax
add bh,30h
mov aski,bh
add ah,30h
mov aski+2,ah
lea dx,msg
mov ah,09h
int 21h
mov di,2fffh
mov cx,0ffffh
here:loop here
dec di
jnz here
jmp ag
; interrupt to display the message
; procedure with suitable delay
quit:
mov ah,4ch
int 21h
;*****SCAN PROCEDURE******
scan proc
mov si,0
mov cx,3
mov bh,0
mov al,80h
nxtrow:
rol al,1
mov bl,al
mov dx,pc
out dx,al
BNMIT/CSE/Mp Lab Manual
; row selection
52
mov dx,pa
in al,dx
; accepting the i/p from port A
cmp al,0
jnz keyid
mov al,bl
inc bh
loop nxtrow
ret
keyid:
mov si,1
mov cx,08
mov ah,0
ag2:
ror al,1
jc skip
inc ah
loop ag2
skip:
ret
scan endp
end
BNMIT/CSE/Mp Lab Manual
53
; SIMPLE CALCULATOR(11B); DOING ADD & SUB
print macro msg
lea dx,msg
mov ah,09h
int 21h
endm
.model small
.stack 200
.data
pa=0d880h
; port address assigned in order
pb=0d881h
pc=0d882h
ctrl=0d883h
result db ?
inputs db 3 dup(?)
msg db 'enter the input as NUM1 +/- NUM2',10,13,'$'
.code
mov ax,@data
; initialization of data segment
mov ds,ax
mov al,90h
mov dx,ctrl
out dx,al
; control word decision
print m1
mov cx,3
mov di,0
ag2:
push cx
ag1:
call scan
cmp si,0
je ag1
mov cl,3
rol bh,cl
add bh,ah
mov inputs[di],bh
mov bp,20000
tere:mov cx,0ffffh
here:loop here
dec bp
BNMIT/CSE/Mp Lab Manual
; procedure with suitable delay
54
jnz tere
inc di
pop cx
loop ag2
mov al,inputs
cmp inputs+1,0ah
jne minus
add al,inputs+2
mov result,al
jmp quit
minus:
sub al,inputs+2
mov result,al
quit:
mov dl,result
add dl,30h
mov ah,02
int 21h
mov ah,4ch
int 21h
;*****SCAN PROCEDURE******
scan proc
mov si,0
mov cx,3
mov bh,0
mov al,80h
nxtrow:
rol al,1
mov bl,al
mov dx,pc
out dx,al
; Row selection
mov dx,pa
in al,dx
; accepting the i/p from port A
cmp al,0
jnz keyid
mov al,bl
inc bh
loop nxtrow
ret
BNMIT/CSE/Mp Lab Manual
55
keyid:
mov si,1
mov cx,08
mov ah,0
agg:
ror al,1
jc skip
inc ah
loop agg
skip:
ret
scan endp
end
BNMIT/CSE/Mp Lab Manual
56