Pulse: a dynamic deadlock detection mechanism using speculative execution

被引:0
|
作者
Li, T [1 ]
Ellis, CS [1 ]
Lebeck, AR [1 ]
Sorin, DJ [1 ]
机构
[1] Duke Univ, Dept Comp Sci, Durham, NC 27706 USA
关键词
D O I
暂无
中图分类号
TP3 [计算技术、计算机技术];
学科分类号
0812 ;
摘要
Deadlock can occur wherever multiple processes interact. Most existing static and dynamic deadlock detection tools focus on simple types of deadlock, such as those caused by incorrect ordering of lock acquisitions. In this paper, we propose Pulse, a novel operating system mechanism that dynamically detects various types of deadlock in application programs. Pulse runs as a system daemon. Periodically, it scans the system for processes that have been blocked for a long time (e.g., waiting on I/O events). To determine if these processes are deadlocked, Pulse speculatively executes them ahead to discover their dependences. Based on this information, it constructs a general resource graph and detects deadlock by checking if the graph contains cycles. The ability to look into the future allows Pulse to detect deadlocks involving consumable resources, such as synchronization semaphores and pipes, which no existing tools can detect. We evaluate Pulse by showing that it can detect deadlocks in the classical dining-philosophers and smokers problems. Furthermore, we show that Pulse can detect a well-known deadlock scenario, which is widely referred to as a denial-of-service vulnerability, in the Apache web server. Our results show that Pulse can detect all these deadlocks within three seconds, and it introduces little performance overhead to normal applications that do not deadlock.
引用
收藏
页码:31 / 44
页数:14
相关论文
共 50 条
  • [1] Dynamic schemes for speculative execution of code
    Raghavan, P
    Shachnai, H
    Yaniv, M
    [J]. SIXTH INTERNATIONAL SYMPOSIUM ON MODELING, ANALYSIS AND SIMULATION OF COMPUTER AND TELECOMMUNICATION SYSTEMS, PROCEEDINGS, 1998, : 309 - 314
  • [2] Dynamic schemes for speculative execution of code
    Raghavan, P
    Shachnai, H
    Yaniv, M
    [J]. PERFORMANCE EVALUATION, 2003, 53 (02) : 125 - 142
  • [3] Compiler support for dynamic speculative pre-execution
    Ro, WW
    Gaudiot, JL
    [J]. INTERACT-7 2003: SEVENTH WORKSHOP ON INTERACTION BETWEEN COMPILERS AND COMPUTER ARCHITECTURES, PROCEEDINGS, 2003, : 14 - 23
  • [4] Static Analysis and Symbolic Execution for Deadlock Detection in MPI Programs
    Douglas, Craig C.
    Krishnamoorthy, Krishanthan
    [J]. COMPUTATIONAL SCIENCE - ICCS 2018, PT II, 2018, 10861 : 783 - 796
  • [5] SPECUSYM: Speculative Symbolic Execution for Cache Timing Leak Detection
    Guo, Shengjian
    Chen, Yueqi
    Li, Peng
    Cheng, Yueqiang
    Wang, Huibo
    Wu, Meng
    Zuo, Zhiqiang
    [J]. 2020 ACM/IEEE 42ND INTERNATIONAL CONFERENCE ON SOFTWARE ENGINEERING (ICSE 2020), 2020, : 1235 - 1247
  • [6] Using predicated execution to improve the performance of a dynamically scheduled machine with speculative execution
    Chang, PY
    Hao, E
    Patt, YN
    Chang, PHP
    [J]. INTERNATIONAL JOURNAL OF PARALLEL PROGRAMMING, 1996, 24 (03) : 209 - 234
  • [7] Execution-based prediction using speculative slices
    Zilles, C
    Sohi, G
    [J]. 28TH ANNUAL INTERNATIONAL SYMPOSIUM ON COMPUTER ARCHITECTURE, PROCEEDINGS, 2001, : 2 - 13
  • [8] SVP: Safe and Efficient Speculative Execution Mechanism through Value Prediction
    Wang, Kaixuan
    Qin, Xinyu
    Yang, Zhuoyuan
    He, Weiliang
    Liu, Yifan
    Han, Jun
    [J]. PROCEEDINGS OF THE GREAT LAKES SYMPOSIUM ON VLSI 2023, GLSVLSI 2023, 2023, : 433 - 437
  • [9] Dynamic Scheduling for Speculative Execution to Improve MapReduce Performance in Heterogeneous Environment
    Jung, Hyungjae
    Nakazato, Hidenori
    [J]. 2014 IEEE 34TH INTERNATIONAL CONFERENCE ON DISTRIBUTED COMPUTING SYSTEMS WORKSHOPS (ICDCSW), 2014, : 119 - 124
  • [10] A dynamic default revision mechanism for speculative computation
    Tiago Oliveira
    Ken Satoh
    Paulo Novais
    José Neves
    Hiroshi Hosobe
    [J]. Autonomous Agents and Multi-Agent Systems, 2017, 31 : 656 - 695