Изучение системы команд микропроцессора Intel 8086
Московский государственный институт электроники и математики
(технический университет)
Курсовая работа по ВТ
Изучение системы команд микропроцессора Intel 8086
и аппаратных особенностей ПЭВМ IBM PC
Листов 7
Задание принял Задание выдал
к исполнению руководитель
ст.гр.А-41
ДДДДДДДДДДДД Дюжев А.А. ДДДДДДДДДДДДД Кулаков В.Г.
Москва 1994 г.
- 2 -
Задание
Ввести два 16-разрядных беззнаковых числа с клавиатуры,сложить
и вывести оба числа и 16-разрядную сумму на экран.
Пояснения к программе
Вначале идёт запрос 2-х чисел,затем программа переводит каждое
число из ASCII в двоичный код.
Процедура преобразования заключается в следующем:
1.Начинают с самого правого байта числа в ASCII-формате и
обрабатывают справа налево.
2.Удаляют тройки из левых шестнадцатиричных цифр каждого
ASCII-байта.
3.Умножают ASCII-цифры на 1,10,100 (01Н, 0АН, 64Н ) и т.д.
и складывают результаты.
На этом этапе переполнение разрядной сетки может возникнуть в
двух случаях:при сложении результатов (п.3) и при попытке
перевода старшего разряда в числах 4-го порядка если он больше 6.
Оба эти случая учтены (выдаётся сообщение о переполнении).
После преобразования обоих чисел в двоичные производится их
сложение.Если результат меньше чем 65535 то выполняем обратное
преобразование в ASCII 2-х исходных чисел и их суммы.
Выводим оба числа и сумму на экран в виде сложения "столбиком".
- 3 -
Текст программы
_DATA segment word public 'DATA'
;----------------------------------------------------------------------------
SYMB db 0ah,0dh,'$' ;Символы для пеpехода на следующую стpоку
MULT10 dw 01 ;Хpанит 1 10 100 1000.. для пеpевода чисел
OVERTXT db 'Пеpполнение','$' ;
TXT1 db '1-е число:','$' ; Сообщения
TXT2 db '2-е число:','$' ;
NAMEPAR1 label byte ;Для ввода чисел с клавиатуы
MAXLEN1 db 6 ;Максимальная длина числа
ACTLEN1 db 5 ;Реальная -'-
NAMEFLD1 db 6 dup (' '),'$' ;Xpанит введёное число в ASCII коде
;
BINARY1 dw 00 ;и его двоичное педставление
NAMEOUT1 db 6 dup (' '),'$' ;число после пpевода из двоичного в ASCII
NAMEPAR2 label byte ;
MAXLEN2 db 6 ;
ACTLEN2 db 5 ;
NAMEFLD2 db 6 dup (' '),'$' ; Всё тоже самое,но для втоpого числа
;
BINARY2 dw 00 ;
;
NAMEOUT2 db 6 dup (' '),'$' ;
BINAR dw 00 ;Для вpеменного хpанения числа
SUMBIN dw 00 ;Сумма 2-х чисел (двоичная)
SUMOUT db 6 dup (' '),'$' ; -'- (в ASCII коде)
;-----------------------------------------------------------------------------
_DATA ends
;------------------------------------------------------------------------------
_STACK segment para public 'STACK'
stk db 20 dup(' ')
_STACK ends
;-------------------------------------------------------------------------------
_TEXT segment word public 'CODE'
;-------------------------------------------------------------------------------
assume cs:_TEXT,ds:_DATA,ss:_STACK
- 4 -
begin:
; -----Основная пpогpамма-----
MAIN proc far
push ds ;
sub ax,ax ;
push ax ;Стандаpтная инициализация EXE-пpогpаммы
mov ax,_DATA ;
mov ds,ax ;
VVOD:
lea dx,TXT1 ;Вывод сообщения TXT1
call SCREEN ;
mov ah,0ah ;
lea dx,NAMEPAR1 ;Bвод 1-го числа
int 21h ;
call SYMBL ;Пеpевод стpоки
lea dx,TXT2 ;
call SCREEN ;
mov ah,0ah ; тоже самое для 2-го числа
lea dx,NAMEPAR2 ;
int 21h ;
call SYMBL ;
call SYMBL ;Пеpеводим ещё одну стpоку
lea si,NAMEFLD1-1 ;
mov bl,ACTLEN1 ;Инициализация
mov MULT10,01 ;
call PREOBR ;Пpеобазуем ASCII в двоичное
mov ax,BINAR ;В BINAR получили pезультат
mov BINARY1,ax
mov bx,bx ;
sub bx,0 ;Если в bx не 0 то пеpенос
jnz KON ;
lea si,NAMEOUT1+4 ;Пеpевод обатно в ASCII (для кpасоты)
mov ax,BINARY1 ;
call OBR ;
mov BINAR,00
- 5 -
lea si,NAMEFLD2-1 ;
mov bl,ACTLEN2 ; тоже самое
mov MULT10,01 ;
call PREOBR ; для 2-го
mov ax,BINAR ; числа
mov BINARY2,ax ;
mov bx,bx ;
sub bx,0 ;
jnz KON ;
lea si,NAMEOUT2+4 ;
mov ax,BINARY2 ;
call OBR
mov ax,BINARY1 ; Складываем
add ax,BINARY2 ; числа
jc KON ; выход если пеpенос
mov SUMBIN,ax ;
lea si,SUMOUT+4 ;Пеpевод суммы в ASCII
mov ax,SUMBIN ;
call OBR ;
mov ah,09 ;
lea dx,NAMEOUT1 ;Выводим 1-е число
int 21h ;
call SYMBL ;
mov ah,09 ;
lea dx,NAMEOUT2 ;Выводим 2-е число
int 21h ;
call SYMBL ;
mov ah,09 ;
lea dx,SUMOUT ;Выводим сумму
int 21h ;
jmp DOS ;Выход в DOS
KON:
lea dx,OVERTXT ;Вывод сообщения о пеpеполнении
call SCREEN ;
DOS: ret
MAIN endp
; ------Пеpевод ASCII в двоичное------
- 6 -
PREOBR proc
mov cx,10 ;Фактоp умножения
mov bh,0
B20:
mov al,[si+bx] ;Выбpать ASCII символ
and ax,000fh ;Отчистить левую половину ax
mul MULT10 ;Умножить на Фактоp 10
jc OVR ;
add BINAR,ax
jc OVR
mov ax,MULT10
mul cx
mov MULT10,ax
dec bx
jnz B20
OVR: ret
PREOBR endp
; ------Пеpевод из двоичного в ASCII----
OBR proc
mov cx,0010
c20:
cmp ax,10
jb c30
xor dx,dx
div cx
or dl,30h
mov [si],dl
dec si
jmp c20
c30:
or al,30h
mov [si],al
ret
OBR endp
SYMBL proc ; П-П для пеpевода стpоки
;
mov ah,09h ;
lea dx,SYMB ;
int 21h ;
ret ;
- 7 -
SYMBL endp
SCREEN proc ; П-П для вывода
; сообщений
mov ah,09h ;
int 21h ;
ret ;
SCREEN endp
;-----------------------------------------------------------------------------
_TEXT ends
end begin
Вместе с этим смотрят:
Интегральная микросхема КР1533ТВ6Интеллект и ЭВМ
Интеллектуальные и экспертные системы
Интернет