CN105022692A - 一种死锁检测验证方法 - Google Patents

一种死锁检测验证方法 Download PDF

Info

Publication number
CN105022692A
CN105022692A CN201510477035.9A CN201510477035A CN105022692A CN 105022692 A CN105022692 A CN 105022692A CN 201510477035 A CN201510477035 A CN 201510477035A CN 105022692 A CN105022692 A CN 105022692A
Authority
CN
China
Prior art keywords
deadlock
state
deadlock detection
model
ctl
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201510477035.9A
Other languages
English (en)
Other versions
CN105022692B (zh
Inventor
杨秋辉
代声馨
张琼宇
孙琳
何洋
杜伊
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sichuan University
Original Assignee
Sichuan University
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sichuan University filed Critical Sichuan University
Priority to CN201510477035.9A priority Critical patent/CN105022692B/zh
Publication of CN105022692A publication Critical patent/CN105022692A/zh
Application granted granted Critical
Publication of CN105022692B publication Critical patent/CN105022692B/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Debugging And Monitoring (AREA)

Abstract

本发明公开了一种死锁检测验证方法,包括:提取出待测进程的状态、状态转移关系;建立不同的死锁检测模板;将进程的状态、状态转移关系以及建模属性按照类别分别写入XML配置文件;读取XML配置文件,选择相应的死锁检测模板进行模型检测:生成时态逻辑表达式CTL,将进程的状态和状态转移关系及时态逻辑表达式CTL转换为SMV模型;执行SMV模型,分析执行结果中时态逻辑表达式CTL的真值,判断设计文档是否包含死锁。本发明通过自动分析死锁检测相关信息的输入自动选择相应模板转换为SMV模型的原型,降低了死锁检测的难度;本方法不受软件开发语言限制,可以在***设计阶段对设计方案进行死锁检测,比在软件开发阶段再发现死锁更能减少不必要的损失。

Description

一种死锁检测验证方法
技术领域
本发明涉及软件设计技术领域,具体为一种死锁检测验证方法。
背景技术
死锁是并发***中比较常见的软件设计缺陷,也是非常典型的解决并发安全所需关注的问题。死锁的发生会导致程序无限等待或资源严重消耗,使整个***没有可用资源而陷于瘫痪,严重影响***安全性和可靠性。
SMV工具是美国CMU计算机学院的L.McMillan博士于1992年开发出的模型检验工具软件,它基于符号模型检验(Symbolic Model Checking)技术,目前为国际上广为流行的分析有限状态***的常用工具,SMV有多个版本,如:CMU-SMV、Cadence-SMV、NuSMV等。
死锁检测的方法主要可以分为静态和动态两大类。静态方法最基本的是代码检查,而所有直接在源程序上做静态死锁检测的技术,都会使用静态程序分析技术。静态程序分析技术是对并发程序的源代码或者规格说明进行人工或者自动化分析,然后通过分析获得程序各个模块的数据依赖关系。静态方法能取得一定的效果,但如果出现并发缺陷如死锁和活锁,其产生来源于特定的程序状态,而且并发软件状态空间非常庞大,这就会使得以人工为主的代码检查难以胜任。
动态方法则是通过并发程序在真实环境或模拟环境中运行,通过检测软件对运行信息进行收集,然后利用收集到的信息进行死锁检测。动态分析方法可以分为测试和监控两大类。动态方法只能覆盖到有限的软件运行情况,对于死锁这类出现概率低的缺陷,并不能有效的检测。
模型检测是静态死锁检测方法中的一种,基本方法是使用并发的模型来描述***,在模型验证时如果模型处于某个非终止状态且没有可达的后继状态时,则发现了死锁。对于模型检测来说,因为并发软件各并发进程之间庞大的交织状态空间,使得模型过于庞大复杂,难以手动构造。所以除了状态空间***问题外,模型的构造也是需要解决的问题。
发明内容
针对上述问题,本发明的目的在于提供一种死锁检测验证方法,该方法可以在***设计阶段对设计方案进行死锁检测,比较容易发现并发缺陷。技术方案如下:
一种死锁检测验证方法,包括:
从并发***设计文档中提取出待测进程的状态、状态转移关系;
根据进程的执行方式及并发控制中的项目建立不同的死锁检测模板;
将进程的状态、状态转移关系以及建模属性按照类别分别写入XML配置文件;
读取XML配置文件,选择相应的死锁检测模板进行模型检测:分析进程的状态及状态转移关系,生成时态逻辑表达式CTL,将进程的状态和状态转移关系及时态逻辑表达式CTL转换为SMV模型;
执行SMV模型,并将执行结果存入文本文档;
读取文本文档,分析执行结果中时态逻辑表达式CTL的真值;
根据通过算法分析CTL的真值判断设计文档是否包含死锁:
若时态逻辑表达式CTL为TRUE,则设计文档没有产生死锁;
若时态逻辑表达式CTL为FALSE,则设计文档产生死锁。
进一步的,所述死锁检测模板建立的方法包括:
将进程同步执行和异步执行抽象为第一组的两个模型检测模板;
将并发控制中的条件变量、互斥锁和信号变量抽象为第二组的三个模型检测模板;
将第一组中的模型检测模板和第二组中的模型检测模板一一组合生成六个死锁检测模板。
更进一步的,还包括:若设计文档产生死锁,则输出产生死锁的执行路径。
更进一步的,还包括选择模型检测工具NuSMV作为模型检测的建模和验证工具。
本发明的有益效果是:本发明通过自动分析死锁检测相关信息的输入自动选择相应模板转换为SMV模型的原型,降低了死锁检测的难度;本方法不受软件开发语言限制,可以在***设计阶段对设计方案进行死锁检测,比在软件开发阶段再发现死锁更能减少不必要的损失。
附图说明
图1为本发明死锁检测验证方法的流程框图。
具体实施方式
下面结合具体实施例对本发明做进一步说明。提出了一种基于模型检测工具NuSMV对死锁进行检测的方法,本方法能够有效的对同步和异步这两种模式下的信号量、条件变量、互斥锁机制引发的死锁进行检测,并且可以在***架构设计阶段就可对抽象出的并发信息进行死锁检测,无需获取源代码。
选择模型检测工具NuSMV作为模型检测的建模和验证工具,并借助于NuSMV对状态空间的穷举搜索,对设计模板进行验证。在设计时选取XML文件作为中间载体对相关信息存储,对用户输入的建模属性和状态转移关系按类别输入到XML文件当中,然后针对生成的XML文件再次读取,对属性分析处理然后转换成NuSMV可识别的SMV模型。
在基于NuSMV进行死锁检测时可以对进程同步执行和异步执行抽象为两个模型检测模板,在对并发控制中使用条件变量、互斥锁和信号量又可以抽象为3个模型检测模板,这样针对同步和异步以及这两种模式下的条件变量、互斥锁和信号量总共可以抽象出6个针对不同模式的死锁检测模板,只需根据并发模式把并发进程的状态及状态转移关系相关信息输入到算法,就会自动转换为用于死锁检测的SMV模型。
具体过程如下:
1.建立模型:从并发***设计文档中提取出待测进程的状态及状态转移关系。
2.根据进程的执行方式及并发控制中的项目建立不同的死锁检测模板。
具体在步骤为:
将进程同步执行和异步执行抽象为第一组的两个模型检测模板;
将并发控制中的条件变量、互斥锁和信号变量抽象为第二组的三个模型检测模板;
将第一组中的模型检测模板和第二组中的模型检测模板一一组合生成六个死锁检测模板。
3.将进程的状态、状态转移关系以及建模属性按照类别分别写入XML配置文件。这样可以根据XML配置文件的属性名称更容易区分状态和转移关系。
4.读取XML配置文件,根据XML配置文件中的属性名称获取进程的状态及状态转移关系。根据获得的并发类型自动选择相应死锁检测模板,然后进行模型检测:分析进程的状态及状态转移关系,根据临界区状态生成用于验证死锁的时态逻辑表达式CTL,将进程的状态和状态转移关系及时态逻辑表达式CTL转换为NuSMV可执行的SMV模型。
5.通过自动化执行SMV模型,并将执行结果存入文本文档。
6.读取文本文档,通过算法分析执行结果中时态逻辑表达式CTL的真值。
7.根据通过算法分析CTL的真值判断设计文档是否包含死锁:
若时态逻辑表达式CTL为TRUE,则设计文档没有产生死锁;
若时态逻辑表达式CTL为FALSE,则设计文档产生死锁,则输出产生死锁的执行路径。
具体实施例如下:
用一个同步互斥锁的例子来完成死锁检测步骤的分析:有两个石匠在同一个生产线雕刻一个雕像,但是只有一套工具,如果石匠空闲,他就可以继续休息或者准备一下去工作,准备工作完成后如果工具可以使用,那么他就可以去生产线工作,工作完成一个阶段后他可以选择休息或者继续工作,如果选择休息他就会把自己手中的工具放下,另外一名石匠可以拿起去工作。
(1)分析***设计文档,对***进行抽象。该实施例是一个同步互斥锁的例子,通过分析例子中的设计需求,得到有两个进程(工人),进程的工作状态分空闲状态、准备状态、工作状态三个状态。初始状态为空闲状态,工作完成后就解锁(放下工具)。空闲状态的下一个状态可以是继续空闲状态或者变为准备状态,如果处于准备状态且互斥锁可用的话,就可以工作,否则处于准备状态等待获得锁。工作之后状态变为空闲并释放锁。
首先针对以上信息进行具体化,把抽象中的状态及状态转移关系抽象为代码级别的原语。
状态(state):rest(休息)、prepare(准备)、work(工作),临界区为work
互斥锁:mutex
进程状态转移关系:rest→{rest,prepare};
prepare&mutex→work;
work→rest;
TRUE→state;
互斥锁状态转移关系:work→FALSE;
!work&mutex!=TRUE→TRUE;
TRUE→mutex;
(2)把上一步中的状态及状态转移关系输入到死锁检测原型并选择相应要检测死锁类型,生成用于信息记录的XML配置文件。XML配置文件中记录了并发的方式、进程名称初始化状态以及按照属性分类的状态转移信息。生成的XML配置文件格式如下:
(3)根据第一步中抽象出来的进程状态和临界区,生成时态逻辑表达式CTL,用来判断状态是否可达,从而进一步判断是否有死锁产生。生成的时态逻辑表达式如下:
SPEC EF(job1.state=work);
SPEC EF!(job1.state=work&job2.state=work)
SPEC AG(job1.state=prepare→AF job1.state=work)
(4)根据时态逻辑表达式CTL和XML配置文件生成SMV模型。本例子中转换之后的SMV模型如下所示:
(5)执行生成的SMV模型,并把结果输出到文本文档保存,再次读取文本文档,对结果进行分析,找到时态逻辑表达式,根据时态逻辑表达式显示检测结果,其检测结果如下:
其中分析时态逻辑表达式为:
EF job1.state=work is true
EF!(job1.state=work&job2.state=work)is true
AG(job1.state=prepare->AF job1.state=work)is false
检测结果显示该例子产生了死锁,当job1处于准备状态时,有一条执行路径将导致他永远也不能进入工作状态。
分析:第四步中,当job2占有了互斥锁之后变为rest状态,但是他没有去释放资源,自己又误认为已经释放资源等待其他进程释放资源,job1也在等待job2释放资源,两个进程将一直等待下去。

Claims (4)

1.一种死锁检测验证方法,其特征在于,包括:
从并发***设计文档中提取出待测进程的状态、状态转移关系;
根据进程的执行方式及并发控制中的项目建立不同的死锁检测模板;
将进程的状态、状态转移关系以及建模属性按照类别分别写入XML配置文件;
读取XML配置文件,选择相应的死锁检测模板进行模型检测:分析进程的状态及状态转移关系,生成时态逻辑表达式CTL,将进程的状态和状态转移关系及时态逻辑表达式CTL转换为SMV模型;
执行SMV模型,并将执行结果存入文本文档;
读取文本文档,分析执行结果中时态逻辑表达式CTL的真值;
根据通过算法分析CTL的真值判断设计文档是否包含死锁:
若时态逻辑表达式CTL为TRUE,则设计文档没有产生死锁;
若时态逻辑表达式CTL为FALSE,则设计文档产生死锁。
2.根据权利要求1所述的死锁检测验证方法,其特征在于,所述死锁检测模板建立的方法包括:
将进程同步执行和异步执行抽象为第一组的两个模型检测模板;
将并发控制中的条件变量、互斥锁和信号变量抽象为第二组的三个模型检测模板;
将第一组中的模型检测模板和第二组中的模型检测模板一一组合生成六个死锁检测模板。
3.根据权利要求1所述的死锁检测验证方法,其特征在于,还包括:若设计文档产生死锁,则输出产生死锁的执行路径。
4.根据权利要求1所述的死锁检测验证方法,其特征在于,还包括选择模型检测工具NuSMV作为模型检测的建模和验证工具。
CN201510477035.9A 2015-08-06 2015-08-06 一种死锁检测验证方法 Expired - Fee Related CN105022692B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510477035.9A CN105022692B (zh) 2015-08-06 2015-08-06 一种死锁检测验证方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510477035.9A CN105022692B (zh) 2015-08-06 2015-08-06 一种死锁检测验证方法

Publications (2)

Publication Number Publication Date
CN105022692A true CN105022692A (zh) 2015-11-04
CN105022692B CN105022692B (zh) 2017-12-01

Family

ID=54412680

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510477035.9A Expired - Fee Related CN105022692B (zh) 2015-08-06 2015-08-06 一种死锁检测验证方法

Country Status (1)

Country Link
CN (1) CN105022692B (zh)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105930722A (zh) * 2016-04-27 2016-09-07 宇龙计算机通信科技(深圳)有限公司 一种基于形式化描述的移动终端安全性检测方法及装置
CN106201731A (zh) * 2016-07-07 2016-12-07 浪潮(北京)电子信息产业有限公司 一种用户态读写锁死锁检测方法及***
CN106201730A (zh) * 2016-07-07 2016-12-07 浪潮(北京)电子信息产业有限公司 一种linux用户态互斥锁死锁检测方法及***
US11062069B1 (en) 2020-03-11 2021-07-13 Mellanox Technologies, Ltd. Bounded deadlock check
CN113157353A (zh) * 2021-04-19 2021-07-23 河南科技大学 一种有限状态自动机的状态锁的检测方法及***

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101833504A (zh) * 2010-04-19 2010-09-15 张翀斌 一种基于模型检验的时序软件质量缺陷检测方法及***
CN102722441A (zh) * 2012-06-11 2012-10-10 清华大学 智能的uml模型的形式化检测方法及装置

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101833504A (zh) * 2010-04-19 2010-09-15 张翀斌 一种基于模型检验的时序软件质量缺陷检测方法及***
CN102722441A (zh) * 2012-06-11 2012-10-10 清华大学 智能的uml模型的形式化检测方法及装置

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
MUSTAPHA BOURAHLA ET AL: "Verification of Real-time Systems by Abstraction of Time Constraints", 《PARELLEL AND DISTRIBUTED PROCESSING SYMPOSIUM,2003.PROCEEDINGS.INTERNATIONAL》 *
NIKOLA BOGUNOVIC ET AL: "Verification of mutual exclusion algorithms with SMV System", 《EUROCON 2003.COMPUTER AS A TOOL.THE IEEE REGION 8》 *
潘敏学等: "死锁检测工具的能力分析与综合应用", 《计算机科学与探索》 *

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105930722A (zh) * 2016-04-27 2016-09-07 宇龙计算机通信科技(深圳)有限公司 一种基于形式化描述的移动终端安全性检测方法及装置
CN105930722B (zh) * 2016-04-27 2018-11-06 宇龙计算机通信科技(深圳)有限公司 一种基于形式化描述的移动终端安全性检测方法及装置
CN106201731A (zh) * 2016-07-07 2016-12-07 浪潮(北京)电子信息产业有限公司 一种用户态读写锁死锁检测方法及***
CN106201730A (zh) * 2016-07-07 2016-12-07 浪潮(北京)电子信息产业有限公司 一种linux用户态互斥锁死锁检测方法及***
US11062069B1 (en) 2020-03-11 2021-07-13 Mellanox Technologies, Ltd. Bounded deadlock check
CN113157353A (zh) * 2021-04-19 2021-07-23 河南科技大学 一种有限状态自动机的状态锁的检测方法及***

Also Published As

Publication number Publication date
CN105022692B (zh) 2017-12-01

Similar Documents

Publication Publication Date Title
CN105022692A (zh) 一种死锁检测验证方法
Rasool et al. Flexible design pattern detection based on feature types
JP6387182B2 (ja) 情報処理方法、装置及びコンピュータ記憶媒体
CN107168762B (zh) 一种基于本体的rucm模型一致性检查方法
CN104991863A (zh) 一种基于功能块图测试模型自动生成测试用例的方法
CN107783758A (zh) 一种智能合约工程方法
Morgado et al. Reverse engineering of graphical user interfaces
CN109388573B (zh) 一种无漏报的中断驱动型程序运行时错误检测方法和***
US20080243470A1 (en) Logical check assist program, recording medium on which the program is recorded, logical check assist apparatus, and logical check assist method
US9298858B1 (en) System and method for reducing models based on a criterion
CN102193858B (zh) 一种测试用例集生成方法
CN102087629A (zh) 一种基于Agent嵌入式软件的不变量测试方法与工具
CN105302547A (zh) 一种面向Verilog HDL设计的故障注入方法
CN106201538B (zh) 一种基于rucm的实时性测试方法
Goli et al. Through the looking glass: Automated design understanding of SystemC-based VPs at the ESL
Tatale et al. A Survey on Test Case Generation using UML Diagrams and Feasibility Study to Generate Combinatorial Logic Oriented Test Cases.
CN115391173A (zh) 从Simulink-StateFlow模型到NuSMV模型的转换方法
Sun et al. A hierarchical CPN model automatically generating method aiming at multithreading program algorithm error detection
CN110286882B (zh) 一种基于模型检测的前台***设计与验证方法
DeOrio et al. Inferno: Streamlining verification with inferred semantics
Lei et al. A model-driven testing framework based on requirement for embedded software
Pockrandt et al. Model checking memory-related properties of hardware/software co-designs
Sahraoui et al. Methodology for fast prototyping of distributed real-time systems
Schöpp et al. Requirements-based code model checking
Elsaka et al. Using methods & measures from network analysis for gui testing

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
CF01 Termination of patent right due to non-payment of annual fee
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20171201

Termination date: 20190806