Функция fillpreds — различия между версиями
Alexander (обсуждение | вклад) (Новая страница: «Функция <strong>fillpreds(Fn)</strong> - функция, реализованная в Си интерфейсе QBE. Р…») |
Alexander (обсуждение | вклад) |
||
| Строка 6: | Строка 6: | ||
== Исходный код == | == Исходный код == | ||
Функция <strong>fillpreds</strong> из <code>cfg.c</code> | Функция <strong>fillpreds</strong> из <code>cfg.c</code> | ||
| − | /* fill predecessors information in blocks */ | + | /* fill predecessors information in blocks */ |
| − | void fillpreds(Fn *f) { | + | void fillpreds(Fn *f) { |
Blk *b; | Blk *b; | ||
for (b=f->start; b; b=b->link) { | for (b=f->start; b; b=b->link) { | ||
Версия 09:27, 26 марта 2018
Функция fillpreds(Fn) - функция, реализованная в Си интерфейсе QBE. Располагается в файле cfg.c и "подключается" в all.h.
Назначение
fillpreds осуществляет заполнение полей pred, npred, visit во всех блоках функции.
Исходный код
Функция fillpreds из cfg.c
/* fill predecessors information in blocks */
void fillpreds(Fn *f) {
Blk *b;
for (b=f->start; b; b=b->link) {
b->npred = 0;
b->pred = 0;
}
for (b=f->start; b; b=b->link) {
if (b->s1)
b->s1->npred++;
if (b->s2 && b->s2 != b->s1)
b->s2->npred++;
}
for (b=f->start; b; b=b->link) {
if (b->s1)
addpred(b, b->s1);
if (b->s2 && b->s2 != b->s1)
addpred(b, b->s2);
}
}