Issue No.10 - Oct. (2011 vol.22)
Blas Cuesta , Universidad Politécnica de Valencia, Valencia
Antonio Robles , Universidad Politécnica de Valencia, Valencia
José Duato , Universidad Politécnica de Valencia, Valencia
DOI Bookmark: http://doi.ieeecomputersociety.org/10.1109/TPDS.2011.80
Token Coherence is a cache coherence protocol that simultaneously captures the best attributes of the traditional approximations to coherence: direct communication between processors (like snooping-based protocols) and no reliance on bus-like interconnects (like directory-based protocols). This is possible thanks to a class of unordered requests that usually succeed in resolving the cache misses. The problem of the unordered requests is that they can cause protocol races, which prevent some misses from being resolved. To eliminate races and ensure the completion of the unresolved misses, Token Coherence uses a starvation prevention mechanism named persistent requests. This mechanism is extremely inefficient and, besides, it endangers the scalability of Token Coherence since it requires storage structures (at each node) whose size grows proportionally to the system size. While multiprocessors continue including an increasingly number of nodes, both the performance and scalability of cache coherence protocols will continue to be key aspects. In this work, we propose an alternative starvation prevention mechanism, named priority requests, that outperforms the persistent request one. This mechanism is able to reduce the application runtime more than 20 percent (on average) in a 64-processor system. Furthermore, thanks to the flexibility shown by priority requests, it is possible to drastically minimize its storage requirements, thereby improving the whole scalability of Token Coherence. Although this is achieved at the expense of a slight performance degradation, priority requests still outperform persistent requests significantly.
Cache coherence, token coherence, starvation prevention, scalability.
Blas Cuesta, Antonio Robles, José Duato, "Efficient and Scalable Starvation Prevention Mechanism for Token Coherence", IEEE Transactions on Parallel & Distributed Systems, vol.22, no. 10, pp. 1610-1623, Oct. 2011, doi:10.1109/TPDS.2011.80