LOOP EXIT PREDICTOR
A processor [100] includes a prediction engine [206] coupled to a training engine [210]. The prediction engine includes a loop exit predictor [232]. The training engine includes a loop exit branch monitor [252] coupled to a loop detector [254]. Based on at least one of a plurality of call return lev...
Gespeichert in:
Hauptverfasser: | , |
---|---|
Format: | Patent |
Sprache: | eng ; fre |
Schlagworte: | |
Online-Zugang: | Volltext bestellen |
Tags: |
Tag hinzufügen
Keine Tags, Fügen Sie den ersten Tag hinzu!
|
Zusammenfassung: | A processor [100] includes a prediction engine [206] coupled to a training engine [210]. The prediction engine includes a loop exit predictor [232]. The training engine includes a loop exit branch monitor [252] coupled to a loop detector [254]. Based on at least one of a plurality of call return levels, the loop detector of the processor takes a snapshot of a retired predicted block during a first retirement time, compares the snapshot to a subsequent retired predicted block at a second retirement time, and based on the comparison, identifies a loop and loop exit branches within the loop for use by the loop exit branch monitor and the loop exit predictor to determine whether to override a general purpose conditional prediction.
Un processeur [100] comprend un moteur de prédiction [206] couplé à un moteur d'apprentissage [210]. Le moteur de prédiction comprend un prédicteur de sortie de boucle [232]. Le moteur d'apprentissage comprend un moniteur de branche de sortie de boucle [252] couplé à un détecteur de boucle [254]. D'après au moins un niveau d'une pluralité de niveaux de retour d'appel, le détecteur de boucle du processeur prend un instantané d'un bloc prédit retiré à un premier moment de retrait, compare l'instantané avec un bloc prédit retiré ultérieur à un second moment de retrait et, d'après la comparaison, identifie une boucle ainsi que les branches de sortie de boucle à l'intérieur de la boucle destinées à être utilisées par le moniteur de branche de sortie de boucle et le prédicteur de sortie de boucle afin de déterminer s'il faut annuler une prédiction conditionnelle à usage général. |
---|