Регистр общего назначения.
ah Al Ax bh Bl Bx ch Cl Cx dh Dl Dx Ax - основной сумматор Bx – базовый регистр Cx- регистр-счетчик Dx- регистр данных Регистры указатели(16 разрядные) SP-указатель стека BP-указатель базы IP-указатель(счетчик) команд Индексные регистры(16) SI- индекс источника DI- индекс приемника. Сегментные регистры(16) CS - адресует код программы, DS - адресует данные, которыми пользуется программа, SS- адресует программный стек, ES-регистр дополнительного сегмента данных. Регистр флагов МП i8086. Назначение регистра, флаги состояния, флаги управления Регистр флагов содержит словосостояние программы, имеет 9 значащих битов (флаги),одни из которых: флаги состояния, флаги управления Флаги состояния: CF - флаг переноса. PF -флаг четности. AF - флаг вспомогательного переноса. ZF - флаг нуля SF - флаг знака Флаги управления: TF - флаг трассировки IF - флаг прерывания DF - флаг направления OF - флаг переполнения. 4.Принцип адресации памяти МП i8086: размер адресного пространства, понятие сегмента, понятие логического и физического адреса. Адресное пространство мп допустимое количество ячеек памяти к кот. мп может обратиться по шине-адресу. Каждая ячейка имеет свой номер (адрес) 20 бит-ША. т.к.внутри регистры Мп имеют разрядность 16 бит и впрямую могут адресовать только 64Кб для расширения адресного пространства был введён механизм сегментации памяти. Всё адресное пространство делиться на параграфы =16 байт. Несколько смежных параграфов образуют сегмент. Размер сегмента в параграфах от 0 до 4096 параграфов.Адрес сегмента определяеться 1-параграф - это значение наз. адресом сегмента и храниться в сегментном регистре. Каж. байт памяти имеет логический адрес кот. состоит из 2-х компонент. ХХХХ:хххх - вид лог. адреса байта. ХХХХ-базовый адрес сегмента, хххх-смещение байта внутри сегмента. Для получения физ. адреса сегмента адрес * на 16 + значение смещения получаем 20 разр. адрес. Логические сегменты программы. Адресация сегментов 4 типа сегментов: Сегмент кода – в нем находятся машинные инструкции, кот. составляют текст программы; Сегмент данных – хранит определенные в программе константы и переменные; Сегмент стека – хранит промежуточные данные, а также адреса возврата из подпрограммы в точку вызова; Сегмент дополнительных данных – используется для размещения динамически определяемых переменных Логические сегменты задаются программистом, так же как порядок расположения их памяти. Сегмент стека. Адресация стека, команды работы со стеком, изменение состояния стека. Стек задается программно или определяется системно. SS-содержит базовый адрес текущего сегмента стека SP указывает на вершину стека PUSH- заносим в стек POP- достаем из стека.
Стек растет в область младших адресов, т.е. при выполнении команды PUSH значение регистра SP аппаратно уменьшается на 2. Помещать в стек и извлекать из него можно только 16-разрядные операнды. т.е. слова. Это значит, что двойное слово помещается и извлекает из стека в два приема, а для помещения в стек одного байта необходимо дополнять его до слова фиктивным байтом.
|