Verifying Mutable Systems

Loading...
Thumbnail Image

Date

2017-10-23

Authors

Scott, Joseph

Advisor

Trefler, Richard

Journal Title

Journal ISSN

Volume Title

Publisher

University of Waterloo

Abstract

Model checking has had much success in the verification of single-process and multi-process programs. However, model checkers assume an immutable topology which limits the verification in several areas. Consider the security domain, model checkers have had success in the verification of unicast structurally static protocols, but struggle to verify dynamic multicast cryptographic protocols. We give a formulation of dynamic model checking which extends traditional model checking by allowing structural changes, mutations, to the topology of multi-process network models. We introduce new mutation models when the structural mutations take either a primitive, non-primitive, or a non-deterministic form, and analyze the general complexities of each. This extends traditional model checking and allows analysis in new areas. We provide a set of proof rules to verify safety properties on dynamic models and outline its automizability. We relate dynamic models to compositional reasoning, dynamic cutoffs, parametrized analysis, and previously established parametric assertions.We provide a proof of concept by analyzing a dynamic mutual exclusion protocol and a multicast cryptography protocol.

Description

Keywords

Model Checking, Computer Aided Verification, Dynamic Analysis, Security

LC Subject Headings

Citation