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 条
  • [41] INTRODUCING C plus plus , GUI PROGRAMMING, AND DESIGN PATTERNS WITH QT AT THE "C53" LEVEL
    Ezust, Paul
    [J]. 4TH INTERNATIONAL TECHNOLOGY, EDUCATION AND DEVELOPMENT CONFERENCE (INTED 2010), 2010, : 3131 - 3137
  • [42] McC and Mc#: Unified C plus plus and C# Design Facts Extractors Tools
    Mihancea, Petru Florin
    Ganea, George
    Verebi, Ioana
    Marinescu, Cristina
    Marinescu, Radu
    [J]. NINTH INTERNATIONAL SYMPOSIUM ON SYMBOLIC AND NUMERIC ALGORITHMS FOR SCIENTIFIC COMPUTING, PROCEEDINGS, 2007, : 101 - 104
  • [43] A Comparison of C/C plus plus -based Software/Hardware Co-design Description Languages
    Hu, Ge
    Ren, Shengbing
    Wang, Xie
    [J]. PROCEEDINGS OF THE 9TH INTERNATIONAL CONFERENCE FOR YOUNG COMPUTER SCIENTISTS, VOLS 1-5, 2008, : 1030 - 1034
  • [44] Performance Analysis of Built-in Parallel Reduction's Implementation in OpenMP C/C plus plus Language Extension
    Bliznak, Michal
    Dulik, Tomas
    Jasek, Roman
    [J]. MODERN TRENDS AND TECHNIQUES IN COMPUTER SCIENCE (CSOC 2014), 2014, 285 : 607 - 617
  • [45] Synchronising C/C plus plus and POWER
    Sarkar, Susmit
    Memarian, Kayvan
    Owens, Scott
    Batty, Mark
    Sewell, Peter
    Maranget, Luc
    Alglave, Jade
    Williams, Derek
    [J]. ACM SIGPLAN NOTICES, 2012, 47 (06) : 311 - 321
  • [46] Design and implementation of transactional agents for manipulating distributed objects
    Tanaka, Y
    Enokido, T
    Takizawa, M
    [J]. 19th International Conference on Advanced Information Networking and Applications, Vol 1, Proceedings: AINA 2005, 2005, : 368 - 373
  • [47] Implementation tradeoffs in the design of flexible transactional memory support
    Shriraman, Arrvindh
    Dwarkadas, Sandhya
    Scott, Michael L.
    [J]. JOURNAL OF PARALLEL AND DISTRIBUTED COMPUTING, 2010, 70 (10) : 1068 - 1084
  • [48] An Efficient Software Implementation of Correctly Rounded Operations Extending FMA: a plus b plus c and a x b plus c x d
    Lauter, Christoph
    [J]. 2017 FIFTY-FIRST ASILOMAR CONFERENCE ON SIGNALS, SYSTEMS, AND COMPUTERS, 2017, : 452 - 456
  • [49] Implementation of a Finite State Machine with Active Libraries in C plus
    Juhasz, Zoltan
    Sipos, Adam
    Porkolab, Zoltan
    [J]. GENERATIVE AND TRANSFORMATIONAL TECHNIQUES IN SOFTWARE ENGINEERING II, 2008, 5235 : 474 - 488
  • [50] Employing C plus plus Templates in the Design of a Computer Algebra Library
    Brandt, Alexander
    Moir, Robert H. C.
    Maza, Marc Moreno
    [J]. MATHEMATICAL SOFTWARE - ICMS 2020, 2020, 12097 : 342 - 352