Simplifying Transactional Memory Support in C plus

被引:8
|
作者
Zardoshti, Pantea [1 ,3 ]
Zhou, Tingzhe [1 ,3 ]
Balaji, Pavithra [1 ,3 ]
Scott, Michael L. [2 ]
Spear, Michael [1 ,3 ]
机构
[1] Lehigh Univ, Bethlehem, PA 18015 USA
[2] Univ Rochester, Comp Sci Dept, 3401 Wegmans Hall, Rochester, NY 14627 USA
[3] Bldg C,113 Res Dr,Lehigh Mountaintop Campus, Bethlehem, PA 18015 USA
关键词
Transactional memory; LLVM; C plus; synchronization;
D O I
10.1145/3328796
中图分类号
TP3 [计算技术、计算机技术];
学科分类号
0812 ;
摘要
C++ has supported a provisional version of Transactional Memory (TM) since 2015, via a technical specification. However, TM has not seen widespread adoption, and compiler vendors have been slow to implement the technical specification. We conjecture that the proposed TM support is too difficult for programmers to use, too complex for compiler designers to implement and verify, and not industry-proven enough to justify final standardization in its current form. To address these problems, we present a different design for supporting TM in C++. By forbidding explicit self-abort, and by introducing an executor-based mechanism for running transactions, our approach makes it easier for developers to get code up and running with TM. Our proposal should also be appealing to compiler developers, as it allows a spectrum of levels of support for TM, with varying performance, and varying reliance on hardware TM support in order to provide scalability. While our design does not enable some of the optimizations admitted by the current technical specification, we show that it enables the implementation of robust support for TM in a small, orthogonal compiler extension. Our implementation is able to handle a wide range of transactional programs, delivering low instrumentation overhead and scalability and performance on par with the current state of the art. Based on this experience, we believe our approach to be a viable means of reinvigorating the standardization of TM in C++.
引用
收藏
页数:24
相关论文
共 50 条
  • [1] On Monitoring C/C plus plus Transactional Memory Programs
    Fiedor, Jan
    Letko, Zdenek
    Lourenco, Joao
    Vojnar, Tomas
    [J]. MATHEMATICAL AND ENGINEERING METHODS IN COMPUTER SCIENCE, MEMICS 2014, 2014, 8934 : 73 - 87
  • [2] Towards Transactional Memory Semantics for C plus
    Shpeisman, Tatiana
    Adl-Tabatabai, Ali-Reza
    Geva, Robert
    Ni, Yang
    Welc, Adam
    [J]. SPAA'09: PROCEEDINGS OF THE TWENTY-FIRST ANNUAL SYMPOSIUM ON PARALLELISM IN ALGORITHMS AND ARCHITECTURES, 2009, : 49 - 58
  • [3] Simplifying Concurrent Algorithms by Exploiting Hardware Transactional Memory
    Dice, Dave
    Moir, Mark
    Lev, Yossi
    Nussbaum, Dan
    Marathe, Virendra J.
    Olszewski, Marek
    [J]. SPAA '10: PROCEEDINGS OF THE TWENTY-SECOND ANNUAL SYMPOSIUM ON PARALLELISM IN ALGORITHMS AND ARCHITECTURES, 2010, : 325 - 334
  • [4] Flexible decoupled transactional memory support
    Shriraman, Arrvindh
    Dwarkadas, Sandhya
    Scott, Michael L.
    [J]. ISCA 2008 PROCEEDINGS: 35TH INTERNATIONAL SYMPOSIUM ON COMPUTER ARCHITECTURE, 2008, : 139 - 150
  • [5] Architectural support for software transactional memory
    Saha, Bratin
    Adl-Tabatabai, Ali-Reza
    Jacobson, Quinn
    [J]. MICRO-39: PROCEEDINGS OF THE 39TH ANNUAL IEEE/ACM INTERNATIONAL SYMPOSIUM ON MICROARCHITECTURE, 2006, : 185 - +
  • [6] Scheduling Support for Transactional Memory Contention Management
    Maldonado, Walther
    Marlier, Patrick
    Felber, Pascal
    Suissa, Adi
    Hendler, Danny
    Fedorova, Alexandra
    Lawall, Julia L.
    Muller, Gilles
    [J]. ACM SIGPLAN NOTICES, 2010, 45 (05) : 79 - 89
  • [7] Scheduling Support for Transactional Memory Contention Management
    Maldonado, Walther
    Marlier, Patrick
    Felber, Pascal
    Suissa, Adi
    Hendler, Danny
    Fedorova, Alexandra
    Lawall, Julia L.
    Muller, Gilles
    [J]. PPOPP 2010: PROCEEDINGS OF THE 2010 ACM SIGPLAN SYMPOSIUM ON PRINCIPLES AND PRACTICE OF PARALLEL PROGRAMMING, 2010, : 79 - 89
  • [8] Transactional memory analysis using CSB plus trees
    Bansal, Rishab
    Ramachandran, Puvichakravarthy
    [J]. INTERNATIONAL CONFERENCE ON ADVANCES IN INFORMATION COMMUNICATION TECHNOLOGY & COMPUTING, 2016, 2016,
  • [9] Design and Implementation of Transactional Constructs for C/C plus
    Ni, Yang
    Welc, Adam
    Adl-Tabatabai, Ali-Reza
    Bach, Moshe
    Berkowits, Sion
    Cownie, James
    Geva, Robert
    Kozhukow, Sergey
    Narayanaswamy, Ravi
    Olivier, Jeffrey
    Preis, Serguei
    Saha, Bratin
    Tal, Ady
    Tian, Xinmin
    [J]. OOPSLA 2008 NASHVILLE, CONFERENCE PROCEEDINGS, 2008, : 195 - 211
  • [10] Design and Implementation of Transactional Constructs for C/C plus
    Ni, Yang
    Welc, Adam
    Adl-Tabatabai, Ali-Reza
    Bach, Moshe
    Berkowits, Sion
    Cownie, James
    Geva, Robert
    Kozhukow, Sergey
    Narayanaswamy, Ravi
    Olivier, Jeffrey
    Preis, Serguei
    Saha, Bratin
    Tal, Ady
    Tian, Xinmin
    [J]. ACM SIGPLAN NOTICES, 2008, 43 (10) : 195 - 211