Title : 
Using a Reconfigurable L1 Data Cache for Efficient Version Management in Hardware Transactional Memory
         
        
            Author : 
Armejach, Adrià ; Seyedi, Azam ; Titos-Gil, Rubén ; Hur, Ibrahim ; Cristal, Adrián ; Unsal, Osman ; Valero, Mateo
         
        
        
        
        
        
            Abstract : 
Transactional Memory (TM) potentially simplifies parallel programming by providing atomicity and isolation for executed transactions. One of the key mechanisms to provide such properties is version management, which defines where and how transactional updates (new values) are stored. Version management can be implemented either eagerly or lazily. In Hardware Transactional Memory (HTM) implementations, eager version management puts new values in-place and old values are kept in a software log, while lazy version management stores new values in hardware buffers keeping old values in-place. Current HTM implementations, for both eager and lazy version management schemes, suffer from performance penalties due to the inability to handle two versions of the same logical data efficiently. In this paper, we introduce a reconfigurable L1 data cache architecture that has two execution modes: a 64KB general purpose mode and a 32KB TM mode which is able to manage two versions of the same logical data. The latter allows to handle old and new transactional values within the cache simultaneously when executing transactional workloads. We explain in detail the architectural design and internals of this Reconfigurable Data Cache (RDC), as well as the supported operations that allow to efficiently solve existing version management problems. We describe how the RDC can support both eager and lazy HTM systems, and we present two RDC-HTM designs. Our evaluation shows that the Eager-RDC-HTM and Lazy-RDC-HTM systems achieve 1.36× and 1.18× speedup, respectively, over state-of-the-art proposals. We also evaluate the area and energy effects of our proposal, and we find that RDC designs are 1.92× and 1.38× more energy-delay efficient compared to baseline HTM systems, with less than 0.3% area impact on modern processors.
         
        
            Keywords : 
cache storage; concurrency control; configuration management; memory architecture; parallel programming; reconfigurable architectures; Eager-RDC-HTM systems; Lazy-RDC-HTM systems; hardware buffers; hardware transactional memory; lazy version management; logical data; parallel programming; reconfigurable L1 data cache; software log; transactional updates; version management; Computer architecture; Decoding; Hardware; Indexes; Microprocessors; Proposals; Software; hardware transactional memory; reconfigurable cache; version management;
         
        
        
        
            Conference_Titel : 
Parallel Architectures and Compilation Techniques (PACT), 2011 International Conference on
         
        
            Conference_Location : 
Galveston, TX
         
        
        
            Print_ISBN : 
978-1-4577-1794-9
         
        
        
            DOI : 
10.1109/PACT.2011.67