Об ассемблере



страница6/52
Дата14.08.2018
Размер3.59 Mb.
#43964
ТипЛекция
1   2   3   4   5   6   7   8   9   ...   52

AAM


(Ascii Adjust after Multiply)

ASCII-коррекция после умножения

 


Схема команды:

aam

Назначение:

Синтаксис

Алгоритм работы:

  • разделить значение регистра al на 10;

  • записать частное в регистр ah, остаток — в регистр al.

Состояние флагов после выполнения команды:

11

07

06

04

02

00

OF

SF

ZF

AF

PF

CF

?









?

Применение:

Команду aam используют для коррекции результата умножения двух неупакованных BCD-чисел. Специальной команды умножения BCD-чисел нет. Поэтому BCD-числа умножаются поразрядно, как обычные двоичные числа, командой mul. Максимальное число, которое получается при таком умножении, — это 9*9=8110=5116. Отсюда понятно, что значения, для которых командой aam можно получить их двузначный BCD-эквивалент в регистре ax, находятся в дипазоне от 00h до 51h. Эту команду можно применять и для преобразования двоичного числа из регистра ax (в диапазоне от 0 до 63h) в его десятичный эквивалент(соответственно, из диапазона от 0 до 9910).

Пример 1. Умножить десятичное число 8 на 9. Подготовить результат к выводу на экран.


        mov     ah,08h  ;ah=08h

        mov     al,09h  ;al= 09h

        mul     ah      ;al=48h — двоичный эквивалент 72

        aam             ;ah=07h,al=02h

        or      ax,3030h        ;ax=3732h — ASCII-представление числа 72


Пример 2. Преобразовать двоичное число 60h в эквивалентное десятичное число.

;поместим число 60h в регистр ax

        mov     ax,60h  ;ax=60h

        aаm             ;ax=0906h — получили десятичный эквивалент числа 60h

        or      ax,3030h        ;символьный эквивалент, можно выводить на экран



См. также: урок 8, приложение 7 и команды aaa, aad, aas, daa, das

AAS


(Ascii Adjust after Substraction)

ASCII-коррекция после вычитания

 


Схема команды: 

aas 

Назначение: корректировка результата вычитания двух неупакованных одноразрядных BCD-чисел.

Синтаксис

Алгоритм работы:

если (младший полубайт регистра al меньше 9) или (флаг af=1), то выполнить следующие действия:



  • уменьшить значение младшего полубайта регистра al на 6;

  • обнулить значение старшего полубайта регистра al;

  • установить флаги af и cf в 1;

иначе установить флаги af и cf в 1.

Состояние флагов после выполнения команды:

11

07

06

04

02

00

OF

SF

ZF

AF

PF

CF

?





r



r

Применение:

Команду aas используют для коррекции результата вычитания двух неупакованных одноразрядных BCD-чисел после команды sub. Операндами в команде sub должны быть правильные одноразрядные BCD-числа. Рассмотрим возможные варианты вычитания одноразрядных BCD-чисел:



  • 5-9 — для вычитания необходимо сделать заем в старшем разряде. Факт такого заема в микропроцессоре фиксируется установкой флагов cf и af в 1 и вычитанием 1 из содержимого ah. В результате после команды aas в регистре al получается правильное значение (модуль результата), которое для нашего примера (с учетом заема из старшего разряда) составляет 6. Одновременно моделируется заем из старшего разряда, что позволяет производить вычитание длинных чисел.

  • 8-6 — для вычитания нет необходимости делать заем в старшем разряде. Поэтому производится сброс флагов cf и af в 0, а ah не изменяется. В результате после команды aas в регистре al получается правильное значение (модуль результата), которое для нашего примера составляет 2.

Пример 1. Вычесть десятичное число 8 из 5. Подготовить результат к выводу на экран.

        mov     al,05h

        mov     bl,08h

        sub     al,bl   ;al=0fdh

        aas             ;al=07, cf=af=1

        or      al,30h  ;al=37h — код символа 7

;вывод результата на экран

        mov     ah,2

        mov     dl,al

        int     21h

        


См. также: уроки 3, 8, приложение 7 и команды aaa, aad, aam, daa, das



Поделитесь с Вашими друзьями:
1   2   3   4   5   6   7   8   9   ...   52




База данных защищена авторским правом ©vossta.ru 2022
обратиться к администрации

    Главная страница