Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:

лаб раб / МПС(1)02

.doc
Скачиваний:
11
Добавлен:
28.03.2015
Размер:
54.27 Кб
Скачать

Часть I

Вариант №2

Лабораторная работа №1.

Цель работы: приобрести практические навыки работы с микропроцессором Intel 80х86, изучить возможности устройства Intel 80х86, практически освоить режимы его работы.

п/п

1-ое слагаемое

2-ое слагаемое

3-ое слагаемое

2

0012

EF6E

0938

cdseg segment 'code'

org 100h

start:

mov ax,0012h

mov cx,EF6Eh

mov dx,0938h

add ax,cx

add ax,dx

int 20h

cdseg ends

end start

Ответ:

AX= F8B816.

Лабораторная работа 2

Изучение арифметических команд и

команд пересылки данных

Например, необходимо найти сумму ряда чисел. При этом задача состоит в том, чтобы осуществить суммирование нескольких чисел сразу. Эти числа могут представлять собой совокупности входных сигналов, находящихся под управлением системы, число изделий (или число сообщений), изготовленных (или принятых) за определенный промежуток времени.

Программа сложения ряда чисел

п/п

Исходный ряд чисел

2

0931,4C05,3388,207A,10FB,0867,045D

cdseg segment 'code'

assume cs:cdseg

org 100h

start:

mov si,offset array

lodsw

mov cx,ax ; count of digits

mov bx,si ; addr of array

sub ax,ax

m1: add ax,[bx]

dec cx

je fin

add bx,0002

jmp m1

fin:

int 20h

array dw 7,0931h,4C05h,3388h,207Ah,10FBh,0867h,045Dh

cdseg ends

end start

Ответ:

C6F7 16.

Рассмотрим арифметику для чисел, занимающих несколько ячеек. Задача состоит в том, чтобы сложить два числа длиной более 16 бит каждое. Исходные числа располагаются в области памяти таким образом, что сначала идут младшие разряды, а затем более старшие. Полученную сумму необходимо поместить в те ячейки памяти, где хранилось первое число.

п/п

1-ое слагаемое

2-ое слагаемое

2

14B24F878A00

C8804A82661C

cdseg segment 'code'

assume cs:cdseg

org 100h

start:

mov cx,(offset data2 -offset data1)/2

mov di,offset data1

mov si,offset data2

m:

mov ax,[di]

adc ax,[si]

stosw

inc si

inc si

dec cx

jne m

int 20h

data1 dw 8A00h,4F87h,14B2h

data2 dw 661Ch,4A82h,0C880h

cdseg ends

end start

Ответ:

Сумма равна DD32 9A09 F01C.

2.3 Лабораторная работа 3

Обработка массивов информации и

организация циклов

Рассмотрим следующую задачу. Массив чисел расположен в области памяти, начиная с адреса NNNN, и состоит из N элементов. Необходимо переслать массив в другую область памяти, начиная с адреса DDDD. В программе для МП Intel 80x86 в качестве адресного регистра используются регистры si и di. Необходимо учитывать, что при каждом проходе программа должна изменять содержимое обоих адресных регистров.

п/п

Исходный массив

2

C880,4A82,661C,B23C,CD13,CC0F,4BFA,71E5,F1B2

Программа:

cdseg segment 'code'

org 100h

start:

mov cx,(offset data2 - offset data1)/2

mov si,offset data1

mov di,offset data2

repne movsw

int 20h

data1 dw C880h,4A82h,661Ch,0B23Ch,0CD13h,0CC0Fh,4BFAh,71E5h,0F1B2h

data2 dw 0AAAAh,0AAAAh,0AAAAh,0AAAAh,0AAAAh,0AAAAh,0AAAAh,0AAAAh,0AAAAh

cdseg ends

end start

Массив данных был перемещен в область памяти под названием data2.

В ряде случаев возникает необходимость выбрать из массива информации данные, представляющие собой ряд максимальных, либо минимальных величин. Предположим, что необходимо написать программу для решения следующей задачи. Дан массив А1, состоящий из N однобайтовых чисел. Необходимо переписать из массива А1 в массив В1 все числа в диапазоне от Н1 до Н2.

п/п

Исходный массив

Нижний Предел

Верх­ний предел

2

C880,4A82,661C,B23C,CD13,CC0F,4BFA

5624

5B3D

cdseg segment 'code'

assume cs:cdseg

org 100h

start:

mov cx,(offset dest - offset source)/2

mov si,offset source

mov di,offset dest

m1:

lodsw

cmp ax, 5624h ; min

jb m2

cmp ax, 5B3Dh ; max

ja m2

stosw

m2:

loop m1

int 20h

source dw 0C880h,4A82h,661Ch,0B23Ch,0CD13h,0CC0Fh,4BFAh

dest dw (offset dest - offset source)/2 dup (0)

cdseg ends

end start

Ответ:

В Dest не было скопировано ни одно число.

Соседние файлы в папке лаб раб