An analysis of I/O and syscalls in critical sections and their implications for transactional memory

Lee Baugh, Craig Zilles

Research output: Chapter in Book/Report/Conference proceedingConference contribution

Abstract

Transactional memory (TM) is a scalable and concurrent way to build atomic sections. One aspect of TM that remains unclear is how side-effecting operations - that is, those which cannot be transparently undone by a TM system - should be handled. This uncertainty poses a significant barrier to the general applicability and acceptance of TM. Further, the absence of transactional workloads makes it difficult to study this aspect In this paper, we characterize the usage of I/O, and in particular system calls, within critical sections in two large applications, exploring both the actions performed and the characteristics of the critical sections in which they are performed. Shared memory programs employing critical sections are the closest approximation available to transactional workloads, so using this characterization, we attempt to reason about how the behavior we observed relates to the previous proposals for handling side-effecting operations within transactions. We find that the large majority of sysculls performed within critical sections can be handled with a range of existing techniques in a way transparent to the application developer. We also find that while side-effecting critical sections are rare, they tend to be quite long-lasting, and that many of these critical sections perform their first syscall (and thus become side-effecting) relatively early in their execution. Finally, we show that while these long-lived, side-effecting critical sections tend to execute concurrently with many critical sections on other threads, we observe little concurrency between side-effecting critical sections.

Original languageEnglish (US)
Title of host publicationISPASS 2008 - IEEE International Symposium on Performance Analysis of Systems and Software
Pages54-62
Number of pages9
DOIs
StatePublished - 2008
EventIEEE International Symposium on Performance Analysis of Systems and Software, ISPASS 2008 - Austin, TX, United States
Duration: Apr 20 2008Apr 22 2008

Publication series

NameISPASS 2008 - IEEE International Symposium on Performance Analysis of Systems and Software

Other

OtherIEEE International Symposium on Performance Analysis of Systems and Software, ISPASS 2008
Country/TerritoryUnited States
CityAustin, TX
Period4/20/084/22/08

ASJC Scopus subject areas

  • Computer Science Applications
  • Software
  • Theoretical Computer Science

Fingerprint

Dive into the research topics of 'An analysis of I/O and syscalls in critical sections and their implications for transactional memory'. Together they form a unique fingerprint.

Cite this