Способы адресации
1.Неявная
2.Непосредственная
3.Прямая
1.К памяти
2.К регистру
4.Косвенная
1.Регистровая
2.К памяти
1.Одноступенчатая
2.Многоступенчатая
5. Базовая (с регистром базы, с общими регистрами)
6.Относительная
7.Индексная (с индексным
регистром, с общими регистрами)
1.Общая
2.Автоинкрементная
1.Постинкрементная
2.Преинкрементная
3.Автодекрементная
1.Постдекрементная
2.Предекрементная
•Косвенная регистровая автоинкрементная
адресация. В коде команды задается номер NR регистра, содержащего адрес (АО) ячейки памяти, в которой хранится операнд. После формирования исполнительного адреса содержимое регистра с номером NR увеличивается на единицу.
|
|
|
|
|
Память |
||
КОП |
NR |
NR |
Регистры |
||||
|
|||||||
|
|
|
|
|
|
||
|
|
|
|
|
|
||
|
|
АО (АО+1) |
|
|
|||
|
|
|
|
|
|||
|
|
|
|
|
АЕ |
|
|
|
|
|
|
|
|
||
|
|
|
|
Операнд |
|||
(АС):=(АС)+М[R[NR]], |
АЕ=R[NR] |
|
|||||
|
|||||||
R[NR]:=R[NR] +1. |
|
|
|
|
|||
|
|
|
|
•Базово-индексная адресация. Исполнительный адрес формируется следующим образом:
АЕ=(RB)+D+(RI)m
или
АЕ=R[NRВ]+R[NRI]m+D,
где RB – регистр, а NRВ – номер регистра базы; RI – регистр, а NRI – номер регистра индекса; D – смещение адреса, указанное в команде; m – масштабный множитель для умножения индекса.
•Косвенная автодекрементная адресация.
Исполнительный адрес формируется следующим образом:
М[A]:=М[A]-1,
АЕ=М[A].
•Страничная адресация. Исполнительный адрес вычисляется путем конкатенации (присоединения) К-разрядного адреса (D) операнда на странице, указанного в команде к старшим разрядам адреса
(АР), которые рассматриваются как адрес страницы и берутся из специального регистра адреса страницы
(RАР). АЕ=(RАР)↔D.
RC |
|
КОП |
|
D |
|
Память |
|
|||
RАР |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
||
|
АР |
|
|
|
АЕ=АР↔D |
|
Страница, |
|||
|
|
|
|
|
|
|
|
|||
|
|
|
|
|
|
|
|
|
Операнд |
|
|
|
|
|
|
|
|
А=АР00…0 |
объем 2K. |
||
|
|
|
|
|
|
|
||||
|
|
|
|
|
|
|
|
|||
(АС):=(АС)+М[(RАР)↔D]. |
|
|
•Особенностизадания способов адресации
–Для указания способа адресации в формате команды может быть специальное поле для каждого адреса. Разрядность этого поля определяется числом различных способов формирования адреса, применяемых в команде.
–Исполнительные адреса первого и второго операндов команды могут формироваться различными способами. Например, для первого операнда применяется непосредственная, а для второго – косвенная регистровая адресация.
–При формировании исполнительного адреса операнда может использоваться сочетание различных способов формирования адреса.