22 lines
2.3 KiB
Markdown
22 lines
2.3 KiB
Markdown
![]() |
#### Описание двухуровневого механизма динамического предсказания ветвлений с учетом корреляции.
|
|||
|
|
|||
|
Соседние переходы могут коррелировать: поведение недавно выполненных переходов влияет на предсказание текущего перехода.
|
|||
|
Это имеет место в ветвлениях, использованных для реализации конструкций if-then-else.
|
|||
|
Предполагается, что есть 2 уровня предсказаний:
|
|||
|
|
|||
|
1) **Глобальный**
|
|||
|
|
|||
|
Запись истории поведения m последних переходов как выполнившихся или нет. Обычно используется m -битный регистр сдвига.
|
|||
|
|
|||
|
2) **На один адрес ветвления**
|
|||
|
|
|||
|
- $2^m$ таблиц предсказания, каждая запись таблицы - это n-битный счетчик с насыщением.
|
|||
|
- Запись истории $1^{го}$ уровня используется для выбора соответствующей из таблиц предсказания $2^{го}$ уровня. Таким образом каждая с $2^m$ таблиц содержит $2^N$ записей и каждая запись - 2-битный (к примеру счетчик).
|
|||
|
- Общее количество необходимых для $2^{го}$ уровня бит: $2^m \times n \times 2^N$. n - количество бит, используемое для предсказания.
|
|||
|
**GAp** - Global Adaptive per address.
|
|||
|
Используется обозначение GAp $(m,n)$, которое означает:
|
|||
|
- Записываются последние $m$ ветвлений для выбора между $2^m$ таблицами истории.
|
|||
|
- Каждая таблица истории $2^{го}$ уровня использует n-битные счетчики (имеет разрядность n бит).
|
|||
|
- Одноуровневая схема бимодальной ВНТ с 2-битными счетчиками обозначается как предсказатель $(0,2)$
|
|||
|
|