Title of article :
A case study in model checking software systems
Author/Authors :
Jeannette M. Wing، نويسنده , , Mandana Vaziri-Farahani، نويسنده ,
Issue Information :
دوماهنامه با شماره پیاپی سال 1997
Pages :
27
From page :
273
To page :
299
Abstract :
Model checking is a proven successful technology for verifying hardware. It works, however, on only finite state machines, and most software systems have infinitely many states. Our approach to applying model checking to software hinges on identifying appropriate abstractions that exploit the nature of both the system, S, and the property, θ, to be verified. We check θ on an abstracted, but finite, model of S. Following this approach we verified three cache coherence protocols used in distributed file systems. These protocols have to satisfy this property: “If a client believes that a cached file is valid then the authorized server believes that the clientʹs copy is valid.” In our finite model of the system, we need only represent the “beliefs” that a client and a server have about a cached file; we can abstract from the caches, the filesʹ contents, and even the files themselves. Moreover, by successive application of the generalization rule from predicate logic, we need only consider a model with at most two clients, one server, and one file. We used McMillanʹs SMV model checker; on our most complicated protocol, SMV took less than 1 s to check over 43600 reachable states
Keywords :
Verification , Abstraction mappings , Cache coherence protocols , Finite state machines , Model checking , Distributed systems
Journal title :
Science of Computer Programming
Serial Year :
1997
Journal title :
Science of Computer Programming
Record number :
1079469
Link To Document :
بازگشت