SwePub
Sök i LIBRIS databas

  Utökad sökning

(WFRF:(Gurov Dilian 1964 ))
 

Sökning: (WFRF:(Gurov Dilian 1964 )) > Specification and v...

Specification and verification of synchronization with condition variables

De Carvalho Gomes, Pedro (författare)
KTH,Teoretisk datalogi, TCS
Gurov, Dilian, 1964- (författare)
KTH,Teoretisk datalogi, TCS
Huisman, M. (författare)
 (creator_code:org_t)
2017-02-16
2017
Engelska.
Ingår i: 5th International Workshop on Formal Techniques for Safety-Critical Systems, FTSCS 2016. - Cham : Springer. - 9783319539454 ; , s. 3-19
  • Konferensbidrag (refereegranskat)
Abstract Ämnesord
Stäng  
  • In this paper we propose a technique to specify and verify the correct synchronization of concurrent programs with condition variables. We define correctness as the liveness property: “every thread synchronizing under a set of condition variables eventually exits the synchronization”, under the assumption that every such thread eventually reaches its synchronization block. Our technique does not avoid the combinatorial explosion of interleavings of thread behaviors. Instead, we alleviate it by abstracting away all details that are irrelevant to the synchronization behavior of the program, which is typically significantly smaller than its overall behavior. First, we introduce SyncTask, a simple imperative language to specify parallel computations that synchronize via condition variables. We consider a SyncTask program to have a correct synchronization iff it terminates. Further, to relieve the programmer from the burden of providing specifications in SyncTask, we introduce an economic annotation scheme for Java programs to assist the automated extraction of SyncTask programs capturing the synchronization behavior of the underlying program. We prove that every Java program annotated according to the scheme (and satisfying the assumption) has a correct synchronization iff its corresponding SyncTask program terminates. We show how to transform the verification of termination into a standard reachability problem over Colored Petri Nets that is efficiently solvable by existing Petri Net analysis tools. Both the SyncTask program extraction and the generation of Petri Nets are implemented in our STaVe tool. We evaluate the proposed framework on a number of test cases as a proof-of-concept.

Ämnesord

NATURVETENSKAP  -- Data- och informationsvetenskap -- Datavetenskap (hsv//swe)
NATURAL SCIENCES  -- Computer and Information Sciences -- Computer Sciences (hsv//eng)

Nyckelord

Computer software
Explosions
Extraction
Petri nets
Safety engineering
Security systems
Specifications
Synchronization
Automated extraction
Combinatorial explosion
Concurrent program
Imperative languages
Liveness properties
Parallel Computation
Reachability problem
Specification and verification
Java programming language

Publikations- och innehållstyp

ref (ämneskategori)
kon (ämneskategori)

Hitta via bibliotek

Till lärosätets databas

Sök utanför SwePub

Kungliga biblioteket hanterar dina personuppgifter i enlighet med EU:s dataskyddsförordning (2018), GDPR. Läs mer om hur det funkar här.
Så här hanterar KB dina uppgifter vid användning av denna tjänst.

 
pil uppåt Stäng

Kopiera och spara länken för att återkomma till aktuell vy