20609

Простой генератор кода

Лекция

Коммуникация, связь, радиоэлектроника и цифровые приборы

Данные вычисленные результаты находятся в регистрах как можно дальше и перенос их в память осуществляется только при необходимости использовать этот регистр. a:= bc b в регистр Ri c в регистр Rj. 2 b в регистр Ri c в памяти ADD Ri с.

Русский

2013-07-31

37 KB

0 чел.

Лекция №10

Простой генератор кода

Генератор кода рассматривает последовательность трех адресных инструкций, учитывая какие из операндов находятся в текущий момент в регистрах.

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

a:= b+c

  1.  b в регистр Ri, c в регистр Rj.

ADD Ri, Rj.

Стоимость=1.

2) b в регистр Ri, c в памяти

ADD Ri, с.

Стоимость=2.

3) b в регистр Ri, c живая

MOV Rj, с

ADD Ri, Rj.

Стоимость=3.

Дескриптор регистров – отслеживает текущее содержимое каждого регистра. Когда для вычисления требуется новый регистр, происходит обращение к регистру.

Дескриптор адреса – отслеживает ячейки памяти, в которых хранятся значения имен.

Алгоритм генерации года

На вход алгоритма поступает последовательность трех адресных инструкций составляющих базовый блок.

Для каждой инструкции вида X:=Y op Z выполняется следующая последовательность действий:

  1.  вызывается функция getreg для определения места L где должен быть сохранен результат X, как правило, это регистр.
  2.  обращаемся к дескриптору адресов для определения текущего положения Y в памяти ().

Если значение Y есть и в памяти и в регистре, то в качестве выбирается регистр. Если Y не находится в L, то генерируем инструкцию

MOV L,Y/

  1.  генерируем инструкцию

op L, Z/ , где  Z/- текущее положение Z.

Аналогично определяем регистр.

Обновляем содержимое дескриптора адреса X  информацией о том, что X находится в L. Если L является регистром, то модифицируем еще и дескриптор регистра. Если X содержится в других регистрах, то очистить эти дескрипторы регистров.

  1.  если текущие значения Y и Z в дальнейшем не используется и не являются живыми при выходе из блока, то удаляем информацию о них из дескриптора регистров.

Алгоритм функции getreg

Функция getreg вызывается для имени переменной

  1.  если имя Y находится в регистре и если Y не является живым именем, то в качестве L возвращается регистр, в котором хранится Y.
  2.  если условие пункта 1 не выполняются, то в качестве L возвращается свободный регистр (если таковой имеется).
  3.  если не выполняется пункт 2, а X используется далее в блоке или операция требует использование регистра, тогда ищется занятый регистр R, генерируется операция MOV m, R. Регистр R выбирается, руководствуясь следующими принципами: значение, храняещееся в нем, будет использовано нескоро или оно уже хранится в памяти.
  4.  если X в блоке не используется, либо не удается найти походящий регистр,тогда в качестве L выбирается ячейка памяти.

Пример:

d:=(a-b) + (a-c) + (a-c)

t  | t1:=a-b   t1:=a-b

u | t2:=a-c   t2:=t1+t1

v | t3:=t2+t2  t3:=a-b

  | d:= t1+t3   u:=t3+t2

t:=a-b

u:=a-c

v:=t+u

d:=v+u

Инструкция

Сгенерированный код

Дескриптор регистров (регистры пусты)

Дескриптор адреса

t:= a-b

MOV R0, a

SUB R0, b

R0 – содержит t

t в R0

u:= a-c

MOV R1, a

SUB R1, c

R0 – содержит t

R1 – содержит u

t в R0

u в R1

v:= t+u

ADD R0, R1

R0 – содержит v

R1 – содержит u

v в R0

u в R1

d:= v+u

ADD R0, R1

MOV d, R0

R0 – содержит d

d в R0

Стоимость инструкций – 10.


 

А также другие работы, которые могут Вас заинтересовать

7542. Характеристика отрасли БОН 29.5 KB
  Характеристика отрасли БОН. Отрасль БОН - особенности формирования, характеристика. Социально - экономическая роль БОН. Классификация услуг. Формы обслуживания населения. Отрасль БОН - особенности формирования,...
7543. Уроки Мастера. Конспекты по театральной педагогике 1.09 MB
  В своей педагогической практике народный артист СССР, профессор ГИТИСа А.А. Гончаров (1918 - 2001) последовательно утверждал принципы совместного обучения актеров и режиссеров. Книга, основанная на материале его уроков, репетиций, бесед со студента...
7544. Теория и технологии обучения. Сборник текстов 1.33 MB
  Теория и технологии обучения Введение Хрестоматия адресована студентам ВЭГУ всех факультетов, изучающих курс Теория обучения и педагогические технологии. Она содержит тот минимум источников, на основе изучения которых студенты могут получить полно...
7545. Связи с общественностью: введение в дисциплину Public Relations 80.5 KB
  Связи с общественностью: введение в дисциплину Учебные цели: изучить определения Public Relations, определить функции Public Relations, выделить основные виды Public Relations Public Relations и реклама, Public Relations и пропаганда, P...
7546. Исторические предпосылки возникновения ПР 82 KB
  Исторические предпосылки возникновения ПР. Учебные цели: познакомиться с историческими источниками Public Relations: риторикой, рекламой, общественным мнением выделить основные этапы институционализации Public Relations в США и...
7547. Основы теории коммуникации 73 KB
  Основы теории коммуникации Учебные цели: изучить сущность информационного и коммуникативного пространства ознакомиться с видами и типами коммуникации, выделить свойства и закономерности коммуникативного пространства охарактеризовать символич...
7548. Субъекты и объекты в ПР-деятельности. Общественное мнение. Группы общественности 61 KB
  Субъекты и объекты в ПР-деятельности. Общественное мнение. Группы общественности Учебные цели: ознакомиться с основными субъектами, объектами, целями, способами коммуникации в системной деятельности Public Relations выделить пять основных целей Pub...
7549. Современные технологии внутреннего ПР 38.5 KB
  Современные технологии внутреннего ПР Когда мы говорим о технологиях Public Relations, связанных с деятельностью конкретного предприятия, благотворительной организации, некоммерческого фонда или коммерческой компании, в...
7550. Внешний ПР. Организация значимых событий 42.5 KB
  Внешний ПР. Организация значимых событий. Внешние Public Relations -технологии В качестве внешних Public Relations-технологий, как правило, могут использоваться: 1) устное сообщение (пресс-конференции, выступления перед различными с...