Генерация высококачественного кода для программ на СИ - Тестирование компиляторов. Часть 3

ОГЛАВЛЕНИЕ


 При сравнении результатов в таблице 1 и в номере за февраль 1988
 необходимо отметить одно изменение. Два теста с использованием регистровых
 переменных (использования указателей и "решето"-sieve) в феврале были
 измерены для 100 итераций, а не для 20-ти. Поскольку полезно
 непосредственное сравнение тестов с использованием регистровых переменных
 и без их использования, тесты с регистровыми переменными в данном случае
 запускались с 20-ю итерациями. Также заметьте, что численные тесты,
 присутствующие в таблице 1, выполнялись для прямого кода процессоров 80x87
 в малой и большой моделях памяти, а не с помощью программного эмулятора.
 Поскольку текст теста оптимизации предназначен для проверки наличия или
 отсутствия отдельных типов оптимизации, он состоит из набора отдельных, не
 связанных фрагментов программ, и не представляет собой целостное,
 проблемно-ориентированное тело программы. Тест организован как основная
 функция (main), содержащая большинство фрагментов кода для оптимизации, и
 несколько отдельных функций, с аргументами или без них. Эти функции
 демонстрируют не только отдельные методы оптимизации, но также оптимизацию
 пролога и эпилога выполняемых функций. С целью обеспечения максимальных
 возможностей для оптимизации, основанной на времени жизни отдельной
 переменной, большинство переменных теста являются глобальными. Многие
 возможности обеспечены специально для общих методов оптимизации, таких как
 удаление лишних сохранений (присваиваний), размножение констант и
 размещение переменных в регистрах.
 Процесс оптимизации кода сложен, и степень повышения эффективности зависит
 не только от типа и изощренности методов оптимизации компилятора, но также
 и от того, как исходный текст программы написан и структурирован.
 Результат также зависит от того, как в исходном тексте используются
 переменные и выражения.
 В таблице 2 собрана информация о том, какие приемы оптимизации выполнялись
 каждым компилятором на тексте теста. Каждый компилятор из рассматриваемого
 набора выполняет простейшие приемы оптимизации, такие как свертка констант
 и алгебраические упрощения. Большинство применяют методы оптимизации
 некоторого промежуточного уровня, включающего снижение мощности и удаление
 общих подвыражений. Некоторые выполняют оптимизацию высокого уровня, такую
 как вынесение инвариантного кода и удаление переменных индукции циклов. Ни
 один не выполняет успешно слияние циклов, и только Datalight Optimum-C
 делает попытки, далеко не удовлетворительные, применения глубокого
 удаления общих подвыражений.

  --------------------------------------------------------------¬
  ¦Таблица 2: Результаты теста оптимизации       ¦
  +-------------------------T---T---T---T---T---T---T---T---T---+
  ¦    КОМПИЛЯТОР ВЕРСИЯ    ¦ 1 ¦ 2 ¦ 3 ¦ 4 ¦ 5 ¦ 6 ¦ 7 ¦ 8 ¦ 9 ¦
  +-------------------------+---+---+---+---+---+---+---+---+---+
  ¦МЕТОДЫ ОПТИМИЗАЦИИ  ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦Свертка констант (целых) ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦
  ¦Свертка констант (плав.) ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦
  ¦Размножение констант     ¦   ¦   ¦ * ¦   ¦   ¦ * ¦ * ¦   ¦ * ¦
  ¦Размножение копий   ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦   ¦ * ¦
  ¦Алгебр.упрощения    ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦
  ¦Подавление деления на 0  ¦   ¦ * ¦   ¦   ¦   ¦ * ¦ * ¦   ¦ * ¦
  ¦Удаление подвыражений    ¦   ¦   ¦ * ¦ * ¦ * ¦ * ¦ * ¦   ¦ * ¦
  ¦Снижение мощности   ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦
  ¦Удаление излишних   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦   загрузок/сохранений   ¦ * ¦   ¦ * ¦ * ¦ * ¦ * ¦ * ¦   ¦ * ¦
  ¦Удаление недостижи- ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦   мого кода   ¦ * ¦ * ¦ * ¦ * ¦   ¦ * ¦ * ¦   ¦ * ¦
  ¦Удаление излишних   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦   присваиваний     ¦   ¦ * ¦ * ¦   ¦   ¦ * ¦ * ¦   ¦ * ¦
  ¦Использ. машинно-   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦   зависимых команд ¦   ¦ * ¦   ¦ * ¦   ¦ * ¦ * ¦ * ¦ * ¦
  ¦Поддержка встроенных     ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦   функций     ¦   ¦   ¦   ¦   ¦   ¦   ¦ * ¦   ¦ * ¦
  ¦Размещение переменных    ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦   в регистрах      ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦
  ¦Непосредственные инструк-¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦   ции 80287   ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦ * ¦   ¦ * ¦
  ¦Сжатие цепочки переходов ¦ * ¦   ¦ * ¦ * ¦   ¦ * ¦ * ¦   ¦ * ¦
  ¦Вынесение инвариантного  ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦   кода   ¦   ¦   ¦   ¦   ¦   ¦   ¦ * ¦   ¦   ¦
  ¦Удаление переменных ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦   индукции циклов  ¦   ¦   ¦   ¦   ¦   ¦   ¦ * ¦   ¦   ¦
  ¦Удаление циклов     ¦   ¦   ¦   ¦   ¦   ¦   ¦ * ¦   ¦   ¦
  ¦Удал. глуб. подвыражений ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦Разворачивание циклов    ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  ¦Слияние циклов      ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦   ¦
  +-------------------------+---+---+---+---+---+---+---+---+---+
  ¦ 1 - BORLAND Turbo C 1.5, 2  -  COMPUTER  INNOVATIONS   ¦
  ¦ C86Plus  1.1,  3  - DATALIGHT Optimum-C 3.14, 4 - LATTICE   ¦
  ¦ MS-DOS C 3.2, 5 - MANX Aztec C 4.0, 6 - METAWARE  High  C   ¦
  ¦ 1.4,  7  - MICROSOFT C 5.0, 8 - MICROSOFT QuickC 1.0, 9 -   ¦
  ¦ WATCOM C 6.0.            ¦
  ¦ * - компилятор применяет этот метод оптимизации.  ¦
  +-------------------------------------------------------------+
  ¦ Большинство включенных в обзор компиляторов языка Си   ¦
  ¦ поддерживают  простые  методы  оптимизации,   такие   как   ¦
  ¦ алгебраические упрощения, и только несколько компиляторов   ¦
  ¦ применяют  более  сложные формы, такие как удаление общих   ¦
  ¦ подвыражений.            ¦
  L--------------------------------------------------------------