PeekPoke

Usage

use PeekPoke;

or

import PeekPoke;

Support for directly accessing an ‘atomic’ variable’s value.

Warning

This module is unstable and the API is likely to change over time.

This module provides peek() and poke() operations on atomics. peek() and poke() are non-atomic read and write operations. They can provide a performance improvement when local reads/writes are performed and atomicity is not required. For example they can be used to initialize an array of atomics or perform a reduction when no concurrent updates are occurring.

use BlockDist, PeekPoke;

const space = {1..1000};
const D = space dmapped new blockDist(space);
var A: [D] atomic int;

forall i in D do
  A[i].poke(i);

const sum = + reduce A.peek();
writeln(sum); // 500500
proc AtomicBool.peek() : bool

Non-atomically reads the stored value.

proc ref AtomicBool.poke(val: bool) : void

Non-atomically writes val.

proc AtomicT.peek() : valType

Non-atomically reads the stored value.

proc ref AtomicT.poke(val: valType) : void

Non-atomically writes val.