From 90a08a19dc47e25613be47981f902c23725a6b98 Mon Sep 17 00:00:00 2001 From: Jan Midtgaard Date: Fri, 20 Dec 2024 15:32:22 +0100 Subject: [PATCH 1/3] Mark backup-thread assertion failure as fixed --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index da6684ff..c503f02b 100644 --- a/README.md +++ b/README.md @@ -412,8 +412,8 @@ property can be done in two different ways: Issues ====== -Race condition in backup thread logic (new, runtime) ----------------------------------------------------- +Race condition in backup thread logic (new, fixed, runtime) +----------------------------------------------------------- An assertion error revealed [a race condition between two atomic updates underlying the coordination between a spawned domain and its backup thread](https://github.com/ocaml/ocaml/issues/13677). From 8b82172439fefe218415dc6339093981470555be Mon Sep 17 00:00:00 2001 From: Jan Midtgaard Date: Fri, 20 Dec 2024 15:42:15 +0100 Subject: [PATCH 2/3] Add Olivier's Unboxed Dynarray crashing bug --- README.md | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/README.md b/README.md index c503f02b..fe6565e3 100644 --- a/README.md +++ b/README.md @@ -412,6 +412,13 @@ property can be done in two different ways: Issues ====== +Unboxed `Dynarray` STM tests segfaults (new, fixed, runtime) +------------------------------------------------------------ + +Early `STM` tests of [the unboxed `Dynarray` PR](https://github.com/ocaml/ocaml/pull/12885) triggered +[segfaults caused by mixing flat float arrays with boxed arrays](https://github.com/ocaml/ocaml/pull/12885#discussion_r1568976695). + + Race condition in backup thread logic (new, fixed, runtime) ----------------------------------------------------------- From c29dc4e4c86fbd0839273452794d1b77232c0b6d Mon Sep 17 00:00:00 2001 From: Jan Midtgaard Date: Fri, 20 Dec 2024 15:43:55 +0100 Subject: [PATCH 3/3] Remove initial utop crashing issue --- README.md | 43 ------------------------------------------- 1 file changed, 43 deletions(-) diff --git a/README.md b/README.md index fe6565e3..824f29b2 100644 --- a/README.md +++ b/README.md @@ -836,49 +836,6 @@ let () = List.iter (fun p -> Task.await pool p) [p0;p1;p2;p3;p4;p5] let () = Task.teardown_pool pool ``` - -Utop segfault (known?, status?) -------------------------------- - -Utop segfaults when loading [src/domain/domain_spawntree.ml](src/domain/domain_spawntree.ml) -interactively: - -``` ocaml -$ utop -──────────────────────────────────────────────┬─────────────────────────────────────────────────────────────────────┬────────────────────────────────────────────── - │ Welcome to utop version 2.8.0 (using OCaml version 4.12.0+domains)! │ - └─────────────────────────────────────────────────────────────────────┘ -Findlib has been successfully loaded. Additional directives: - #require "package";; to load a package - #list;; to list the available packages - #camlp4o;; to load camlp4 (standard syntax) - #camlp4r;; to load camlp4 (revised syntax) - #predicates "p,q,...";; to set these predicates - Topfind.reset();; to force that packages will be reloaded - #thread;; to enable threads - - -Type #utop_help for help about using utop. - -utop # #require "ppx_deriving.show";; -utop # #require "qcheck";; -utop # #use "src/domain_spawntree.ml";; -type cmd = Incr | Decr | Spawn of cmd list -val pp_cmd : Format.formatter -> cmd -> unit = -val show_cmd : cmd -> string = -val count_spawns : cmd -> int = -val gen : int -> int -> cmd Gen.t = -val shrink_cmd : cmd Shrink.t = -val interp : int -> cmd -> int = -val dom_interp : int Atomic.t -> cmd -> unit = -val t : max_depth:int -> max_width:int -> Test.t = -random seed: 359528592 -Segmentation fault (core dumped) -``` - -This does not happen when running a plain `ocaml` top-level though, so it -seems `utop`-specific. - --- This project has been created and is maintained by Tarides.