Efficient memory management for concurrent programs that use message passing

被引:2
|
作者
Sagonas, Konstantinos [1 ]
Wilhelmsson, Jesper [1 ]
机构
[1] Uppsala Univ, Dept Informat Technol, Uppsala, Sweden
关键词
incremental and real-time garbage collection; thread-local heaps; message analysis; concurrent languages; mutator utilization; erlang;
D O I
10.1016/j.scico.2006.02.006
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
We present an efficient memory management scheme for concurrent programming languages where communication occurs by using message passing with copying semantics. The runtime system is built around process-local heaps, which frees the memory manager from redundant synchronization in a multi-threaded implementation and allows the memory reclamation of process-local heaps to be a private business and to often take place without ever triggering garbage collection. The allocator is guided by a static analysis which speculatively allocates data possibly used as messages in a shared memory area. To respect the (soft) real-time requirements of the language, we develop and present in detail a generational, incremental garbage collection scheme tailored to the characteristics of this runtime system. The incremental collector imposes no overhead on the mutator, requires no costly barrier mechanisms, has a relatively small space overhead, and can be scheduled on the basis of either a time or a work quantum. We have implemented these schemes in the context of an industrial-strength implementation of a concurrent functional language used to develop large-scale, highly concurrent, telecommunication applications. Our measurements across a range of applications indicate that the incremental collector imposes only very small overhead on the total runtime and can achieve very short pause times (1 ms or less) while being able to sustain a high degree of mutator utilization. (c) 2006 Elsevier B.V. All rights reserved.
引用
收藏
页码:98 / 121
页数:24
相关论文
共 50 条
  • [1] Message analysis for concurrent programs using message passing
    Carlsson, Richard
    Sagonas, Konstantinos
    Wilhelmsson, Jesper
    [J]. ACM TRANSACTIONS ON PROGRAMMING LANGUAGES AND SYSTEMS, 2006, 28 (04): : 715 - 746
  • [2] Data flow testing in concurrent programs with message passing and shared memory paradigms
    Souza, Paulo S. L.
    Souza, Simone S.
    Rocha, Murilo G.
    Prado, Rafael R.
    Batista, Raphael N.
    [J]. 2013 INTERNATIONAL CONFERENCE ON COMPUTATIONAL SCIENCE, 2013, 18 : 149 - 158
  • [3] Deterministic Replay for Message-Passing-Based Concurrent Programs
    Elwakil, Mohamed
    Yang, Zijiang
    [J]. ACM TRANSACTIONS ON DESIGN AUTOMATION OF ELECTRONIC SYSTEMS, 2012, 17 (03)
  • [4] Incorporating memory layout in the modeling of message passing programs
    Seinstra, FJ
    Koelma, D
    [J]. JOURNAL OF SYSTEMS ARCHITECTURE, 2003, 49 (03) : 109 - 121
  • [5] Incorporating memory layout in the modeling of message passing programs
    Seinstra, FJ
    Koelma, D
    [J]. 10TH EUROMICRO WORKSHOP ON PARALLEL, DISTRIBUTED AND NETWORK-BASED PROCESSING, PROCEEDINGS, 2002, : 293 - 300
  • [6] TIMING PARALLEL PROGRAMS THAT USE MESSAGE PASSING
    KARONIS, NT
    [J]. JOURNAL OF PARALLEL AND DISTRIBUTED COMPUTING, 1992, 14 (01) : 29 - 36
  • [7] Efficient message passing on shared memory multiprocessors
    [J]. Lect Notes Comput Sci, (221):
  • [8] Verifying concurrent message-passing C programs with recursive calls
    Chaki, S
    Clarke, E
    Kidd, N
    Reps, T
    Touili, T
    [J]. TOOLS AND ALGORITHMS FOR THE CONSTRUCTION AND ANALYSIS OF SYSTEMS, PROCEEDINGS, 2006, 3920 : 334 - 349
  • [9] Efficient message passing on UNIX shared memory multiprocessors
    Bernaschi, M
    [J]. FUTURE GENERATION COMPUTER SYSTEMS, 1998, 13 (06) : 443 - 449
  • [10] Efficient reachability testing of asynchronous message-passing programs
    Lei, Y
    Tai, KC
    [J]. EIGHTH IEEE INTERNATIONAL CONFERENCE ON ENGINEERING OF COMPLEX COMPUTER SYSTEMS, PROCEEDINGS, 2002, : 35 - 44