Design and Implementation of Transactional Constructs for C/C plus

被引:0
|
作者
Ni, Yang [1 ]
Welc, Adam [1 ]
Adl-Tabatabai, Ali-Reza [1 ]
Bach, Moshe [1 ]
Berkowits, Sion [1 ]
Cownie, James [1 ]
Geva, Robert [1 ]
Kozhukow, Sergey [1 ]
Narayanaswamy, Ravi [1 ]
Olivier, Jeffrey [1 ]
Preis, Serguei [1 ]
Saha, Bratin [1 ]
Tal, Ady [1 ]
Tian, Xinmin [1 ]
机构
[1] Intel Corp, Santa Clara, CA 95051 USA
关键词
Transactional memory; C/C plus;
D O I
暂无
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
This paper presents a software transactional memory system that introduces first-class C++ language constructs for transactional pro-ramming. We describe new C++ language extensions, a production-quality optimizing C++ compiler that translates and optimizes these extensions, and a high-performance STM runtime library. The transactional language constructs support C++ language features including classes, inheritance, virtual functions, exception handling, and templates. The compiler automatically instruments the program for transactional execution and optimizes TM overheads. The runtime library implements multiple execution modes and implements a novel STM algorithm that supports both optimistic and pessimistic concurrency control. The runtime switches a transaction's execution mode dynamically to improve performance and to handle calls to precompiled functions and I/O libraries. We present experimental results on 8 cores (two quad-core CPUs) running a set of 20 non-trivial parallel programs. Our measurements show that our system scales well as the numbers of cores increases and that our compiler and runtime optimizations improve scalability.
引用
收藏
页码:195 / 211
页数:17
相关论文
共 50 条
  • [1] 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
  • [2] 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
  • [3] REFACTORING OF C/C plus plus PREPROCESSOR CONSTRUCTS AT THE MODEL LEVEL
    Vidacs, Laszlo
    [J]. ICSOFT 2009: PROCEEDINGS OF THE 4TH INTERNATIONAL CONFERENCE ON SOFTWARE AND DATA TECHNOLOGIES, VOL 1, 2009, : 232 - 237
  • [4] Simplifying Transactional Memory Support in C plus
    Zardoshti, Pantea
    Zhou, Tingzhe
    Balaji, Pavithra
    Scott, Michael L.
    Spear, Michael
    [J]. ACM TRANSACTIONS ON ARCHITECTURE AND CODE OPTIMIZATION, 2019, 16 (03)
  • [5] 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
  • [6] An empirical study on C plus plus concurrency constructs
    Wu, Di
    Chen, Lin
    Zhou, Yuming
    Xu, Baowen
    [J]. 2015 ACM/IEEE INTERNATIONAL SYMPOSIUM ON EMPIRICAL SOFTWARE ENGINEERING AND MEASUREMENT (ESEM), 2015, : 257 - 266
  • [7] CCmutator: A Mutation Generator for Concurrency Constructs in Multithreaded C/C plus plus Applications
    Kusano, Markus
    Wang, Chao
    [J]. 2013 28TH IEEE/ACM INTERNATIONAL CONFERENCE ON AUTOMATED SOFTWARE ENGINEERING (ASE), 2013, : 722 - 725
  • [8] An extensive empirical study on C plus plus concurrency constructs
    Wu, Di
    Chen, Lin
    Zhou, Yuming
    Xu, Baowen
    [J]. INFORMATION AND SOFTWARE TECHNOLOGY, 2016, 76 : 1 - 18
  • [9] Design and Implementation of a Language-Complete C plus plus Semantic Graph
    Duffy, Edward B.
    Malloy, Brian A.
    [J]. PROCEEDINGS OF THE 50TH ANNUAL ASSOCIATION FOR COMPUTING MACHINERY SOUTHEAST CONFERENCE, 2012,
  • [10] The Use of C plus plus Exception Handling Constructs: A Comprehensive Study
    Bonifacio, Rodrigo
    Carvalho, Fausto
    Ramos, Guilherme N.
    Kulesza, Uira
    Coelho, Roberta
    [J]. 2015 IEEE 15TH INTERNATIONAL WORKING CONFERENCE ON SOURCE CODE ANALYSIS AND MANIPULATION (SCAM), 2015, : 21 - 30