Skip to content
This repository has been archived by the owner on Aug 26, 2022. It is now read-only.

Files

Latest commit

 

History

History
17 lines (11 loc) · 3.58 KB

ObjectSharing.md

File metadata and controls

17 lines (11 loc) · 3.58 KB

Sharing objects across machines

A P# program is expected to be free of data races. This means that two different machines should not race on the access to the same object, unless both accesses are reads. Typically, the programmer should have an ownership protocol in mind to associate a unique owner machine to an object when writes have to be performed on the object. An exception to this rule is when using Microsoft.PSharp.SharedObjects.

Microsoft.PSharp.SharedObjects

We have designed multiple shared data structures for use in P# programs that can considerably simplify the development of a P# program. Instances of these data structures can be shared freely and accessed by multiple machines, even when performing write operations. There is a simple API for creating these shared objects. Currently three kinds of shared objects are available: SharedCounter, SharedRegister<T> and SharedDictionary, but more may be made available in the future (please send us a request if you need a specific data structure, and you believe is generic enough to be included in this library).

Internally, these data structures are written so that they use fast thread-safe implementations in production runs of P# program. For instance, SharedCounter uses Interlocked operations, SharedRegister uses small critical sections implemented using locks and SharedDictionary uses a ConcurrentDictionary. However, during bug-finding mode (i.e., while running tests under PSharpTester) the implementation automatically switches to use a Machine that serializes all accesses to the object. Thus, PSharpTester sees a usual P# program with no synchronization operations other than Machine creation and message passing.

At the moment, the APIs used to implement SharedObjects are internal to P#. They may be made available externally in the future so that users can create their own library of shared data structures.

Example: See how this sample shares a SharedDictionary object and a SharedCounter object between two machines that access the objects concurrently.

Important remark on using SharedDictionary<TKey, TValue>

Conceptually one should think of a P# SharedObject as a wrapper around a P# machine. Thus, one needs to be careful about stashing references inside a SharedObject and treat it in the same manner as sharing references between machines. In the case of a SharedDictionary both key and value objects (which are passed by reference into the dictionary) should not be mutated unless first removed from the dictionary because this can lead to a data race. Consider two machines that share a SharedDictionary object D. If both machines grab the value D[k] at the same key k they will each have a reference to the same value object, creating the potential for a data race (unless the intention is to only do read operations on the value object).

The same note holds for SharedRegister<T> when T is a struct type with reference fields inside it.