Publication | Closed Access
LogTM: Log-based Transactional Memory
681
Citations
38
References
2006
Year
Unknown Venue
EngineeringComputer ArchitectureTransactional SystemTransaction ProcessingSoftware AnalysisConcurrency ControlHardware SecurityPer-thread LogSystem SoftwareParallel ComputingLog ManagementData ManagementComputer EngineeringComputer ScienceLog-based Transactional MemoryProgram AnalysisParallel ProgrammingConcurrent Data StructureTransactions AbortTransactional Memory
Transactional memory (TM) simplifies parallel programming by guaranteeing that transactions appear to execute atomically and in isolation. Implementing these properties includes providing data version management for the simultaneous storage of both new (visible if the transaction commits) and old (retained if the transaction aborts) values. Most (hardware) TM systems leave old values "in place" (the target memory address) and buffer new values elsewhere until commit. This makes aborts fast, but penalizes (the much more frequent) commits. In this paper, we present a new implementation of transactional memory, log-based transactional memory (LogTM), that makes commits fast by storing old values to a per-thread log in cacheable virtual memory and storing new values in place. LogTM makes two additional contributions. First, LogTM extends a MOESI directory protocol to enable both fast conflict detection on evicted blocks and fast commit (using lazy cleanup). Second, LogTM handles aborts in (library) software with little performance penalty. Evaluations running micro- and SPLASH-2 benchmarks on a 32-way multiprocessor support our decision to optimize for commit by showing that only 1-2% of transactions abort.
| Year | Citations | |
|---|---|---|
Page 1
Page 1