Skip to main content

PipeCheck: Specifying and Verifying Microarchitectural Enforcement of Memory Consistency Models

Author(s): Lustig, Daniel; Pellauer, Michael; Martonosi, Margaret

Download
To refer to this page use: http://arks.princeton.edu/ark:/88435/pr10j83
Full metadata record
DC FieldValueLanguage
dc.contributor.authorLustig, Daniel-
dc.contributor.authorPellauer, Michael-
dc.contributor.authorMartonosi, Margaret-
dc.date.accessioned2021-10-08T19:45:26Z-
dc.date.available2021-10-08T19:45:26Z-
dc.date.issued2014en_US
dc.identifier.citationLustig, Daniel, Michael Pellauer, and Margaret Martonosi. "PipeCheck: Specifying and Verifying Microarchitectural Enforcement of Memory Consistency Models." 47th Annual IEEE/ACM International Symposium on Microarchitecture (2014): pp. 635-646. doi:10.1109/MICRO.2014.38en_US
dc.identifier.issn1072-4451-
dc.identifier.urihttps://mrmgroup.cs.princeton.edu/papers/dlustig_MICRO14header.pdf-
dc.identifier.urihttp://arks.princeton.edu/ark:/88435/pr10j83-
dc.description.abstractWe present PipeCheck, a methodology and automated tool for verifying that a particular micro architecture correctly implements the consistency model required by its architectural specification. PipeCheck adapts the notion of a "happens before" graph from architecture-level analysis techniques to the micro architecture space. Each node in the "micro architecturally happens before" (μhb) graph represents not only a memory instruction, but also a particular location (e.g., Pipeline stage) within the micro architecture. Architectural specifications such as "preserved program order" are then treated as propositions to be verified, rather than simply as assumptions. PipeCheck allows an architect to easily and rigorously test whether a micro architecture is stronger than, equal in strength to, or weaker than its architecturally-specified consistency model. We also specify and analyze the behavior of common micro architectural optimizations such as speculative load reordering which technically violate formal architecture-level definitions. We evaluate PipeCheck using a library of established litmus tests on a set of open-source pipelines. Using PipeCheck, we were able to validate the largest pipeline, the Open SPARC T2, in just minutes. We also identified a bug in the O3 pipeline of the gem5 simulator.en_US
dc.format.extent635 - 646en_US
dc.language.isoen_USen_US
dc.relation.ispartof47th Annual IEEE/ACM International Symposium on Microarchitectureen_US
dc.rightsAuthor's manuscripten_US
dc.titlePipeCheck: Specifying and Verifying Microarchitectural Enforcement of Memory Consistency Modelsen_US
dc.typeConference Articleen_US
dc.identifier.doi10.1109/MICRO.2014.38-
dc.identifier.eissn2379-3155-
pu.type.symplectichttp://www.symplectic.co.uk/publications/atom-terms/1.0/conference-proceedingen_US

Files in This Item:
File Description SizeFormat 
PipeCheckMicroarchitecturalEnforceConsistencyMod.pdf824.53 kBAdobe PDFView/Download


Items in OAR@Princeton are protected by copyright, with all rights reserved, unless otherwise indicated.