Bounded verification of message-passing concurrency in Go using Promela and Spin

04/03/2020
by   Nicolas Dilley, et al.
0

This paper describes a static verification framework for the message-passing fragment of the Go programming language. Our framework extracts models that over-approximate the message-passing behaviour of a program. These models, or behavioural types, are encoded in Promela, hence can be efficiently verified with Spin. We improve on previous works by verifying programs that include communication-related parameters that are unknown at compile-time, i.e., programs that spawn a parameterised number of threads or that create channels with a parameterised capacity. These programs are checked via a bounded verification approach with bounds provided by the user.

READ FULL TEXT

Please sign up or login with your details

Forgot password? Click here to reset