liu.seSök publikationer i DiVA
Ändra sökning
RefereraExporteraLänk till posten
Permanent länk

Direktlänk
Referera
Referensformat
  • apa
  • ieee
  • modern-language-association-8th-edition
  • vancouver
  • oxford
  • Annat format
Fler format
Språk
  • de-DE
  • en-GB
  • en-US
  • fi-FI
  • nn-NO
  • nn-NB
  • sv-SE
  • Annat språk
Fler språk
Utmatningsformat
  • html
  • text
  • asciidoc
  • rtf
An integrated specification and verification technique for highly concurrent data structures
Uppsala University, Sweden.
Uppsala University, Sweden.
Uppsala University, Sweden; Brno University of Technology, Czech Republic.
Uppsala University, Sweden.
Visa övriga samt affilieringar
2017 (Engelska)Ingår i: International Journal on Software Tools for Technology Transfer, ISSN 1433-2779, E-ISSN 1433-2787, Vol. 19, nr 5, s. 549-563Artikel i tidskrift (Refereegranskat) Published
Abstract [en]

We present a technique for automatically verifying safety properties of concurrent programs, in particular programs that rely on subtle dependencies of local states of different threads, such as lock-free implementations of stacks and queues in an environment without garbage collection. Our technique addresses the joint challenges of infinite-state specifications, an unbounded number of threads, and an unbounded heap managed by explicit memory allocation. Our technique builds on the automata-theoretic approach to model checking, in which a specification is given by an automaton that observes the execution of a program and accepts executions that violate the intended specification. We extend this approach by allowing specifications to be given by a class of infinite-state automata. We show how such automata can be used to specify queues, stacks, and other data structures, by extending a data-independence argument. For verification, we develop a shape analysis, which tracks correlations between pairs of threads, and a novel abstraction to make the analysis practical. We have implemented our method and used it to verify programs, some of which have not been verified by any other automatic method before.

Ort, förlag, år, upplaga, sidor
SPRINGER HEIDELBERG , 2017. Vol. 19, nr 5, s. 549-563
Nyckelord [en]
Verification; Pointer programs; Explicit memory allocation; Queue; Stack; Unbounded; Concurrency; Specification; Linearizability
Nationell ämneskategori
Datavetenskap (datalogi)
Identifikatorer
URN: urn:nbn:se:liu:diva-141116DOI: 10.1007/s10009-016-0415-4ISI: 000409295800004OAI: oai:DiVA.org:liu-141116DiVA, id: diva2:1144777
Anmärkning

Funding Agencies|Uppsala Programming for Multicore Architectures Research Center (UPMARC); Czech Science Foundation [13-37876P]; Brno University of Technology [FIT-S-12-1, FIT-S-14-2486]; CENIIT research organization at Linkoping [12.04]

Tillgänglig från: 2017-09-27 Skapad: 2017-09-27 Senast uppdaterad: 2024-01-17

Open Access i DiVA

Fulltext saknas i DiVA

Övriga länkar

Förlagets fulltextCorrection

Sök vidare i DiVA

Av författaren/redaktören
Rezine, Ahmed
Av organisationen
Programvara och systemTekniska fakulteten
I samma tidskrift
International Journal on Software Tools for Technology Transfer
Datavetenskap (datalogi)

Sök vidare utanför DiVA

GoogleGoogle Scholar

doi
urn-nbn

Altmetricpoäng

doi
urn-nbn
Totalt: 322 träffar
RefereraExporteraLänk till posten
Permanent länk

Direktlänk
Referera
Referensformat
  • apa
  • ieee
  • modern-language-association-8th-edition
  • vancouver
  • oxford
  • Annat format
Fler format
Språk
  • de-DE
  • en-GB
  • en-US
  • fi-FI
  • nn-NO
  • nn-NB
  • sv-SE
  • Annat språk
Fler språk
Utmatningsformat
  • html
  • text
  • asciidoc
  • rtf