- Numerous minor internal improvements (@polytypic)
- Added many benchmarks to allow better understanding of the overheads of composable transactions (@polytypic)
- Exposed shape of
_ Loc.t
to avoid float array pessimization (@polytypic) - Made
Accumulator
automatically scaling and removed optionaln_way
arguments (@polytypic) - Use polymorphic variant for
mode
(@polytypic) - Add
?backoff
toLoc.compare_and_set
(@polytypic) - Remove the Op API (@polytypic, @lyrm)
- Fix
Hashtbl.clear
(@polytypic) - Fix single location updates to be linearizable (@polytypic)
- Add
Xt.compare_and_set
(@polytypic) - Add
Dllist.create_node value
(@polytypic) - Workarounds for CSE optimization (@polytypic)
- Changed to use
(implicit_transitive_deps false)
(@polytypic) - Move
Backoff
module to its ownbackoff
package (@lyrm, @polytypic) - Support padding to avoid false sharing (@polytypic)
- Pass through
?timeoutf
to blocking operations on data structures (@polytypic) - Ported to OCaml 4.13 (@polytypic)
- Ported to OCaml 4.14 (@polytypic)
- Add timeout support to potentially blocking operations (@polytypic)
- Add explicit
~xt
parameter toXt.call
to make it polymorphic (@polytypic)
- Fix to also snapshot and rollback post commit actions (@polytypic)
- Fix
Loc.compare_and_set
to have strong semantics (@polytypic) - Fix single location no-op updates to be strictly serializable (@polytypic)
- Add
Dllist.move_l node list
andDllist.move_r node list
(@polytypic)
- Improve
Hashtbl
read-write performance and addswap
(@polytypic) - Avoid some unnecessary verifies of read-only CMP operations (@polytypic)
- Add synchronizing variable
Mvar
tokcas_data
(@polytypic) - Fix to allow retry from within
Xt.update
andXt.modify
(@polytypic)
- Add nested conditional transaction support (@polytypic)
- Add explicit location validation support (@polytypic)
- Allocation of location ids in a transaction log friendly order (@polytypic)
- Per location operating mode selection (@Dashy-Dolphin, review: @polytypic)
- Injectivity
!'a Kcas_data.Dllist.t
annotation (@polytypic)
- Added doubly-linked list
Dllist
tokcas_data
(@polytypic) - Minor optimizations (@polytypic)
- Remove the
Tx
API (@polytypic) - Add blocking support to turn kcas into a proper STM (@polytypic, review: @lyrm)
- Add periodic validation of transactions (@polytypic)
- Introduce
kcas_data
companion package of composable lock-free data structures (@polytypic) - Add
is_in_log
operation to determine whether a location has been accessed by a transaction (@polytypic) - Add
Loc.modify
(@polytypic) - Add transactional
swap
operation to exchange contents of two locations (@polytypic) - Injectivity
!'a Loc.t
and variance+'a Tx.t
annotations (@polytypic)
- Add support for post commit actions to transactions (@polytypic)
- Bring
Xt
andTx
access combinators to parity and addcompare_and_swap
(@polytypic)
- New explicit transaction log passing API based on idea by @gasche (@polytypic, review: @samoht and @lyrm)
- New k-CAS-n-CMP algorithm extending the GKMZ algorithm (@polytypic, review: @bartoszmodelski)
- Complete redesign adding a new transaction API (@polytypic, review: @bartoszmodelski)
- Fix a bug in GKMZ implementation (@polytypic, review: @bartoszmodelski)
- Change to use the new GKMZ algorithm (@polytypic, review: @bartoszmodelski)
- Add preflights sorting and checks (@bartoszmodelski, review: @polytypic)
- Republish in opam (update opam, dune) (@tmcgilchrist, review: @Sudha247)