Skip to content

ConcurrentBoogieAndPthreads

Lars Nitzke edited this page Dec 4, 2018 · 39 revisions

Concurrent Boogie and Pthreads

Introductory Material

Boogie

  • Boogie specification (noch kein Support für Nebenläufigkeit)This is Boogie 2
  • Microsoft's tool for Boogie verificationBoogie @ rise4fun
  • A Boogie interpreter Boogaloo
  • Some extension of Boogie for concurrency (maybe not what we want)CIVL

Ultimate

Pthreads

Pthreads in Wikipedia

Example programs that we would like to handle are in the pthreads* subfolders of the SV-COMP C benchmarks

Project Goals

  • Erweitere Boogie in Ultimate um Support für Nebenläufigkeit.
    • Erweitere unseren Boogie AST um neue Sprachkonstrukte.
    • Erweitere unseren Boogie Parser.
    • Erweitere unsere Boogie-zu-Boogie Transformationen um Support für neue Sprachkonstrukte.
  • Erweitere unsere Boogie-zu-Kontrollflußgraph um Support für neue Sprachkonstrukte.
  • Erweitere unsere C-zu-Boogie Übersetzung um Support für pthread.
  • Create a document or wikipage that documents our extension

First Idea for a Boogie Extension

Add two new statements

Fork Statement

Syntax: fork Expr^{,+} Id ( Expr* )

Semantics: Call procedure Id as a new thread. First argument: list of thread identifier (must contain at least one item), Second argument: name of called procedure, Other arguments: arguments of called procedure

Note that analogously to the Boogie specification we use Id^{,+} to denote a comma-separated list of identifiers.

Join Statement

Syntax: join Expr^{,+}

join Id^{,+} assign Expr^{,+}

Semantics: Wait until thread with thread identifier Expr^{,+} has been finished.

Boogie-to-CFG support

Fork Statement

Let P be the name of the forked procedure.
For each forked procedure we add two global variables:

  1. thidvar_P - stores the identifier or list of identifiers for the created thread
  2. th_P_inUse - stores the information if procedure P is currently forked or not

and three edges to the CFG:

  1. One that points to the next location of the current procedure. It is labeled with fork thidvar_P.
  2. Another that points to the entry location of the forked procedure. This edge is labeled with the actual fork statement (here fork x foo(y, z)). It also assigns the global variables thidvar_P and th_P_inUse.
  3. and finally the edge pointing to an exception that is raised when the procedure P is already forked.

Example:

Join Statement

Let P be the name of the forked procedure.
For each join statement we add one edge from each exit location of a potential forked procedure.
A potential procedure has the same number and types of expressions in the thidvar_P variable as the given arguments in the join statement.

Example:

Tasks

Boogie examples

Implement algorithms that solve the mutual exclusion problem and implement them in our (extended) Boogie language. Take e.g., the algorithms that have already been implemented in our webinterface. We will use these examples as regression tests.

Clone this wiki locally