Dynamic hammock predication for non-predicated instruction set architectures | IEEE Conference Publication | IEEE Xplore

Dynamic hammock predication for non-predicated instruction set architectures


Abstract:

Conventional speculative architectures use branch prediction to evaluate the most likely execution path during program execution. However certain branches are difficult t...Show More

Abstract:

Conventional speculative architectures use branch prediction to evaluate the most likely execution path during program execution. However certain branches are difficult to predict. One solution to this problem is to evaluate both paths following such a conditional branch. Predicated execution can be used to implement this form of multi-path execution. Predicated architectures fetch and issue instructions that have associated predicates. These predicates indicate if the instruction should commit its result. Predicating a branch reduces the number of branches executed, eliminating the chance of branch misprediction at the cost of executing additional instructions. In this paper, we propose a restricted form of multi-path execution called Dynamic Predication for architectures with little or no support for predicated instructions in their instruction set. Dynamic predication dynamically predicates instruction sequences in the form of a branch hammock concurrently executing both paths of the branch. A branch hammock is a short forward branch that spans a few instructions in the form of an if-then or if-then-else construct we mark these and other constructs in the executable. When the decode stage detects such a sequence, it passes a predicated instruction sequence to a dynamically scheduled execution core. Our results show that dynamic predication can accrue speedups of up to 13%.
Date of Conference: 18-18 October 1998
Date Added to IEEE Xplore: 06 August 2002
Print ISBN:0-8186-8591-3
Print ISSN: 1089-795X
Conference Location: Paris, France

Contact IEEE to Subscribe

References

References is not available for this document.