package ambient-context

  1. Overview
  2. Docs

Source file util_atomic.ml

1
2
3
4
5
6
7
8
9
10
11
12
(** Update loop *)
let update_cas (type res) (self : 'a Atomic.t) (f : 'a -> res * 'a) : res =
  let exception Ret of res in
  try
    while true do
      let old_val = Atomic.get self in
      let res, new_val = f old_val in
      if Atomic.compare_and_set self old_val new_val then
        raise_notrace (Ret res)
    done;
    assert false
  with Ret r -> r