Dynamic Predication of Indirect Jumps

Download Now
Provided by: University of Teramo
Format: PDF
Indirect jumps are used to implement increasingly common programming language constructs such as virtual function calls, switch-case statements, jump tables, and interface calls. Unfortunately, the prediction accuracy of indirect jumps has remained low because many indirect jumps have multiple targets that are difficult to predict even with specialized hardware. This paper proposes a new way of handling hard-to-predict indirect jumps: dynamically predicating them. The compiler identifies indirect jumps that are suitable for predication along with their Control-Flow Merge (CFM) points. The micro-architecture predicates the instructions between different targets of the jump and its CFM point if the jump turns out to be hard-to-predict at run time.
Download Now

Find By Topic