学位论文详细信息
Automatic techniques for proving correctness of heap-manipulating programs
program verification;heap analysis;Floyd-Hoare Logic;Satisfiability Modulo Theories (SMT) solver;decision procedure;automata;monadic second-order logic;data structure;natural proofs;recursion;separation logic
Qiu, Xiaokang
关键词: program verification;    heap analysis;    Floyd-Hoare Logic;    Satisfiability Modulo Theories (SMT) solver;    decision procedure;    automata;    monadic second-order logic;    data structure;    natural proofs;    recursion;    separation logic;   
Others  :  https://www.ideals.illinois.edu/bitstream/handle/2142/45498/Xiaokang_Qiu.pdf?sequence=1&isAllowed=y
美国|英语
来源: The Illinois Digital Environment for Access to Learning and Scholarship
PDF
【 摘 要 】

Reliability is critical for system software, such as OS kernels, mobile browsers, embedded systems and cloud systems. The correctness of these programs, especially for security, is highly desirable, as they should provide a trustworthy platform for higher-level applications and the end-users. Unfortunately, due to its inherent complexity, the verification process of these programs is typically manual/semi-automatic, tedious, and painful. Automating the reasoning behind these verification tasks and decreasing the dependence on manual help is one of the greatest challenges in software verification.This dissertation presents two logic-based automatic software verification systems, namely Strand and Dryad, that help in the task of verification of heap-manipulating programs, which is one of the most complex aspects of modern software that eludes automatic verification. Strand is a logic that combines an expressive heap-logic with an arbitrary data-logic and admits several powerful decidable fragments. The general decision procedures can be used in not only proving programs correct but also in software analysis and testing. Dryad is a family of logics, including Dryad-tree as a first-order logic for trees and Dryad-sep as a dialect of separation logic. Both the two logics are amenable to automated reasoning using the natural proof strategy, a radically new approach to software verification. Dryad and the natural proof techniques are so far the most efficient logic-based approach that can verify the full correctness of a wide variety of challenging programs, including a large number of programs from various open-source libraries. They hold promise of hatching the next-generation automatic verification techniques.

【 预 览 】
附件列表
Files Size Format View
Automatic techniques for proving correctness of heap-manipulating programs 1191KB PDF download
  文献评价指标  
  下载次数:8次 浏览次数:42次