2025-05-02 08:19.51: New job: test ocaml-multicore/picos https://github.com/ocaml-multicore/picos.git#refs/heads/add-more-structured-run-ops (b8c263ffca1fd5be055623f9324793842a505d38) (linux-x86_64:debian-12-5.3_x86_32_opam-2.3)
Base: ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10
Opam project build
To reproduce locally:
git clone --recursive "https://github.com/ocaml-multicore/picos.git" -b "add-more-structured-run-ops" && cd "picos" && git reset --hard b8c263ff
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10
# debian-12-5.3_x86_32_opam-2.3
USER 1000:1000
SHELL [ "/usr/bin/linux32", "/bin/sh", "-c" ]
ENV CLICOLOR_FORCE="1"
ENV OPAMCOLOR="always"
WORKDIR /src
RUN sudo ln -f /usr/bin/opam-2.3 /usr/bin/opam
RUN opam init --reinit -ni
RUN uname -rs && opam exec -- ocaml -version && opam --version
WORKDIR /src
RUN sudo chown opam /src
RUN cd ~/opam-repository && (git cat-file -e 6bf1d7b4b789bbbf1388886ea336653bace6fde7 || git fetch origin master) && git reset -q --hard 6bf1d7b4b789bbbf1388886ea336653bace6fde7 && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 picos_std.opam picos_mux.opam picos_meta.opam picos_lwt.opam picos_io_cohttp.opam picos_io.opam picos_aux.opam picos.opam ./
RUN opam pin add -yn picos_std.dev './' && \
opam pin add -yn picos_mux.dev './' && \
opam pin add -yn picos_meta.dev './' && \
opam pin add -yn picos_lwt.dev './' && \
opam pin add -yn picos_io_cohttp.dev './' && \
opam pin add -yn picos_io.dev './' && \
opam pin add -yn picos_aux.dev './' && \
opam pin add -yn picos.dev './'
RUN echo '(lang dune 3.0)' > './dune-project'
ENV DEPS="alcotest.1.9.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.16.4 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base base64.3.5.1 bigstringaf.0.10.0 bos.0.2.1 ca-certs.1.0.1 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.1.0 cohttp-lwt.6.1.0 cohttp-lwt-unix.6.1.0 conduit.8.0.0 conduit-lwt.8.0.0 conduit-lwt-unix.8.0.0 conf-gmp.5 conf-gmp-powm-sec.4 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.3.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.18.1 dune-configurator.3.18.1 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.10.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.1.0 ipaddr.5.6.0 ipaddr-sexp.5.6.0 js_of_ocaml.6.0.1 js_of_ocaml-compiler.6.0.1 kdf.1.0.0 logs.0.8.0 lwt.5.9.1 macaddr.5.6.0 magic-mime.1.3.1 mdx.2.5.0 menhir.20240715 menhirCST.20240715 menhirLib.20240715 menhirSdk.20240715 mirage-crypto.2.0.0 mirage-crypto-ec.2.0.0 mirage-crypto-pk.2.0.0 mirage-crypto-rng.2.0.0 mtime.2.1.0 multicore-bench.0.1.7 multicore-magic.2.3.1 multicore-magic-dscheck.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-option-bytecode-only.1 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.0 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 oseq.0.5.1 ppx_derivers.1.2.1 ppx_sexp_conv.v0.16.0 ppxlib.0.35.0 psq.0.2.1 ptime.1.2.0 qcheck-core.0.25 qcheck-multicoretests-util.0.8 qcheck-stm.0.8 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.4 seq.base sexplib0.v0.16.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.8 tsort.2.2.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.4 x509.1.0.6 yojson.2.2.2 zarith.1.14"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.3 --depext-only -y picos_std.dev picos_mux.dev picos_meta.dev picos_lwt.dev picos_io_cohttp.dev picos_io.dev picos_aux.dev picos.dev $DEPS
RUN opam install $DEPS
COPY --chown=1000:1000 . /src
RUN opam exec -- dune build @install @check @runtest && rm -rf _build
END-OF-DOCKERFILE
docker build .
END-REPRO-BLOCK
2025-05-02 08:19.51: Using cache hint "ocaml-multicore/picos-ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10-debian-12-5.3_x86_32_opam-2.3-bc53c192e60a4d891cfbf9f20e86f876"
2025-05-02 08:19.51: Using OBuilder spec:
((from ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10)
(comment debian-12-5.3_x86_32_opam-2.3)
(user (uid 1000) (gid 1000))
(shell /usr/bin/linux32 /bin/sh -c)
(env CLICOLOR_FORCE 1)
(env OPAMCOLOR always)
(workdir /src)
(run (shell "sudo ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
(run (shell "opam init --reinit -ni"))
(run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
(workdir /src)
(run (shell "sudo chown opam /src"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 6bf1d7b4b789bbbf1388886ea336653bace6fde7 || git fetch origin master) && git reset -q --hard 6bf1d7b4b789bbbf1388886ea336653bace6fde7 && git log --no-decorate -n1 --oneline && opam update -u"))
(copy (src picos_std.opam picos_mux.opam picos_meta.opam picos_lwt.opam picos_io_cohttp.opam picos_io.opam picos_aux.opam picos.opam)
(dst ./))
(run (network host)
(shell "opam pin add -yn picos_std.dev './' && \
\nopam pin add -yn picos_mux.dev './' && \
\nopam pin add -yn picos_meta.dev './' && \
\nopam pin add -yn picos_lwt.dev './' && \
\nopam pin add -yn picos_io_cohttp.dev './' && \
\nopam pin add -yn picos_io.dev './' && \
\nopam pin add -yn picos_aux.dev './' && \
\nopam pin add -yn picos.dev './'"))
(run (network host)
(shell "echo '(lang dune 3.0)' > './dune-project'"))
(env DEPS "alcotest.1.9.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.16.4 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base base64.3.5.1 bigstringaf.0.10.0 bos.0.2.1 ca-certs.1.0.1 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.1.0 cohttp-lwt.6.1.0 cohttp-lwt-unix.6.1.0 conduit.8.0.0 conduit-lwt.8.0.0 conduit-lwt-unix.8.0.0 conf-gmp.5 conf-gmp-powm-sec.4 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.3.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.18.1 dune-configurator.3.18.1 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.10.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.1.0 ipaddr.5.6.0 ipaddr-sexp.5.6.0 js_of_ocaml.6.0.1 js_of_ocaml-compiler.6.0.1 kdf.1.0.0 logs.0.8.0 lwt.5.9.1 macaddr.5.6.0 magic-mime.1.3.1 mdx.2.5.0 menhir.20240715 menhirCST.20240715 menhirLib.20240715 menhirSdk.20240715 mirage-crypto.2.0.0 mirage-crypto-ec.2.0.0 mirage-crypto-pk.2.0.0 mirage-crypto-rng.2.0.0 mtime.2.1.0 multicore-bench.0.1.7 multicore-magic.2.3.1 multicore-magic-dscheck.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-option-bytecode-only.1 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.0 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 oseq.0.5.1 ppx_derivers.1.2.1 ppx_sexp_conv.v0.16.0 ppxlib.0.35.0 psq.0.2.1 ptime.1.2.0 qcheck-core.0.25 qcheck-multicoretests-util.0.8 qcheck-stm.0.8 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.4 seq.base sexplib0.v0.16.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.8 tsort.2.2.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.4 x509.1.0.6 yojson.2.2.2 zarith.1.14")
(env CI true)
(env OCAMLCI true)
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam update --depexts && opam install --cli=2.3 --depext-only -y picos_std.dev picos_mux.dev picos_meta.dev picos_lwt.dev picos_io_cohttp.dev picos_io.dev picos_aux.dev picos.dev $DEPS"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam install $DEPS"))
(copy (src .) (dst /src))
(run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build"))
)
2025-05-02 08:19.51: Waiting for resource in pool OCluster
2025-05-02 08:19.51: Waiting for worker…
2025-05-02 08:19.52: Got resource from pool OCluster
Building on x86-bm-c3.sw.ocaml.org
All commits already cached
HEAD is now at b8c263f Experiment
(from ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10)
WARNING: The requested image's platform (linux/386) does not match the detected host platform (linux/amd64) and no specific platform was requested
2025-05-02 08:19.52 ---> using "b8e2c67a48f21f6b588dbd3c84402e21f46800f10cf95f4f261f434a6291fdbb" from cache
/: (comment debian-12-5.3_x86_32_opam-2.3)
/: (user (uid 1000) (gid 1000))
/: (shell /usr/bin/linux32 /bin/sh -c)
/: (env CLICOLOR_FORCE 1)
/: (env OPAMCOLOR always)
/: (workdir /src)
/src: (run (shell "sudo ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
2025-05-02 08:19.52 ---> using "dbddeba6b94881d7b9e20e18f9a790b97f859b309d9a15754e761cfc21febe07" from cache
/src: (run (shell "opam init --reinit -ni"))
Configuring from /home/opam/.opamrc and then from built-in defaults.
Checking for available remotes: rsync and local, git.
- you won't be able to use mercurial repositories unless you install the hg command on your system.
- you won't be able to use darcs repositories unless you install the darcs command on your system.
This development version of opam requires an update to the layout of /home/opam/.opam from version 2.0 to version 2.2, which can't be reverted.
You may want to back it up before going further.
Continue? [y/n] y
Format upgrade done.
<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2025-05-02 08:19.52 ---> using "6d4e3c82c6a9d252ed847e874a886a16b449e7669a8b1f1b119f3bbe00d69cf1" from cache
/src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
Linux 5.15.0-134-generic
The OCaml toplevel, version 5.3.0
2.3.0
2025-05-02 08:19.52 ---> using "2aafa5118b96adfea99fa63311b6c7a323cc5b186ecb4fcee7464018f41cf437" from cache
/src: (workdir /src)
/src: (run (shell "sudo chown opam /src"))
2025-05-02 08:19.52 ---> using "1fb5da2713e27d7ae14ee3de7540f6a80fd3394e513af3cb01ce174b04304c72" from cache
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 6bf1d7b4b789bbbf1388886ea336653bace6fde7 || git fetch origin master) && git reset -q --hard 6bf1d7b4b789bbbf1388886ea336653bace6fde7 && git log --no-decorate -n1 --oneline && opam update -u"))
From https://github.com/ocaml/opam-repository
* branch master -> FETCH_HEAD
da74d7829f..b90fd8709a master -> origin/master
6bf1d7b4b7 Merge pull request #27809 from kit-ty-kate/misc-conf-altlinux
<><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[default] synchronised from git+file:///home/opam/opam-repository
Everything as up-to-date as possible (run with --verbose to show unavailable upgrades).
However, you may "opam upgrade" these packages explicitly, which will ask permission to downgrade or uninstall the conflicting packages.
Nothing to do.
# To update the current shell environment, run: eval $(opam env)
2025-05-02 08:19.52 ---> using "0d4e0af1012787d34c728c5638c75214fa508d886d373de4e174d097ad950188" from cache
/src: (copy (src picos_std.opam picos_mux.opam picos_meta.opam picos_lwt.opam picos_io_cohttp.opam picos_io.opam picos_aux.opam picos.opam)
(dst ./))
2025-05-02 08:19.52 ---> using "fd1f345f262d69282eb1bfe1898ddb848736f4e50dc30861412c7d64b6c21b3d" from cache
/src: (run (network host)
(shell "opam pin add -yn picos_std.dev './' && \
\nopam pin add -yn picos_mux.dev './' && \
\nopam pin add -yn picos_meta.dev './' && \
\nopam pin add -yn picos_lwt.dev './' && \
\nopam pin add -yn picos_io_cohttp.dev './' && \
\nopam pin add -yn picos_io.dev './' && \
\nopam pin add -yn picos_aux.dev './' && \
\nopam pin add -yn picos.dev './'"))
[picos_std.dev] synchronised (file:///src)
picos_std is now pinned to file:///src (version dev)
[picos_mux.dev] synchronised (file:///src)
picos_mux is now pinned to file:///src (version dev)
[picos_meta.dev] synchronised (file:///src)
picos_meta is now pinned to file:///src (version dev)
[picos_lwt.dev] synchronised (file:///src)
picos_lwt is now pinned to file:///src (version dev)
[picos_io_cohttp.dev] synchronised (file:///src)
picos_io_cohttp is now pinned to file:///src (version dev)
[picos_io.dev] synchronised (file:///src)
picos_io is now pinned to file:///src (version dev)
[picos_aux.dev] synchronised (file:///src)
picos_aux is now pinned to file:///src (version dev)
[picos.dev] synchronised (file:///src)
picos is now pinned to file:///src (version dev)
2025-05-02 08:19.52 ---> using "5b7120563ce1164bd6c9198df59bda1bf26ccfcfdffc9e4ca0cd3426340148c8" from cache
/src: (run (network host)
(shell "echo '(lang dune 3.0)' > './dune-project'"))
2025-05-02 08:19.52 ---> using "674146e6a2e83d4de5784b72ca1b52cf0d563264d7967f8d86991acce01e6426" from cache
/src: (env DEPS "alcotest.1.9.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.16.4 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base base64.3.5.1 bigstringaf.0.10.0 bos.0.2.1 ca-certs.1.0.1 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.1.0 cohttp-lwt.6.1.0 cohttp-lwt-unix.6.1.0 conduit.8.0.0 conduit-lwt.8.0.0 conduit-lwt-unix.8.0.0 conf-gmp.5 conf-gmp-powm-sec.4 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.3.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.18.1 dune-configurator.3.18.1 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.10.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.1.0 ipaddr.5.6.0 ipaddr-sexp.5.6.0 js_of_ocaml.6.0.1 js_of_ocaml-compiler.6.0.1 kdf.1.0.0 logs.0.8.0 lwt.5.9.1 macaddr.5.6.0 magic-mime.1.3.1 mdx.2.5.0 menhir.20240715 menhirCST.20240715 menhirLib.20240715 menhirSdk.20240715 mirage-crypto.2.0.0 mirage-crypto-ec.2.0.0 mirage-crypto-pk.2.0.0 mirage-crypto-rng.2.0.0 mtime.2.1.0 multicore-bench.0.1.7 multicore-magic.2.3.1 multicore-magic-dscheck.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-option-bytecode-only.1 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.0 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 oseq.0.5.1 ppx_derivers.1.2.1 ppx_sexp_conv.v0.16.0 ppxlib.0.35.0 psq.0.2.1 ptime.1.2.0 qcheck-core.0.25 qcheck-multicoretests-util.0.8 qcheck-stm.0.8 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.4 seq.base sexplib0.v0.16.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.8 tsort.2.2.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.4 x509.1.0.6 yojson.2.2.2 zarith.1.14")
/src: (env CI true)
/src: (env OCAMLCI true)
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam update --depexts && opam install --cli=2.3 --depext-only -y picos_std.dev picos_mux.dev picos_meta.dev picos_lwt.dev picos_io_cohttp.dev picos_io.dev picos_aux.dev picos.dev $DEPS"))
+ /usr/bin/sudo "apt-get" "update"
- Hit:1 http://deb.debian.org/debian bookworm InRelease
- Get:2 http://deb.debian.org/debian bookworm-updates InRelease [55.4 kB]
- Get:3 http://deb.debian.org/debian-security bookworm-security InRelease [48.0 kB]
- Get:4 http://deb.debian.org/debian-security bookworm-security/main i386 Packages [251 kB]
- Fetched 354 kB in 0s (1053 kB/s)
- Reading package lists...
-
<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[picos.dev] synchronised (file:///src)
[picos_aux.dev] synchronised (file:///src)
[picos_io.dev] synchronised (file:///src)
[picos_io_cohttp.dev] synchronised (file:///src)
[picos_lwt.dev] synchronised (file:///src)
[picos_meta.dev] synchronised (file:///src)
[picos_mux.dev] synchronised (file:///src)
[picos_std.dev] synchronised (file:///src)
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-option-bytecode-only is already installed (current version is 1).
[NOTE] Package ocaml-config is already installed (current version is 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[NOTE] Package base-unix is already installed (current version is base).
[NOTE] Package base-threads is already installed (current version is base).
[NOTE] Package base-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains is already installed (current version is base).
[NOTE] Package base-bigarray is already installed (current version is base).
The following system packages will first need to be installed:
libgmp-dev pkg-config
<><> Handling external dependencies <><><><><><><><><><><><><><><><><><><><><><>
+ /usr/bin/sudo "apt-get" "install" "-qq" "-yy" "libgmp-dev" "pkg-config"
- debconf: delaying package configuration, since apt-utils is not installed
- Selecting previously unselected package libgmpxx4ldbl:i386.
- (Reading database ...
(Reading database ... 5%
(Reading database ... 10%
(Reading database ... 15%
(Reading database ... 20%
(Reading database ... 25%
(Reading database ... 30%
(Reading database ... 35%
(Reading database ... 40%
(Reading database ... 45%
(Reading database ... 50%
(Reading database ... 55%
(Reading database ... 60%
(Reading database ... 65%
(Reading database ... 70%
(Reading database ... 75%
(Reading database ... 80%
(Reading database ... 85%
(Reading database ... 90%
(Reading database ... 95%
(Reading database ... 100%
(Reading database ... 18763 files and directories currently installed.)
- Preparing to unpack .../0-libgmpxx4ldbl_2%3a6.2.1+dfsg1-1.1_i386.deb ...
- Unpacking libgmpxx4ldbl:i386 (2:6.2.1+dfsg1-1.1) ...
- Selecting previously unselected package libgmp-dev:i386.
- Preparing to unpack .../1-libgmp-dev_2%3a6.2.1+dfsg1-1.1_i386.deb ...
- Unpacking libgmp-dev:i386 (2:6.2.1+dfsg1-1.1) ...
- Selecting previously unselected package libpkgconf3:i386.
- Preparing to unpack .../2-libpkgconf3_1.8.1-1_i386.deb ...
- Unpacking libpkgconf3:i386 (1.8.1-1) ...
- Selecting previously unselected package pkgconf-bin.
- Preparing to unpack .../3-pkgconf-bin_1.8.1-1_i386.deb ...
- Unpacking pkgconf-bin (1.8.1-1) ...
- Selecting previously unselected package pkgconf:i386.
- Preparing to unpack .../4-pkgconf_1.8.1-1_i386.deb ...
- Unpacking pkgconf:i386 (1.8.1-1) ...
- Selecting previously unselected package pkg-config:i386.
- Preparing to unpack .../5-pkg-config_1.8.1-1_i386.deb ...
- Unpacking pkg-config:i386 (1.8.1-1) ...
- Setting up libpkgconf3:i386 (1.8.1-1) ...
- Setting up libgmpxx4ldbl:i386 (2:6.2.1+dfsg1-1.1) ...
- Setting up pkgconf-bin (1.8.1-1) ...
- Setting up libgmp-dev:i386 (2:6.2.1+dfsg1-1.1) ...
- Setting up pkgconf:i386 (1.8.1-1) ...
- Setting up pkg-config:i386 (1.8.1-1) ...
- Processing triggers for libc-bin (2.36-9+deb12u10) ...
2025-05-02 08:19.52 ---> using "ba578d019c85edec570dc0224e3ed0f7479c740033e7c9773917901b7dcd4c82" from cache
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam install $DEPS"))
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-option-bytecode-only is already installed (current version is 1).
[NOTE] Package ocaml-config is already installed (current version is 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[NOTE] Package base-unix is already installed (current version is base).
[NOTE] Package base-threads is already installed (current version is base).
[NOTE] Package base-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains is already installed (current version is base).
[NOTE] Package base-bigarray is already installed (current version is base).
The following actions will be performed:
=== install 96 packages
- install alcotest 1.9.0
- install angstrom 0.16.1
- install asn1-combinators 0.3.2
- install astring 0.8.5
- install backoff 0.1.1
- install base v0.16.4
- install base-bytes base
- install base64 3.5.1
- install bigstringaf 0.10.0
- install bos 0.2.1
- install ca-certs 1.0.1
- install camlp-streams 5.0.1
- install cmdliner 1.3.0
- install cohttp 6.1.0
- install cohttp-lwt 6.1.0
- install cohttp-lwt-unix 6.1.0
- install conduit 8.0.0
- install conduit-lwt 8.0.0
- install conduit-lwt-unix 8.0.0
- install conf-gmp 5
- install conf-gmp-powm-sec 4
- install conf-pkg-config 4
- install containers 3.15
- install cppo 1.8.0
- install csexp 1.5.2
- install digestif 1.3.0
- install domain-local-await 1.0.1
- install domain-name 0.4.1
- install domain_shims 0.1.0
- install dscheck 0.5.0
- install dune 3.18.1
- install dune-configurator 3.18.1
- install duration 0.2.1
- install either 1.0.0
- install eqaf 0.10
- install fmt 0.10.0
- install fpath 0.7.3
- install gen 1.1
- install gmap 0.3.0
- install http 6.1.0
- install ipaddr 5.6.0
- install ipaddr-sexp 5.6.0
- install js_of_ocaml 6.0.1
- install js_of_ocaml-compiler 6.0.1
- install kdf 1.0.0
- install logs 0.8.0
- install lwt 5.9.1
- install macaddr 5.6.0
- install magic-mime 1.3.1
- install mdx 2.5.0
- install menhir 20240715
- install menhirCST 20240715
- install menhirLib 20240715
- install menhirSdk 20240715
- install mirage-crypto 2.0.0
- install mirage-crypto-ec 2.0.0
- install mirage-crypto-pk 2.0.0
- install mirage-crypto-rng 2.0.0
- install mtime 2.1.0
- install multicore-bench 0.1.7
- install multicore-magic 2.3.1
- install multicore-magic-dscheck 2.3.1
- install ocaml-compiler-libs v0.17.0
- install ocaml-syntax-shims 1.0.0
- install ocaml-version 4.0.0
- install ocamlbuild 0.16.1
- install ocamlfind 1.9.8
- install ocplib-endian 1.2
- install ohex 0.2.0
- install oseq 0.5.1
- install ppx_derivers 1.2.1
- install ppx_sexp_conv v0.16.0
- install ppxlib 0.35.0
- install psq 0.2.1
- install ptime 1.2.0
- install qcheck-core 0.25
- install qcheck-multicoretests-util 0.8
- install qcheck-stm 0.8
- install re 1.12.0
- install result 1.5
- install rresult 0.7.0
- install sedlex 3.4
- install seq base
- install sexplib0 v0.16.0
- install stdlib-shims 0.3.0
- install stringext 1.6.0
- install thread-local-storage 0.2
- install thread-table 1.0.0
- install topkg 1.0.8
- install tsort 2.2.0
- install uri 4.4.0
- install uri-sexp 4.4.0
- install uutf 1.0.4
- install x509 1.0.6
- install yojson 2.2.2
- install zarith 1.14
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved asn1-combinators.0.3.2 (cached)
-> retrieved angstrom.0.16.1 (cached)
-> retrieved astring.0.8.5 (cached)
-> retrieved alcotest.1.9.0 (cached)
-> retrieved backoff.0.1.1 (cached)
-> retrieved base.v0.16.4 (cached)
-> retrieved base64.3.5.1 (cached)
-> retrieved bigstringaf.0.10.0 (cached)
-> retrieved ca-certs.1.0.1 (cached)
-> retrieved bos.0.2.1 (cached)
-> retrieved camlp-streams.5.0.1 (cached)
-> retrieved cmdliner.1.3.0 (cached)
-> retrieved conf-gmp.5 (cached)
-> retrieved conf-gmp-powm-sec.4 (cached)
-> retrieved conduit.8.0.0, conduit-lwt.8.0.0, conduit-lwt-unix.8.0.0 (cached)
-> retrieved cohttp.6.1.0, cohttp-lwt.6.1.0, cohttp-lwt-unix.6.1.0, http.6.1.0 (cached)
-> retrieved containers.3.15 (cached)
-> installed conf-gmp.5
-> installed conf-pkg-config.4
-> retrieved cppo.1.8.0 (cached)
-> retrieved csexp.1.5.2 (cached)
-> installed conf-gmp-powm-sec.4
-> retrieved domain-local-await.1.0.1 (cached)
-> retrieved domain-name.0.4.1 (cached)
-> retrieved domain_shims.0.1.0 (cached)
-> retrieved dscheck.0.5.0 (cached)
-> retrieved duration.0.2.1 (cached)
-> retrieved either.1.0.0 (cached)
-> retrieved eqaf.0.10 (cached)
-> retrieved fmt.0.10.0 (cached)
-> retrieved fpath.0.7.3 (cached)
-> retrieved gen.1.1 (cached)
-> retrieved gmap.0.3.0 (cached)
-> retrieved ipaddr.5.6.0, ipaddr-sexp.5.6.0, macaddr.5.6.0 (cached)
-> retrieved digestif.1.3.0 (cached)
-> retrieved kdf.1.0.0 (cached)
-> retrieved logs.0.8.0 (cached)
-> retrieved lwt.5.9.1 (cached)
-> retrieved magic-mime.1.3.1 (cached)
-> retrieved mdx.2.5.0 (cached)
-> retrieved dune.3.18.1, dune-configurator.3.18.1 (cached)
-> retrieved js_of_ocaml.6.0.1, js_of_ocaml-compiler.6.0.1 (cached)
-> retrieved menhir.20240715, menhirCST.20240715, menhirLib.20240715, menhirSdk.20240715 (cached)
-> retrieved mirage-crypto.2.0.0, mirage-crypto-ec.2.0.0, mirage-crypto-pk.2.0.0, mirage-crypto-rng.2.0.0 (cached)
-> retrieved mtime.2.1.0 (cached)
-> retrieved multicore-bench.0.1.7 (cached)
-> retrieved multicore-magic.2.3.1, multicore-magic-dscheck.2.3.1 (cached)
-> installed cmdliner.1.3.0
-> retrieved ocaml-compiler-libs.v0.17.0 (cached)
-> retrieved ocaml-syntax-shims.1.0.0 (cached)
-> retrieved ocaml-version.4.0.0 (cached)
-> retrieved ocplib-endian.1.2 (cached)
-> retrieved ocamlbuild.0.16.1 (cached)
-> retrieved ocamlfind.1.9.8 (cached)
-> retrieved ohex.0.2.0 (cached)
-> retrieved oseq.0.5.1 (cached)
-> retrieved ppx_derivers.1.2.1 (cached)
-> retrieved ppx_sexp_conv.v0.16.0 (cached)
-> retrieved psq.0.2.1 (cached)
-> retrieved ptime.1.2.0 (cached)
-> retrieved qcheck-core.0.25 (cached)
-> retrieved qcheck-multicoretests-util.0.8, qcheck-stm.0.8 (cached)
-> retrieved ppxlib.0.35.0 (cached)
-> retrieved re.1.12.0 (cached)
-> retrieved result.1.5 (cached)
-> retrieved seq.base (cached)
-> installed seq.base
-> retrieved rresult.0.7.0 (cached)
-> retrieved sedlex.3.4 (cached)
-> retrieved sexplib0.v0.16.0 (cached)
-> retrieved stdlib-shims.0.3.0 (cached)
-> retrieved stringext.1.6.0 (cached)
-> retrieved thread-local-storage.0.2 (cached)
-> retrieved thread-table.1.0.0 (cached)
-> retrieved tsort.2.2.0 (cached)
-> retrieved uutf.1.0.4 (cached)
-> retrieved topkg.1.0.8 (cached)
-> retrieved uri.4.4.0, uri-sexp.4.4.0 (cached)
-> retrieved x509.1.0.6 (cached)
-> retrieved yojson.2.2.2 (cached)
-> retrieved zarith.1.14 (cached)
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed zarith.1.14
-> installed ocamlbuild.0.16.1
-> installed topkg.1.0.8
-> installed rresult.0.7.0
-> installed mtime.2.1.0
-> installed ptime.1.2.0
-> installed uutf.1.0.4
-> installed fmt.0.10.0
-> installed astring.0.8.5
-> installed fpath.0.7.3
-> installed dune.3.18.1
-> installed backoff.0.1.1
-> installed camlp-streams.5.0.1
-> installed csexp.1.5.2
-> installed asn1-combinators.0.3.2
-> installed base64.3.5.1
-> installed domain-name.0.4.1
-> installed domain_shims.0.1.0
-> installed duration.0.2.1
-> installed either.1.0.0
-> installed eqaf.0.10
-> installed gen.1.1
-> installed gmap.0.3.0
-> installed http.6.1.0
-> installed macaddr.5.6.0
-> installed menhirCST.20240715
-> installed menhirSdk.20240715
-> installed multicore-magic.2.3.1
-> installed ocaml-version.4.0.0
-> installed ohex.0.2.0
-> installed oseq.0.5.1
-> installed ppx_derivers.1.2.1
-> installed psq.0.2.1
-> installed re.1.12.0
-> installed result.1.5
-> installed sexplib0.v0.16.0
-> installed stdlib-shims.0.3.0
-> installed stringext.1.6.0
-> installed thread-local-storage.0.2
-> installed thread-table.1.0.0
-> installed tsort.2.2.0
-> installed menhirLib.20240715
-> installed domain-local-await.1.0.1
-> installed qcheck-core.0.25
-> installed ipaddr.5.6.0
-> installed cppo.1.8.0
-> installed qcheck-multicoretests-util.0.8
-> installed ocplib-endian.1.2
-> installed yojson.2.2.2
-> installed digestif.1.3.0
-> installed qcheck-stm.0.8
-> installed magic-mime.1.3.1
-> installed multicore-bench.0.1.7
-> installed dune-configurator.3.18.1
-> installed bigstringaf.0.10.0
-> installed ocaml-syntax-shims.1.0.0
-> installed ocaml-compiler-libs.v0.17.0
-> installed angstrom.0.16.1
-> installed alcotest.1.9.0
-> installed mirage-crypto.2.0.0
-> installed containers.3.15
-> installed kdf.1.0.0
-> installed dscheck.0.5.0
-> installed multicore-magic-dscheck.2.3.1
-> installed lwt.5.9.1
-> installed uri.4.4.0
-> installed base.v0.16.4
-> installed menhir.20240715
-> installed ppxlib.0.35.0
-> installed ppx_sexp_conv.v0.16.0
-> installed sedlex.3.4
-> installed uri-sexp.4.4.0
-> installed ipaddr-sexp.5.6.0
-> installed js_of_ocaml-compiler.6.0.1
-> installed logs.0.8.0
-> installed mirage-crypto-rng.2.0.0
-> installed mirage-crypto-pk.2.0.0
-> installed bos.0.2.1
-> installed mdx.2.5.0
-> installed conduit.8.0.0
-> installed cohttp.6.1.0
-> installed conduit-lwt.8.0.0
-> installed cohttp-lwt.6.1.0
-> installed mirage-crypto-ec.2.0.0
-> installed x509.1.0.6
-> installed ca-certs.1.0.1
-> installed conduit-lwt-unix.8.0.0
-> installed cohttp-lwt-unix.6.1.0
-> installed js_of_ocaml.6.0.1
Done.
# To update the current shell environment, run: eval $(opam env)
2025-05-02 08:19.52 ---> using "b7b85bec5f5c39780cc41b532d4296f94c642b20c32aa42be41b3b126d7e404e" from cache
/src: (copy (src .) (dst /src))
2025-05-02 08:19.53 ---> saved as "4b3b5a38aa7488540ba5edc8094dce3be90222b00ed8bee9d4e5517b71d2cd14"
/src: (run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build"))
(cd _build/default/test && ./test_server_and_client.exe)
Using non-blocking sockets and fibers on OCaml 5:
Recursive server running
Server listening
Client B running
Server accepting
Server accepted client
Client A running
Server accepting
Server accepted client
Server accepting
Client B connected
Client B wrote 100
Client A connected
Client A wrote 100
Server read 100
Server wrote 50
Server read 100
Server wrote 50
Client B read 50
Client A read 50
Server and Client test: OK
(cd _build/default/test && ./test_finally.exe)
Testing `Picos_finally'.
This run has ID `8HE0GZGI'.
[OK] move 0 is lazy.
[OK] borrow 0 returns resource.
Full test results in `/src/_build/default/test/_build/_tests/Picos_finally'.
Test Successful in 0.033s. 2 tests run.
(cd _build/default/test && ./test_lwt_unix.exe)
Testing `Picos_lwt'.
This run has ID `UBZ7PM50'.
[OK] Basics 0
Full test results in `/src/_build/default/test/_build/_tests/Picos_lwt'.
Test Successful in 0.051s. 1 test run.
(cd _build/default/bench && ./main.exe -brief 'Picos Computation')
Picos Computation:
attach detach pairs over time/1 worker:
0.13 M/s
attach detach pairs over time/2 workers:
0.40 M/s
attach detach pairs over time/4 workers:
0.47 M/s
attach detach pairs over time/trivial:
0.47 M/s
time per attach detach pair/1 worker:
7573.18 ns
time per attach detach pair/2 workers:
5006.66 ns
time per attach detach pair/4 workers:
8553.01 ns
time per attach detach pair/trivial:
2125.46 ns
(cd _build/default/test && ./test_sync.exe -- '^Mutex and Condition$' 0)
Testing `Picos_sync'.
This run has ID `KJFW89G3'.
[OK] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.052s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Mutex and Condition$' 1)
Testing `Picos_sync'.
This run has ID `73TWXL2L'.
[SKIP] Mutex and Condition 0 basics.
[OK] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.057s. 1 test run.
(cd _build/default/bench && ./main.exe -brief 'Picos Current')
Picos Current:
ops over time/1 worker:
1.78 M/s
ops over time/2 workers:
3.49 M/s
ops over time/4 workers:
5.91 M/s
time per op/1 worker:
562.31 ns
time per op/2 workers:
572.79 ns
time per op/4 workers:
677.33 ns
(cd _build/default/test && ./test_io.exe)
Testing `Picos_io'.
This run has ID `4GMGNO07'.
[OK] Unix 0 openfile and read.
[OK] Unix 1 sleepf.
[OK] Unix 2 select empty timeout.
[OK] Unix 3 select empty ∞.
[OK] Unix 4 select.
[OK] Unix 5 system.
Full test results in `/src/_build/default/test/_build/_tests/Picos_io'.
Test Successful in 0.541s. 6 tests run.
(cd _build/default/test && ./test_picos_lwt_unix_with_cohttp.exe)
Uri: //127.0.0.1:8000/hello-lwt
Method: GET
host: 127.0.0.1:8000
user-agent: ocaml-cohttp/v6.1.0
content-length: 0
Body:
(cd _build/default/bench && ./main.exe -brief 'Picos FLS (excluding Current)')
Picos FLS (excluding Current):
gets over time/1 worker:
4.93 M/s
gets over time/2 workers:
11.66 M/s
gets over time/4 workers:
23.31 M/s
sets over time/1 worker:
6.62 M/s
sets over time/2 workers:
13.43 M/s
sets over time/4 workers:
23.03 M/s
time per get/1 worker:
202.92 ns
time per get/2 workers:
171.52 ns
time per get/4 workers:
171.62 ns
time per set/1 worker:
151.02 ns
time per set/2 workers:
148.96 ns
time per set/4 workers:
173.70 ns
(cd _build/default/test && ./test_io_with_lwt.exe)
Testing `Picos_io_with_lwt'.
This run has ID `4C0SMQ3H'.
[OK] Unix 0 system.
Full test results in `/src/_build/default/test/_build/_tests/Picos_io_with_lwt'.
Test Successful in 2.096s. 1 test run.
(cd _build/default/bench && ./main.exe -brief 'Picos TLS')
Picos TLS:
gets over time/1 worker:
2.78 M/s
gets over time/2 workers:
6.31 M/s
gets over time/4 workers:
11.68 M/s
sets over time/1 worker:
2.78 M/s
sets over time/2 workers:
6.18 M/s
sets over time/4 workers:
10.19 M/s
time per get/1 worker:
359.17 ns
time per get/2 workers:
317.10 ns
time per get/4 workers:
342.38 ns
time per set/1 worker:
360.33 ns
time per set/2 workers:
323.60 ns
time per set/4 workers:
392.40 ns
(cd _build/default/test && ./test_io_cohttp.exe)
Uri: //127.0.0.1:39563/hello-io-cohttp
Method: POST
host: 127.0.0.1:39563
user-agent: ocaml-cohttp/v6.1.0
content-length: 17
Body: It's-a-Me, Picos!
(cd _build/default/bench && ./main.exe -brief 'Picos DLS')
Picos DLS:
gets over time/1 worker:
2.39 M/s
gets over time/2 workers:
4.77 M/s
gets over time/4 workers:
10.90 M/s
sets over time/1 worker:
3.14 M/s
sets over time/2 workers:
6.30 M/s
sets over time/4 workers:
12.10 M/s
time per get/1 worker:
417.56 ns
time per get/2 workers:
419.20 ns
time per get/4 workers:
367.02 ns
time per set/1 worker:
318.15 ns
time per set/2 workers:
317.25 ns
time per set/4 workers:
330.70 ns
(cd _build/default/test && ./test_sync.exe -- '^Mutex and Condition$' 2)
Testing `Picos_sync'.
This run has ID `C9KZH7BZ'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[OK] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 5.506s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Lock and Lock.Condition$' 0)
Testing `Picos_sync'.
This run has ID `J6DWZI19'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[OK] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.025s. 1 test run.
(cd _build/default/example && ./guards.exe)
Testing with scheduler: lwt
Ran guarded case statement examples.
(cd _build/default/test && ./test_structured.exe)
Testing `Picos_structured'.
This run has ID `SL2KINTT'.
[OK] Bundle 0 fork after terminate.
[OK] Bundle 1 fork after escape.
[OK] Bundle 2 exception in child terminates.
[OK] Bundle 3 cancelation awaits children.
[OK] Bundle 4 block raises when forbidden.
[OK] Bundle 5 block raises Sys_error when fiber finishes.
[OK] Bundle 6 termination nests.
[OK] Bundle 7 promise cancelation does not terminate.
[OK] Bundle 8 error in promise terminates.
[OK] Bundle 9 can wait promises.
[OK] Bundle 10 can select promises.
[OK] Run 0 any and all errors.
[OK] Run 1 any and all returns.
[OK] Run 2 race any.
[OK] Run 3 for_n basic.
Full test results in `/src/_build/default/test/_build/_tests/Picos_structured'.
Test Successful in 8.112s. 15 tests run.
(cd _build/default/test && ./test_select.exe)
Testing `Picos_select'.
This run has ID `BJUTPC43'.
[OK] Intr 0
Full test results in `/src/_build/default/test/_build/_tests/Picos_select'.
Test Successful in 10.349s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Lock and Lock.Condition$' 1)
Testing `Picos_sync'.
This run has ID `KPM1ZU8L'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[OK] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 3.673s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Lock and Lock.Condition$' 2)
Testing `Picos_sync'.
This run has ID `UJ0NG8NN'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[OK] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.015s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Lock and Lock.Condition$' 3)
Testing `Picos_sync'.
This run has ID `NCQLAOSN'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[OK] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.009s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 0)
Testing `Picos_sync'.
This run has ID `3E2HJUM7'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[OK] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.078s. 1 test run.
(cd _build/default/test && ./test_picos_dscheck.exe)
Testing `Picos DSCheck'.
This run has ID `SLQU1EK8'.
[OK] Trigger 0 basic contract.
[OK] Computation 0 basic contract.
[OK] Computation 1 removes triggers.
Full test results in `/src/_build/default/test/_build/_tests/Picos DSCheck'.
Test Successful in 11.145s. 3 tests run.
(cd _build/default/bench && ./main.exe -brief 'Yield with Picos_std_sync')
Yield with Picos_std_sync:
locked yields over time/1024 fibers with Lock:
0.04 M/s
locked yields over time/1024 fibers with Rwlock:
0.04 M/s
locked yields over time/1024 fibers with Sem:
0.04 M/s
locked yields over time/1024 fibers with Sem 2:
0.05 M/s
locked yields over time/1024 fibers with Sem 3:
0.05 M/s
locked yields over time/1024 fibers with Sem 4:
0.06 M/s
locked yields over time/1 fiber with Lock:
0.32 M/s
locked yields over time/1 fiber with Rwlock:
0.33 M/s
locked yields over time/1 fiber with Sem:
0.31 M/s
locked yields over time/1 fiber with Sem 2:
0.31 M/s
locked yields over time/1 fiber with Sem 3:
0.27 M/s
locked yields over time/1 fiber with Sem 4:
0.26 M/s
locked yields over time/256 fibers with Lock:
0.06 M/s
locked yields over time/256 fibers with Rwlock:
0.04 M/s
locked yields over time/256 fibers with Sem:
0.06 M/s
locked yields over time/256 fibers with Sem 2:
0.08 M/s
locked yields over time/256 fibers with Sem 3:
0.08 M/s
locked yields over time/256 fibers with Sem 4:
0.09 M/s
locked yields over time/2 domains with Lock:
0.09 M/s
locked yields over time/2 domains with Rwlock:
0.08 M/s
locked yields over time/2 domains with Sem:
0.11 M/s
locked yields over time/2 domains with Sem 2:
0.31 M/s
locked yields over time/2 domains with Sem 3:
0.30 M/s
locked yields over time/2 domains with Sem 4:
0.34 M/s
locked yields over time/2 fibers with Lock:
0.31 M/s
locked yields over time/2 fibers with Rwlock:
0.33 M/s
locked yields over time/2 fibers with Sem:
0.32 M/s
locked yields over time/2 fibers with Sem 2:
0.24 M/s
locked yields over time/2 fibers with Sem 3:
0.27 M/s
locked yields over time/2 fibers with Sem 4:
0.27 M/s
locked yields over time/3 domains with Lock:
0.08 M/s
locked yields over time/3 domains with Rwlock:
0.10 M/s
locked yields over time/3 domains with Sem:
0.11 M/s
locked yields over time/3 domains with Sem 2:
0.24 M/s
locked yields over time/3 domains with Sem 3:
0.43 M/s
locked yields over time/3 domains with Sem 4:
0.41 M/s
locked yields over time/3 fibers with Lock:
0.32 M/s
locked yields over time/3 fibers with Rwlock:
0.33 M/s
locked yields over time/3 fibers with Sem:
0.32 M/s
locked yields over time/3 fibers with Sem 2:
0.27 M/s
locked yields over time/3 fibers with Sem 3:
0.27 M/s
locked yields over time/3 fibers with Sem 4:
0.26 M/s
locked yields over time/4 domains with Lock:
0.02 M/s
locked yields over time/4 domains with Rwlock:
0.09 M/s
locked yields over time/4 domains with Sem:
0.09 M/s
locked yields over time/4 domains with Sem 2:
0.04 M/s
locked yields over time/4 domains with Sem 3:
0.35 M/s
locked yields over time/4 domains with Sem 4:
0.50 M/s
locked yields over time/4 fibers with Lock:
0.28 M/s
locked yields over time/4 fibers with Rwlock:
0.33 M/s
locked yields over time/4 fibers with Sem:
0.31 M/s
locked yields over time/4 fibers with Sem 2:
0.20 M/s
locked yields over time/4 fibers with Sem 3:
0.26 M/s
locked yields over time/4 fibers with Sem 4:
0.26 M/s
locked yields over time/512 fibers with Lock:
0.05 M/s
locked yields over time/512 fibers with Rwlock:
0.05 M/s
locked yields over time/512 fibers with Sem:
0.05 M/s
locked yields over time/512 fibers with Sem 2:
0.07 M/s
locked yields over time/512 fibers with Sem 3:
0.07 M/s
locked yields over time/512 fibers with Sem 4:
0.08 M/s
locked yields over time/8 domains with Lock:
0.02 M/s
locked yields over time/8 domains with Rwlock:
0.10 M/s
locked yields over time/8 domains with Sem:
0.08 M/s
locked yields over time/8 domains with Sem 2:
0.04 M/s
locked yields over time/8 domains with Sem 3:
0.03 M/s
locked yields over time/8 domains with Sem 4:
0.06 M/s
locked yields over time/8 fibers with Lock:
0.28 M/s
locked yields over time/8 fibers with Rwlock:
0.30 M/s
locked yields over time/8 fibers with Sem:
0.40 M/s
locked yields over time/8 fibers with Sem 2:
0.26 M/s
locked yields over time/8 fibers with Sem 3:
0.26 M/s
locked yields over time/8 fibers with Sem 4:
0.26 M/s
time per locked yield/1024 fibers with Lock:
26706.23 ns
time per locked yield/1024 fibers with Rwlock:
24447.92 ns
time per locked yield/1024 fibers with Sem:
23066.53 ns
time per locked yield/1024 fibers with Sem 2:
18996.31 ns
time per locked yield/1024 fibers with Sem 3:
19307.86 ns
time per locked yield/1024 fibers with Sem 4:
17461.69 ns
time per locked yield/1 fiber with Lock:
3079.40 ns
time per locked yield/1 fiber with Rwlock:
3046.94 ns
time per locked yield/1 fiber with Sem:
3181.56 ns
time per locked yield/1 fiber with Sem 2:
3218.69 ns
time per locked yield/1 fiber with Sem 3:
3735.85 ns
time per locked yield/1 fiber with Sem 4:
3851.15 ns
time per locked yield/256 fibers with Lock:
17021.11 ns
time per locked yield/256 fibers with Rwlock:
23072.21 ns
time per locked yield/256 fibers with Sem:
17473.99 ns
time per locked yield/256 fibers with Sem 2:
12377.02 ns
time per locked yield/256 fibers with Sem 3:
12579.22 ns
time per locked yield/256 fibers with Sem 4:
10892.63 ns
time per locked yield/2 domains with Lock:
21415.48 ns
time per locked yield/2 domains with Rwlock:
24531.53 ns
time per locked yield/2 domains with Sem:
18575.62 ns
time per locked yield/2 domains with Sem 2:
6449.38 ns
time per locked yield/2 domains with Sem 3:
6612.19 ns
time per locked yield/2 domains with Sem 4:
5843.57 ns
time per locked yield/2 fibers with Lock:
3177.14 ns
time per locked yield/2 fibers with Rwlock:
3058.43 ns
time per locked yield/2 fibers with Sem:
3125.69 ns
time per locked yield/2 fibers with Sem 2:
4095.35 ns
time per locked yield/2 fibers with Sem 3:
3731.70 ns
time per locked yield/2 fibers with Sem 4:
3761.79 ns
time per locked yield/3 domains with Lock:
37034.37 ns
time per locked yield/3 domains with Rwlock:
30951.72 ns
time per locked yield/3 domains with Sem:
26345.59 ns
time per locked yield/3 domains with Sem 2:
12720.23 ns
time per locked yield/3 domains with Sem 3:
7013.45 ns
time per locked yield/3 domains with Sem 4:
7269.83 ns
time per locked yield/3 fibers with Lock:
3160.15 ns
time per locked yield/3 fibers with Rwlock:
3066.93 ns
time per locked yield/3 fibers with Sem:
3140.57 ns
time per locked yield/3 fibers with Sem 2:
3750.13 ns
time per locked yield/3 fibers with Sem 3:
3742.17 ns
time per locked yield/3 fibers with Sem 4:
3835.12 ns
time per locked yield/4 domains with Lock:
192209.18 ns
time per locked yield/4 domains with Rwlock:
45311.09 ns
time per locked yield/4 domains with Sem:
42346.47 ns
time per locked yield/4 domains with Sem 2:
93050.38 ns
time per locked yield/4 domains with Sem 3:
11436.74 ns
time per locked yield/4 domains with Sem 4:
8034.89 ns
time per locked yield/4 fibers with Lock:
3552.72 ns
time per locked yield/4 fibers with Rwlock:
3071.36 ns
time per locked yield/4 fibers with Sem:
3185.34 ns
time per locked yield/4 fibers with Sem 2:
5779.46 ns
time per locked yield/4 fibers with Sem 3:
3783.60 ns
time per locked yield/4 fibers with Sem 4:
3776.12 ns
time per locked yield/512 fibers with Lock:
19240.20 ns
time per locked yield/512 fibers with Rwlock:
19418.68 ns
time per locked yield/512 fibers with Sem:
19912.12 ns
time per locked yield/512 fibers with Sem 2:
14520.09 ns
time per locked yield/512 fibers with Sem 3:
14694.15 ns
time per locked yield/512 fibers with Sem 4:
13061.16 ns
time per locked yield/8 domains with Lock:
423885.20 ns
time per locked yield/8 domains with Rwlock:
78355.92 ns
time per locked yield/8 domains with Sem:
103638.85 ns
time per locked yield/8 domains with Sem 2:
190931.01 ns
time per locked yield/8 domains with Sem 3:
297286.65 ns
time per locked yield/8 domains with Sem 4:
129074.79 ns
time per locked yield/8 fibers with Lock:
3596.77 ns
time per locked yield/8 fibers with Rwlock:
3349.29 ns
time per locked yield/8 fibers with Sem:
2472.72 ns
time per locked yield/8 fibers with Sem 2:
3782.79 ns
time per locked yield/8 fibers with Sem 3:
3832.14 ns
time per locked yield/8 fibers with Sem 4:
3798.31 ns
(cd _build/default/bench && ./main.exe -brief 'Picos Spawn')
Picos Spawn:
(cd _build/default/bench && ./main.exe -brief 'Picos Yield')
Picos Yield:
time per yield/100 fibers:
2206.64 ns
time per yield/10 fibers:
2174.22 ns
time per yield/1 fiber:
2297.71 ns
yields over time/100 fibers:
0.45 M/s
yields over time/10 fibers:
0.46 M/s
yields over time/1 fiber:
0.44 M/s
(cd _build/default/bench && ./main.exe -brief 'Picos Cancel_after with Picos_select')
Picos Cancel_after with Picos_select:
async round-trips over time/1 worker:
0.04 M/s
async round-trips over time/2 workers:
0.06 M/s
async round-trips over time/4 workers:
0.08 M/s
round-trips over time/1 worker:
0.02 M/s
round-trips over time/2 workers:
0.06 M/s
round-trips over time/4 workers:
0.15 M/s
time per async round-trip/1 worker:
24197.88 ns
time per async round-trip/2 workers:
32379.69 ns
time per async round-trip/4 workers:
49298.95 ns
time per round-trip/1 worker:
58056.04 ns
time per round-trip/2 workers:
32023.62 ns
time per round-trip/4 workers:
26168.84 ns
(cd _build/default/bench && ./main.exe -brief 'Ref with Picos_std_sync')
Ref with Picos_std_sync:
ops over time/cas int with Lock:
1.37 M/s
ops over time/cas int with Rwlock:
1.49 M/s
ops over time/cas int with Sem:
1.54 M/s
ops over time/get with Lock:
1.66 M/s
ops over time/get with Rwlock:
1.88 M/s
ops over time/get with Sem:
1.74 M/s
ops over time/incr with Lock:
1.54 M/s
ops over time/incr with Rwlock:
1.83 M/s
ops over time/incr with Sem:
1.40 M/s
ops over time/push & pop with Lock:
1.45 M/s
ops over time/push & pop with Rwlock:
1.72 M/s
ops over time/push & pop with Sem:
1.74 M/s
ops over time/swap with Lock:
1.70 M/s
ops over time/swap with Rwlock:
1.67 M/s
ops over time/swap with Sem:
1.62 M/s
ops over time/xchg int with Lock:
1.53 M/s
ops over time/xchg int with Rwlock:
1.58 M/s
ops over time/xchg int with Sem:
1.48 M/s
time per op/cas int with Lock:
731.04 ns
time per op/cas int with Rwlock:
671.26 ns
time per op/cas int with Sem:
650.55 ns
time per op/get with Lock:
601.40 ns
time per op/get with Rwlock:
532.94 ns
time per op/get with Sem:
573.44 ns
time per op/incr with Lock:
649.38 ns
time per op/incr with Rwlock:
545.93 ns
time per op/incr with Sem:
712.28 ns
time per op/push & pop with Lock:
691.12 ns
time per op/push & pop with Rwlock:
579.91 ns
time per op/push & pop with Sem:
573.31 ns
time per op/swap with Lock:
589.29 ns
time per op/swap with Rwlock:
597.14 ns
time per op/swap with Sem:
618.79 ns
time per op/xchg int with Lock:
655.18 ns
time per op/xchg int with Rwlock:
633.95 ns
time per op/xchg int with Sem:
677.02 ns
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 1)
Testing `Picos_sync'.
This run has ID `PNKFEORE'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[OK] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 2.943s. 1 test run.
(cd _build/default/bench && ./main.exe -brief Picos_mpmcq)
Picos_mpmcq:
messages over time/1 nb adder, 1 nb taker:
1.52 M/s
messages over time/1 nb adder, 2 nb takers:
1.09 M/s
messages over time/1 nb adder, 4 nb takers:
1.02 M/s
messages over time/2 nb adders, 1 nb taker:
1.32 M/s
messages over time/2 nb adders, 2 nb takers:
1.26 M/s
messages over time/2 nb adders, 4 nb takers:
1.26 M/s
messages over time/4 nb adders, 1 nb taker:
1.44 M/s
messages over time/4 nb adders, 2 nb takers:
1.13 M/s
messages over time/4 nb adders, 4 nb takers:
1.13 M/s
messages over time/one domain:
0.74 M/s
time per message/1 nb adder, 1 nb taker:
1318.55 ns
time per message/1 nb adder, 2 nb takers:
2744.20 ns
time per message/1 nb adder, 4 nb takers:
4901.75 ns
time per message/2 nb adders, 1 nb taker:
2265.06 ns
time per message/2 nb adders, 2 nb takers:
3164.90 ns
time per message/2 nb adders, 4 nb takers:
4771.99 ns
time per message/4 nb adders, 1 nb taker:
3479.40 ns
time per message/4 nb adders, 2 nb takers:
5321.45 ns
time per message/4 nb adders, 4 nb takers:
7107.87 ns
time per message/one domain:
1352.84 ns
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 2)
Testing `Picos_sync'.
This run has ID `UMMA3PH7'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[OK] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.008s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 3)
Testing `Picos_sync'.
This run has ID `1K55K5QE'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[OK] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.008s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 4)
Testing `Picos_sync'.
This run has ID `4ZRIVQ1A'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[OK] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.006s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 5)
Testing `Picos_sync'.
This run has ID `EML78OFN'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[OK] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.009s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 6)
Testing `Picos_sync'.
This run has ID `6KRKKNFA'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[OK] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.007s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Semaphore$ 0)
Testing `Picos_sync'.
This run has ID `A770UP88'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[OK] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.005s. 1 test run.
(cd _build/default/bench && ./main.exe -brief Picos_mpscq)
Picos_mpscq:
messages over time/1 nb adder, 1 nb taker:
2.44 M/s
messages over time/2 nb adders, 1 nb taker:
2.76 M/s
messages over time/4 nb adders, 1 nb taker:
2.92 M/s
messages over time/one domain:
0.99 M/s
time per message/1 nb adder, 1 nb taker:
821.34 ns
time per message/2 nb adders, 1 nb taker:
1086.11 ns
time per message/4 nb adders, 1 nb taker:
1711.54 ns
time per message/one domain:
1005.19 ns
(cd _build/default/test && ./test_sync.exe -- ^Semaphore$ 1)
Testing `Picos_sync'.
This run has ID `N15QK1E5'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[OK] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 1.801s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Sem$ 0)
Testing `Picos_sync'.
This run has ID `F28J9BPR'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[OK] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.006s. 1 test run.
(cd _build/default/bench && ./main.exe -brief Picos_htbl)
Picos_htbl:
operations over time/1 worker, 10% reads:
0.13 M/s
operations over time/1 worker, 50% reads:
0.21 M/s
operations over tim
/1 worker, 90% reads:
0.20 M/s
operations over time/2 workers, 10% reads:
0.28 M/s
operations over time/2 workers, 50% reads:
0.39 M/s
operations over time/2 workers, 90% reads:
0.39 M/s
operations over time/4 workers, 10% reads:
0.50 M/s
operations over time/4 workers, 50% reads:
0.63 M/s
operations over time/4 workers, 90% reads:
0.84 M/s
operations over time/8 workers, 10% reads:
1.06 M/s
operations over time/8 workers, 50% reads:
1.21 M/s
operations over time/8 workers, 90% reads:
1.67 M/s
time per operation/1 worker, 10% reads:
7999.31 ns
time per operation/1 worker, 50% reads:
4706.43 ns
time per operation/1 worker, 90% reads:
4988.47 ns
time per operation/2 workers, 10% reads:
7068.50 ns
time per operation/2 workers, 50% reads:
5087.12 ns
time per operation/2 workers, 90% reads:
5071.06 ns
time per operation/4 workers, 10% reads:
7931.12 ns
time per operation/4 workers, 50% reads:
6305.40 ns
time per operation/4 workers, 90% reads:
4785.78 ns
time per operation/8 workers, 10% reads:
7537.15 ns
time per operation/8 workers, 50% reads:
6586.74 ns
time per operation/8 workers, 90% reads:
4782.10 ns
(cd _build/default/bench && ./main.exe -brief 'Hashtbl with Picos_std_sync')
Hashtbl with Picos_std_sync:
operations over time/1 worker, 10% reads with Lock:
0.65 M/s
operations over time/1 worker, 10% reads with Rwlock:
0.70 M/s
operations over time/1 worker, 10% reads with Sem:
0.81 M/s
operations over time/1 worker, 100% reads with Lock:
0.64 M/s
operations over time/1 worker, 100% reads with Rwlock:
0.98 M/s
operations over time/1 worker, 100% reads with Sem:
0.92 M/s
operations over time/1 worker, 50% reads with Lock:
0.68 M/s
operations over time/1 worker, 50% reads with Rwlock:
0.87 M/s
operations over time/1 worker, 50% reads with Sem:
0.77 M/s
operations over time/1 worker, 90% reads with Lock:
0.63 M/s
operations over time/1 worker, 90% reads with Rwlock:
0.94 M/s
operations over time/1 worker, 90% reads with Sem:
0.91 M/s
operations over time/1 worker, 95% reads with Lock:
0.63 M/s
operations over time/1 worker, 95% reads with Rwlock:
0.96 M/s
operations over time/1 worker, 95% reads with Sem:
0.91 M/s
operations over time/2 workers, 10% reads with Lock:
0.67 M/s
operations over time/2 workers, 10% reads with Rwlock:
0.59 M/s
operations over time/2 workers, 10% reads with Sem:
0.62 M/s
operations over time/2 workers, 100% reads with Lock:
0.92 M/s
operations over time/2 workers, 100% reads with Rwlock:
1.56 M/s
operations over time/2 workers, 100% reads with Sem:
0.75 M/s
operations over time/2 workers, 50% reads with Lock:
0.69 M/s
operations over time/2 workers, 50% reads with Rwlock:
0.72 M/s
operations over time/2 workers, 50% reads with Sem:
0.69 M/s
operations over time/2 workers, 90% reads with Lock:
0.90 M/s
operations over time/2 workers, 90% reads with Rwlock:
1.03 M/s
operations over time/2 workers, 90% reads with Sem:
0.65 M/s
operations over time/2 workers, 95% reads with Lock:
0.91 M/s
operations over time/2 workers, 95% reads with Rwlock:
1.14 M/s
operations over time/2 workers, 95% reads with Sem:
0.77 M/s
operations over time/4 workers, 10% reads with Lock:
0.33 M/s
operations over time/4 workers, 10% reads with Rwlock:
0.27 M/s
operations over time/4 workers, 10% reads with Sem:
0.43 M/s
operations over time/4 workers, 100% reads with Lock:
0.47 M/s
operations over time/4 workers, 100% reads with Rwlock:
2.88 M/s
operations over time/4 workers, 100% reads with Sem:
0.53 M/s
operations over time/4 workers, 50% reads with Lock:
0.33 M/s
operations over time/4 workers, 50% reads with Rwlock:
0.35 M/s
operations over time/4 workers, 50% reads with Sem:
0.47 M/s
operations over time/4 workers, 90% reads with Lock:
0.43 M/s
operations over time/4 workers, 90% reads with Rwlock:
0.79 M/s
operations over time/4 workers, 90% reads with Sem:
0.50 M/s
operations over time/4 workers, 95% reads with Lock:
0.44 M/s
operations over time/4 workers, 95% reads with Rwlock:
0.94 M/s
operations over time/4 workers, 95% reads with Sem:
0.53 M/s
operations over time/8 workers, 10% reads with Lock:
0.29 M/s
operations over time/8 workers, 10% reads with Rwlock:
0.29 M/s
operations over time/8 workers, 10% reads with Sem:
0.35 M/s
operations over time/8 workers, 100% reads with Lock:
0.37 M/s
operations over time/8 workers, 100% reads with Rwlock:
4.97 M/s
operations over time/8 workers, 100% reads with Sem:
0.45 M/s
operations over time/8 workers, 50% reads with Lock:
0.31 M/s
operations over time/8 workers, 50% reads with Rwlock:
0.37 M/s
operations over time/8 workers, 50% reads with Sem:
0.36 M/s
operations over time/8 workers, 90% reads with Lock:
0.35 M/s
operations over time/8 workers, 90% reads with Rwlock:
0.79 M/s
operations over time/8 workers, 90% reads with Sem:
0.47 M/s
operations over time/8 workers, 95% reads with Lock:
0.31 M/s
operations over time/8 workers, 95% reads with Rwlock:
1.15 M/s
operations over time/8 workers, 95% reads with Sem:
0.48 M/s
time per operation/1 worker, 10% reads with Lock:
1545.74 ns
time per operation/1 worker, 10% reads with Rwlock:
1423.61 ns
time per operation/1 worker, 10% reads with Sem:
1237.95 ns
time per operation/1 worker, 100% reads with Lock:
1562.11 ns
time per operation/1 worker, 100% reads with Rwlock:
1024.11 ns
time per operation/1 worker, 100% reads with Sem:
1088.68 ns
time per operation/1 worker, 50% reads with Lock:
1474.48 ns
time per operation/1 worker, 50% reads with Rwlock:
1147.76 ns
time per operation/1 worker, 50% reads with Sem:
1298.17 ns
time per operation/1 worker, 90% reads with Lock:
1591.57 ns
time per operation/1 worker, 90% reads with Rwlock:
1059.16 ns
time per operation/1 worker, 90% reads with Sem:
1094.15 ns
time per operation/1 worker, 95% reads with Lock:
1579.17 ns
time per operation/1 worker, 95% reads with Rwlock:
1043.00 ns
time per operation/1 worker, 95% reads with Sem:
1093.54 ns
time per operation/2 workers, 10% reads with Lock:
3000.74 ns
time per operation/2 workers, 10% reads with Rwlock:
3374.22 ns
time per operation/2 workers, 10% reads with Sem:
3216.72 ns
time per operation/2 workers, 100% reads with Lock:
2181.05 ns
time per operation/2 workers, 100% reads with Rwlock:
1282.05 ns
time per operation/2 workers, 100% reads with Sem:
2656.48 ns
time per operation/2 workers, 50% reads with Lock:
2904.14 ns
time per operation/2 workers, 50% reads with Rwlock:
2786.81 ns
time per operation/2 workers, 50% reads with Sem:
2894.43 ns
time per operation/2 workers, 90% reads with Lock:
2220.74 ns
time per operation/2 workers, 90% reads with Rwlock:
1944.04 ns
time per operation/2 workers, 90% reads with Sem:
3053.56 ns
time per operation/2 workers, 95% reads with Lock:
2189.31 ns
time per operation/2 workers, 95% reads with Rwlock:
1760.07 ns
time per operation/2 workers, 95% reads with Sem:
2599.41 ns
time per operation/4 workers, 10% reads with Lock:
12178.67 ns
time per operation/4 workers, 10% reads with Rwlock:
14988.85 ns
time per operation/4 workers, 10% reads with Sem:
9225.16 ns
time per operation/4 workers, 100% reads with Lock:
8489.56 ns
time per operation/4 workers, 100% reads with Rwlock:
1387.58 ns
time per operation/4 workers, 100% reads with Sem:
7584.08 ns
time per operation/4 workers, 50% reads with Lock:
12280.82 ns
time per operation/4 workers, 50% reads with Rwlock:
11523.62 ns
time per operation/4 workers, 50% reads with Sem:
8536.13 ns
time per operation/4 workers, 90% reads with Lock:
9267.59 ns
time per operation/4 workers, 90% reads with Rwlock:
5051.38 ns
time per operation/4 workers, 90% reads with Sem:
8033.08 ns
time per operation/4 workers, 95% reads with Lock:
9078.75 ns
time per operation/4 workers, 95% reads with Rwlock:
4267.99 ns
time per operation/4 workers, 95% reads with Sem:
7505.40 ns
time per operation/8 workers, 10% reads with Lock:
27800.03 ns
time per operation/8 workers, 10% reads with Rwlock:
28011.51 ns
time per operation/8 workers, 10% reads with Sem:
22590.92 ns
time per operation/8 workers, 100% reads with Lock:
21738.17 ns
time per operation/8 workers, 100% reads with Rwlock:
1609.51 ns
time per operation/8 workers, 100% reads with Sem:
17709.85 ns
time per operation/8 workers, 50% reads with Lock:
25649.31 ns
time per operation/8 workers, 50% reads with Rwlock:
21386.13 ns
time per operation/8 workers, 50% reads with Sem:
22192.01 ns
time per operation/8 workers, 90% reads with Lock:
22976.77 ns
time per operation/8 workers, 90% reads with Rwlock:
10091.57 ns
time per operation/8 workers, 90% reads with Sem:
17157.19 ns
time per operation/8 workers, 95% reads with Lock:
25463.22 ns
time per operation/8 workers, 95% reads with Rwlock:
6949.21 ns
time per operation/8 workers, 95% reads with Sem:
16576.14 ns
(cd _build/default/test && ./test_sync.exe -- ^Sem$ 1)
Testing `Picos_sync'.
This run has ID `C80VPNR4'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[OK] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 7.674s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Sem$ 2)
Testing `Picos_sync'.
This run has ID `RN97P0MO'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[OK] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.005s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Sem$ 3)
Testing `Picos_sync'.
This run has ID `BPJHYSC9'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[OK] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.005s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Lazy$ 0)
Testing `Picos_sync'.
This run has ID `75B8EUVD'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[OK] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.006s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Lazy$ 1)
Testing `Picos_sync'.
This run has ID `3HKJIS8G'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[OK] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.005s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Event$ 0)
Testing `Picos_sync'.
This run has ID `XUNH7U0W'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[OK] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.106s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Barrier$ 0)
Testing `Picos_sync'.
This run has ID `K87URNJ2'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[OK] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.009s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Barrier$ 1)
Testing `Picos_sync'.
This run has ID `DDPNJ26F'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[OK] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.010s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Non-cancelable ops$' 0)
Testing `Picos_sync'.
This run has ID `LGPDLGZI'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[OK] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.005s. 1 test run.
(cd _build/default/test && ./test_picos.exe)
Testing `Picos'.
This run has ID `6FNETJ6E'.
[OK] Trigger 0 basics.
[OK] Computation 0 basics.
[OK] Computation 1 tx.
[OK] Computation 2 signals in order.
[OK] Fiber.FLS 0 basics.
[OK] Cancel 0
[OK] Cancel after 0
Full test results in `/src/_build/default/test/_build/_tests/Picos'.
Test Successful in 28.599s. 7 tests run.
(cd _build/default/test && ./test_mpmcq_dscheck.exe)
Testing `Picos_mpmcq DSCheck'.
This run has ID `50ZCSFN4'.
[OK] Multiple pushes and pops 0
Full test results in `/src/_build/default/test/_build/_tests/Picos_mpmcq DSCheck'.
Test Successful in 32.289s. 1 test run.
(cd _build/default/bench && ./main.exe -brief Picos_stdio)
Picos_stdio:
blocking reads over time/1 worker:
0.00 M/s
blocking reads over time/2 workers:
0.00 M/s
blocking reads over time/4 workers:
0.02 M/s
non-blocking reads over time/1 worker:
0.31 M/s
non-blocking reads over time/2 workers:
0.70 M/s
non-blocking reads over time/4 workers:
1.19 M/s
time per blocking read/1 worker:
567062.96 ns
time per blocking read/2 workers:
463258.62 ns
time per blocking read/4 workers:
234512.30 ns
time per non-blocking read/1 worker:
3251.75 ns
time per non-blocking read/2 workers:
2849.29 ns
time per non-blocking read/4 workers:
3356.26 ns
(cd _build/default/bench && ./main.exe -brief 'Picos_sync Stream')
Picos_sync Stream:
messages over time/1 nb pusher, 1 nb reader:
0.89 M/s
messages over time/2 nb pushers, 1 nb reader:
0.92 M/s
messages over time/4 nb pushers, 1 nb reader:
1.26 M/s
messages over time/one domain:
0.63 M/s
time per message/1 nb pusher, 1 nb reader:
2242.94 ns
time per message/2 nb pushers, 1 nb reader:
3247.50 ns
time per message/4 nb pushers, 1 nb reader:
3978.65 ns
time per message/one domain:
1576.46 ns
(cd _build/default/bench && ./main.exe -brief Fib)
Fib:
(cd _build/default/bench && ./main.exe -brief 'Picos binaries')
Picos binaries:
(cd _build/default/bench && ./main.exe -brief 'Bounded_q with Picos_std_sync')
Bounded_q with Picos_std_sync:
messages over time/1 adder, 1 taker with Lock:
0.50 M/s
messages over time/1 adder, 2 takers with Lock:
0.05 M/s
messages over time/1 adder, 4 takers with Lock:
0.03 M/s
messages over time/2 adders, 1 taker with Lock:
0.26 M/s
messages over time/2 adders, 2 takers with Lock:
0.25 M/s
messages over time/2 adders, 4 takers with Lock:
0.12 M/s
messages over time/4 adders, 1 taker with Lock:
0.30 M/s
messages over time/4 adders, 2 takers with Lock:
0.23 M/s
messages over time/4 adders, 4 takers with Lock:
0.15 M/s
messages over time/one domain with Lock:
0.55 M/s
time per message/1 adder, 1 taker with Lock:
4016.82 ns
time per message/1 adder, 2 takers with Lock:
58619.45 ns
time per message/1 adder, 4 takers with Lock:
170880.12 ns
time per message/2 adders, 1 taker with Lock:
11537.53 ns
time per message/2 adders, 2 takers with Lock:
16008.47 ns
time per message/2 adders, 4 takers with Lock:
49400.63 ns
time per message/4 adders, 1 taker with Lock:
16718.96 ns
time per message/4 adders, 2 takers with Lock:
26073.29 ns
time per message/4 adders, 4 takers with Lock:
54625.96 ns
time per message/one domain with Lock:
1820.60 ns
(cd _build/default/bench && ./main.exe -brief 'Memory usage')
Memory usage:
stack and heap used/Fun.protect:
100.00 B
stack and heap used/fiber in a bundle:
116.00 B
stack and heap used/fiber in a flock:
124.00 B
stack and heap used/fiber with shared computation & latch:
104.00 B
stack and heap used/finally:
80.00 B
stack and heap used/instantiate:
112.00 B
stack and heap used/join_after bundle:
176.00 B
stack and heap used/join_after flock:
176.00 B
stack and heap used/lastly:
76.00 B
stack and heap used/promise in a bundle:
176.00 B
stack and heap used/promise in a flock:
184.00 B
(cd _build/default/test && ./test_htbl.exe)
random seed: 454417110
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Htbl sequential
[ ] 0 0 0 0 / 32 0.0s Htbl sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Htbl sequential
[ ] 0 0 0 0 / 32 0.0s Htbl parallel
[ ] 1 0 0 1 / 32 0.8s Htbl parallel
[ ] 2 0 0 2 / 32 1.5s Htbl parallel
[ ] 3 0 0 3 / 32 3.1s Htbl parallel
[ ] 4 0 0 4 / 32 7.5s Htbl parallel
[ ] 5 0 0 5 / 32 8.4s Htbl parallel
[ ] 6 0 0 6 / 32 8.6s Htbl parallel
[ ] 7 0 0 7 / 32 8.8s Htbl parallel
[ ] 9 0 0 9 / 32 9.6s Htbl parallel
[ ] 10 0 0 10 / 32 11.8s Htbl parallel
[ ] 14 0 0 14 / 32 12.1s Htbl parallel
[ ] 15 0 0 15 / 32 14.3s Htbl parallel
[ ] 19 0 0 19 / 32 14.5s Htbl parallel
[ ] 21 0 0 21 / 32 14.9s Htbl parallel
[ ] 22 0 0 22 / 32 15.1s Htbl parallel
[ ] 23 0 0 23 / 32 18.8s Htbl parallel
[ ] 25 0 0 25 / 32 20.6s Htbl parallel
[ ] 26 0 0 26 / 32 21.2s Htbl parallel
[ ] 27 0 0 27 / 32 21.7s Htbl parallel
[✓] 32 0 0 32 / 32 21.8s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 167349137
generated error fail pass / total time test name
[ ] 0 0 0 0 / 56 0.0s Htbl sequential
[✓] 56 0 0 56 / 56 0.0s Htbl sequential
[ ] 0 0 0 0 / 56 0.0s Htbl parallel
[ ] 2 0 0 2 / 56 1.4s Htbl parallel
[ ] 8 0 0 8 / 56 2.9s Htbl parallel
[ ] 12 0 0 12 / 56 7.6s Htbl parallel
[ ] 16 0 0 16 / 56 11.5s Htbl parallel
[ ] 17 0 0 17 / 56 12.1s Htbl parallel
[ ] 18 0 0 18 / 56 13.3s Htbl parallel
[ ] 19 0 0 19 / 56 14.7s Htbl parallel
[ ] 22 0 0 22 / 56 18.2s Htbl parallel
[ ] 23 0 0 23 / 56 21.1s Htbl parallel
[ ] 25 0 0 25 / 56 23.1s Htbl parallel
[ ] 26 0 0 26 / 56 24.1s Htbl parallel
[ ] 29 0 0 29 / 56 24.8s Htbl parallel
[ ] 30 0 0 30 / 56 25.0s Htbl parallel
[ ] 32 0 0 32 / 56 30.1s Htbl parallel
[ ] 35 0 0 35 / 56 30.5s Htbl parallel
[ ] 37 0 0 37 / 56 32.0s Htbl parallel
[ ] 42 0 0 42 / 56 35.8s Htbl parallel
[ ] 46 0 0 46 / 56 36.1s Htbl parallel
[ ] 52 0 0 52 / 56 36.2s Htbl parallel
[ ] 54 0 0 54 / 56 37.1s Htbl parallel
[ ] 55 0 0 55 / 56 37.4s Htbl parallel
[ ] 56 0 0 56 / 56 38.7s Htbl parallel
[✓] 56 0 0 56 / 56 38.7s Htbl parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_mpmcq.exe)
random seed: 19337157
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mpmcq sequential
[ ] 0 0 0 0 / 32 0.0s Mpmcq sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Mpmcq sequential
[ ] 0 0 0 0 / 32 0.0s Mpmcq parallel
[ ] 1 0 0 1 / 32 0.5s Mpmcq parallel
[ ] 2 0 0 2 / 32 1.3s Mpmcq parallel
[ ] 3 0 0 3 / 32 2.0s Mpmcq parallel
[ ] 4 0 0 4 / 32 2.5s Mpmcq parallel
[ ] 5 0 0 5 / 32 2.9s Mpmcq parallel
[ ] 6 0 0 6 / 32 3.5s Mpmcq parallel
[ ] 7 0 0 7 / 32 4.1s Mpmcq parallel
[ ] 8 0 0 8 / 32 6.6s Mpmcq parallel
[ ] 9 0 0 9 / 32 8.1s Mpmcq parallel
[ ] 10 0 0 10 / 32 8.2s Mpmcq parallel
[ ] 11 0 0 11 / 32 8.5s Mpmcq parallel
[ ] 12 0 0 12 / 32 8.9s Mpmcq parallel
[ ] 13 0 0 13 / 32 10.6s Mpmcq parallel
[ ] 14 0 0 14 / 32 11.0s Mpmcq parallel
[ ] 15 0 0 15 / 32 11.3s Mpmcq parallel
[ ] 16 0 0 16 / 32 11.7s Mpmcq parallel
[ ] 17 0 0 17 / 32 11.9s Mpmcq parallel
[ ] 19 0 0 19 / 32 12.3s Mpmcq parallel
[ ] 20 0 0 20 / 32 12.5s Mpmcq parallel
[ ] 21 0 0 21 / 32 12.7s Mpmcq parallel
[ ] 23 0 0 23 / 32 18.2s Mpmcq parallel
[ ] 26 0 0 26 / 32 18.9s Mpmcq parallel
[ ] 27 0 0 27 / 32 19.1s Mpmcq parallel
[ ] 31 0 0 31 / 32 20.5s Mpmcq parallel
[ ] 32 0 0 32 / 32 21.8s Mpmcq parallel
[✓] 32 0 0 32 / 32 21.8s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 1057786396
generated error fail pass / total time test name
[ ] 0 0 0 0 / 56 0.0s Mpmcq sequential
[✓] 56 0 0 56 / 56 0.0s Mpmcq sequential
[ ] 0 0 0 0 / 56 0.0s Mpmcq parallel
[ ] 3 0 0 3 / 56 0.7s Mpmcq parallel
[ ] 4 0 0 4 / 56 1.7s Mpmcq parallel
[ ] 9 0 0 9 / 56 1.8s Mpmcq parallel
[ ] 10 0 0 10 / 56 2.0s Mpmcq parallel
[ ] 12 0 0 12 / 56 2.1s Mpmcq parallel
[ ] 22 0 0 22 / 56 2.2s Mpmcq parallel
[ ] 25 0 0 25 / 56 3.5s Mpmcq parallel
[ ] 31 0 0 31 / 56 4.1s Mpmcq parallel
[ ] 32 0 0 32 / 56 5.3s Mpmcq parallel
[ ] 36 0 0 36 / 56 9.2s Mpmcq parallel
[ ] 37 0 0 37 / 56 9.3s Mpmcq parallel
[ ] 38 0 0 38 / 56 9.8s Mpmcq parallel
[ ] 42 0 0 42 / 56 13.0s Mpmcq parallel
[ ] 43 0 0 43 / 56 15.2s Mpmcq parallel
[ ] 47 0 0 47 / 56 15.3s Mpmcq parallel
[ ] 48 0 0 48 / 56 15.8s Mpmcq parallel
[ ] 54 0 0 54 / 56 16.3s Mpmcq parallel
[✓] 56 0 0 56 / 56 16.3s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 718295290
generated error fail pass / total time test name
[ ] 0 0 0 0 / 50 0.0s Mpmcq sequential
[✓] 50 0 0 50 / 50 0.0s Mpmcq sequential
[ ] 0 0 0 0 / 50 0.0s Mpmcq parallel
[ ] 9 0 0 9 / 50 0.1s Mpmcq parallel
[ ] 13 0 0 13 / 50 0.2s Mpmcq parallel
[ ] 21 0 0 21 / 50 1.4s Mpmcq parallel
[ ] 25 0 0 25 / 50 2.9s Mpmcq parallel
[ ] 29 0 0 29 / 50 4.5s Mpmcq parallel
[ ] 35 0 0 35 / 50 4.7s Mpmcq parallel
[ ] 36 0 0 36 / 50 5.8s Mpmcq parallel
[ ] 41 0 0 41 / 50 9.4s Mpmcq parallel
[ ] 43 0 0 43 / 50 11.2s Mpmcq parallel
[ ] 46 0 0 46 / 50 11.3s Mpmcq parallel
[ ] 48 0 0 48 / 50 14.9s Mpmcq parallel
[ ] 50 0 0 50 / 50 15.2s Mpmcq parallel
[✓] 50 0 0 50 / 50 15.2s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 644178574
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mpmcq sequential
[✓] 32 0 0 32 / 32 0.0s Mpmcq sequential
[ ] 0 0 0 0 / 32 0.0s Mpmcq parallel
[ ] 13 0 0 13 / 32 0.4s Mpmcq parallel
[ ] 14 0 0 14 / 32 1.3s Mpmcq parallel
[ ] 16 0 0 16 / 32 1.5s Mpmcq parallel
[ ] 22 0 0 22 / 32 1.7s Mpmcq parallel
[ ] 26 0 0 26 / 32 1.8s Mpmcq parallel
[ ] 32 0 0 32 / 32 1.9s Mpmcq parallel
[✓] 32 0 0 32 / 32 1.9s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 861116935
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mpmcq sequential
[✓] 32 0 0 32 / 32 0.0s Mpmcq sequential
[ ] 0 0 0 0 / 32 0.0s Mpmcq parallel
[ ] 5 0 0 5 / 32 0.2s Mpmcq parallel
[ ] 12 0 0 12 / 32 3.8s Mpmcq parallel
[ ] 13 0 0 13 / 32 5.8s Mpmcq parallel
[ ] 16 0 0 16 / 32 5.9s Mpmcq parallel
[ ] 22 0 0 22 / 32 7.0s Mpmcq parallel
[ ] 25 0 0 25 / 32 7.1s Mpmcq parallel
[ ] 28 0 0 28 / 32 7.3s Mpmcq parallel
[ ] 30 0 0 30 / 32 7.8s Mpmcq parallel
[✓] 32 0 0 32 / 32 7.9s Mpmcq parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_mpscq.exe)
random seed: 588050840
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mpscq sequential
[ ] 0 0 0 0 / 32 0.0s Mpscq sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Mpscq sequential
[ ] 0 0 0 0 / 32 0.0s Mpscq parallel
[ ] 1 0 0 1 / 32 1.0s Mpscq parallel
[ ] 2 0 0 2 / 32 2.0s Mpscq parallel
[ ] 3 0 0 3 / 32 3.2s Mpscq parallel
[ ] 4 0 0 4 / 32 10.9s Mpscq parallel
[ ] 6 0 0 6 / 32 11.4s Mpscq parallel
[ ] 7 0 0 7 / 32 11.9s Mpscq parallel
[ ] 9 0 0 9 / 32 12.1s Mpscq parallel
[ ] 10 0 0 10 / 32 13.1s Mpscq parallel
[ ] 11 0 0 11 / 32 14.7s Mpscq parallel
[ ] 12 0 0 12 / 32 16.3s Mpscq parallel
[ ] 13 0 0 13 / 32 18.2s Mpscq parallel
[ ] 16 0 0 16 / 32 20.2s Mpscq parallel
[ ] 19 0 0 19 / 32 20.3s Mpscq parallel
[ ] 20 0 0 20 / 32 22.5s Mpscq parallel
[ ] 21 0 0 21 / 32 22.8s Mpscq parallel
[ ] 22 0 0 22 / 32 23.8s Mpscq parallel
[ ] 24 0 0 24 / 32 24.4s Mpscq parallel
[ ] 25 0 0 25 / 32 30.2s Mpscq parallel
[ ] 27 0 0 27 / 32 30.3s Mpscq parallel
[ ] 31 0 0 31 / 32 30.6s Mpscq parallel
[ ] 32 0 0 32 / 32 32.5s Mpscq parallel
[✓] 32 0 0 32 / 32 32.5s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 215383142
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mpscq sequential
[✓] 32 0 0 32 / 32 0.0s Mpscq sequential
[ ] 0 0 0 0 / 32 0.0s Mpscq parallel
[ ] 7 0 0 7 / 32 0.2s Mpscq parallel
[ ] 9 0 0 9 / 32 1.1s Mpscq parallel
[ ] 10 0 0 10 / 32 2.1s Mpscq parallel
[ ] 11 0 0 11 / 32 2.2s Mpscq parallel
[ ] 15 0 0 15 / 32 5.9s Mpscq parallel
[ ] 17 0 0 17 / 32 6.1s Mpscq parallel
[ ] 18 0 0 18 / 32 7.7s Mpscq parallel
[ ] 24 0 0 24 / 32 8.9s Mpscq parallel
[ ] 27 0 0 27 / 32 9.7s Mpscq parallel
[ ] 28 0 0 28 / 32 13.3s Mpscq parallel
[✓] 32 0 0 32 / 32 13.4s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 899602319
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mpscq sequential
[✓] 32 0 0 32 / 32 0.0s Mpscq sequential
[ ] 0 0 0 0 / 32 0.0s Mpscq parallel
[ ] 1 0 0 1 / 32 0.0s Mpscq parallel
[ ] 5 0 0 5 / 32 0.1s Mpscq parallel
[ ] 7 0 0 7 / 32 2.3s Mpscq parallel
[ ] 10 0 0 10 / 32 2.5s Mpscq parallel
[ ] 15 0 0 15 / 32 4.8s Mpscq parallel
[ ] 16 0 0 16 / 32 4.9s Mpscq parallel
[ ] 20 0 0 20 / 32 5.3s Mpscq parallel
[ ] 22 0 0 22 / 32 5.4s Mpscq parallel
[ ] 25 0 0 25 / 32 5.9s Mpscq parallel
[ ] 26 0 0 26 / 32 6.0s Mpscq parallel
[ ] 27 0 0 27 / 32 7.1s Mpscq parallel
[ ] 29 0 0 29 / 32 7.4s Mpscq parallel
[ ] 32 0 0 32 / 32 7.6s Mpscq parallel
[✓] 32 0 0 32 / 32 7.6s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 92179267
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mpscq sequential
[✓] 32 0 0 32 / 32 0.0s Mpscq sequential
[ ] 0 0 0 0 / 32 0.0s Mpscq parallel
[ ] 3 0 0 3 / 32 0.2s Mpscq parallel
[ ] 5 0 0 5 / 32 0.3s Mpscq parallel
[ ] 13 0 0 13 / 32 0.7s Mpscq parallel
[ ] 15 0 0 15 / 32 1.2s Mpscq parallel
[ ] 18 0 0 18 / 32 2.9s Mpscq parallel
[ ] 20 0 0 20 / 32 7.9s Mpscq parallel
[ ] 21 0 0 21 / 32 8.1s Mpscq parallel
[ ] 23 0 0 23 / 32 8.2s Mpscq parallel
[ ] 24 0 0 24 / 32 8.5s Mpscq parallel
[ ] 32 0 0 32 / 32 8.6s Mpscq parallel
[✓] 32 0 0 32 / 32 8.6s Mpscq parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_sem.exe)
random seed: 761607297
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Sem sequential
[ ] 0 0 0 0 / 32 0.0s Sem sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Sem sequential
[ ] 0 0 0 0 / 32 0.0s Sem parallel
[ ] 1 0 0 1 / 32 5.5s Sem parallel
[ ] 2 0 0 2 / 32 5.9s Sem parallel
[ ] 3 0 0 3 / 32 6.5s Sem parallel
[ ] 4 0 0 4 / 32 6.8s Sem parallel
[ ] 5 0 0 5 / 32 7.1s Sem parallel
[ ] 6 0 0 6 / 32 7.4s Sem parallel
[ ] 7 0 0 7 / 32 7.6s Sem parallel
[ ] 8 0 0 8 / 32 7.9s Sem parallel
[ ] 9 0 0 9 / 32 13.0s Sem parallel
[ ] 14 0 0 14 / 32 14.1s Sem parallel
[ ] 16 0 0 16 / 32 14.3s Sem parallel
[ ] 20 0 0 20 / 32 14.4s Sem parallel
[ ] 23 0 0 23 / 32 14.5s Sem parallel
[ ] 24 0 0 24 / 32 14.7s Sem parallel
[ ] 25 0 0 25 / 32 14.8s Sem parallel
[ ] 27 0 0 27 / 32 15.0s Sem parallel
[ ] 29 0 0 29 / 32 15.2s Sem parallel
[✓] 32 0 0 32 / 32 15.2s Sem parallel
================================================================================
success (ran 2 tests)
random seed: 170974906
generated error fail pass / total time test name
[ ] 0 0 0 0 / 64 0.0s Sem sequential
[✓] 64 0 0 64 / 64 0.0s Sem sequential
[ ] 0 0 0 0 / 64 0.0s Sem parallel
[ ] 1 0 0 1 / 64 1.1s Sem parallel
[ ] 2 0 0 2 / 64 1.3s Sem parallel
[ ] 3 0 0 3 / 64 5.3s Sem parallel
[ ] 5 0 0 5 / 64 5.6s Sem parallel
[ ] 6 0 0 6 / 64 6.5s Sem parallel
[ ] 8 0 0 8 / 64 10.1s Sem parallel
[ ] 9 0 0 9 / 64 10.4s Sem parallel
[ ] 11 0 0 11 / 64 13.3s Sem parallel
[ ] 12 0 0 12 / 64 16.2s Sem parallel
[ ] 19 0 0 19 / 64 16.4s Sem parallel
[ ] 20 0 0 20 / 64 16.7s Sem parallel
[ ] 25 0 0 25 / 64 16.8s Sem parallel
[ ] 34 0 0 34 / 64 16.9s Sem parallel
[ ] 38 0 0 38 / 64 17.8s Sem parallel
[ ] 39 0 0 39 / 64 19.2s Sem parallel
[ ] 48 0 0 48 / 64 19.3s Sem parallel
[ ] 54 0 0 54 / 64 20.1s Sem parallel
[ ] 57 0 0 57 / 64 23.0s Sem parallel
[ ] 58 0 0 58 / 64 23.2s Sem parallel
[ ] 60 0 0 60 / 64 24.7s Sem parallel
[✓] 64 0 0 64 / 64 24.7s Sem parallel
================================================================================
success (ran 2 tests)
random seed: 655894680
generated error fail pass / total time test name
[ ] 0 0 0 0 / 48 0.0s Sem sequential
[✓] 48 0 0 48 / 48 0.0s Sem sequential
[ ] 0 0 0 0 / 48 0.0s Sem parallel
[ ] 3 0 0 3 / 48 0.1s Sem parallel
[ ] 7 0 0 7 / 48 0.4s Sem parallel
[ ] 9 0 0 9 / 48 1.9s Sem parallel
[ ] 14 0 0 14 / 48 2.2s Sem parallel
[ ] 19 0 0 19 / 48 3.6s Sem parallel
[ ] 22 0 0 22 / 48 6.6s Sem parallel
[ ] 25 0 0 25 / 48 6.7s Sem parallel
[ ] 26 0 0 26 / 48 8.2s Sem parallel
[ ] 29 0 0 29 / 48 9.7s Sem parallel
[ ] 32 0 0 32 / 48 11.1s Sem parallel
[ ] 44 0 0 44 / 48 11.5s Sem parallel
[ ] 48 0 0 48 / 48 14.6s Sem parallel
[✓] 48 0 0 48 / 48 14.6s Sem parallel
================================================================================
success (ran 2 tests)
random seed: 598078759
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Sem sequential
[✓] 32 0 0 32 / 32 0.0s Sem sequential
[ ] 0 0 0 0 / 32 0.0s Sem parallel
[ ] 7 0 0 7 / 32 0.1s Sem parallel
[ ] 11 0 0 11 / 32 3.3s Sem parallel
[ ] 15 0 0 15 / 32 6.2s Sem parallel
[ ] 18 0 0 18 / 32 6.9s Sem parallel
[ ] 19 0 0 19 / 32 7.1s Sem parallel
[ ] 20 0 0 20 / 32 7.5s Sem parallel
[ ] 28 0 0 28 / 32 7.7s Sem parallel
[ ] 31 0 0 31 / 32 7.8s Sem parallel
[✓] 32 0 0 32 / 32 7.8s Sem parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_lock.exe)
random seed: 217413370
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Lock sequential
[ ] 0 0 0 0 / 32 0.0s Lock sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Lock sequential
[ ] 0 0 0 0 / 32 0.0s Lock parallel
[ ] 1 0 0 1 / 32 1.0s Lock parallel
[ ] 2 0 0 2 / 32 1.6s Lock parallel
[ ] 3 0 0 3 / 32 2.5s Lock parallel
[ ] 4 0 0 4 / 32 2.9s Lock parallel
[ ] 5 0 0 5 / 32 3.6s Lock parallel
[ ] 6 0 0 6 / 32 4.3s Lock parallel
[ ] 7 0 0 7 / 32 4.8s Lock parallel
[ ] 8 0 0 8 / 32 9.6s Lock parallel
[ ] 9 0 0 9 / 32 10.3s Lock parallel
[ ] 10 0 0 10 / 32 10.7s Lock parallel
[ ] 11 0 0 11 / 32 12.0s Lock parallel
[ ] 12 0 0 12 / 32 12.3s Lock parallel
[ ] 14 0 0 14 / 32 12.5s Lock parallel
[ ] 15 0 0 15 / 32 16.4s Lock parallel
[ ] 20 0 0 20 / 32 18.8s Lock parallel
[ ] 22 0 0 22 / 32 19.0s Lock parallel
[ ] 23 0 0 23 / 32 19.9s Lock parallel
[ ] 27 0 0 27 / 32 20.0s Lock parallel
[ ] 29 0 0 29 / 32 20.4s Lock parallel
[✓] 32 0 0 32 / 32 20.4s Lock parallel
================================================================================
success (ran 2 tests)
random seed: 150367713
generated error fail pass / total time test name
[ ] 0 0 0 0 / 61 0.0s Lock sequential
[✓] 61 0 0 61 / 61 0.0s Lock sequential
[ ] 0 0 0 0 / 61 0.0s Lock parallel
[ ] 3 0 0 3 / 61 0.9s Lock parallel
[ ] 4 0 0 4 / 61 1.3s Lock parallel
[ ] 7 0 0 7 / 61 3.1s Lock parallel
[ ] 11 0 0 11 / 61 3.2s Lock parallel
[ ] 17 0 0 17 / 61 4.3s Lock parallel
[ ] 18 0 0 18 / 61 7.5s Lock parallel
[ ] 21 0 0 21 / 61 9.2s Lock parallel
[ ] 23 0 0 23 / 61 12.2s Lock parallel
[ ] 24 0 0 24 / 61 15.2s Lock parallel
[ ] 30 0 0 30 / 61 15.7s Lock parallel
[ ] 35 0 0 35 / 61 15.9s Lock parallel
[ ] 36 0 0 36 / 61 16.8s Lock parallel
[ ] 42 0 0 42 / 61 16.9s Lock parallel
[ ] 47 0 0 47 / 61 20.0s Lock parallel
[ ] 48 0 0 48 / 61 20.1s Lock parallel
[ ] 49 0 0 49 / 61 20.5s Lock parallel
[ ] 53 0 0 53 / 61 21.4s Lock parallel
[ ] 54 0 0 54 / 61 21.8s Lock parallel
[ ] 55 0 0 55 / 61 21.9s Lock parallel
[ ] 57 0 0 57 / 61 22.0s Lock parallel
[ ] 58 0 0 58 / 61 22.4s Lock parallel
[✓] 61 0 0 61 / 61 22.4s Lock parallel
================================================================================
success (ran 2 tests)
random seed: 190484538
generated error fail pass / total time test name
[ ] 0 0 0 0 / 37 0.0s Lock sequential
[✓] 37 0 0 37 / 37 0.0s Lock sequential
[ ] 0 0 0 0 / 37 0.0s Lock parallel
[ ] 1 0 0 1 / 37 2.9s Lock parallel
[ ] 2 0 0 2 / 37 6.1s Lock parallel
[ ] 3 0 0 3 / 37 6.3s Lock parallel
[ ] 13 0 0 13 / 37 9.1s Lock parallel
[ ] 18 0 0 18 / 37 11.7s Lock parallel
[ ] 20 0 0 20 / 37 14.5s Lock parallel
[ ] 22 0 0 22 / 37 17.6s Lock parallel
[ ] 23 0 0 23 / 37 18.0s Lock parallel
[ ] 27 0 0 27 / 37 18.3s Lock parallel
[ ] 28 0 0 28 / 37 18.7s Lock parallel
[ ] 29 0 0 29 / 37 19.1s Lock parallel
[ ] 31 0 0 31 / 37 19.3s Lock parallel
[ ] 36 0 0 36 / 37 20.0s Lock parallel
[ ] 37 0 0 37 / 37 20.4s Lock parallel
[✓] 37 0 0 37 / 37 20.4s Lock parallel
================================================================================
success (ran 2 tests)
(cd _build/default/bench && ./main.exe -brief Picos_std_structured.Run)
Picos_std_structured.Run:
ignores over time/1 mfifo, run_n 100:
1.17 M/s
ignores over time/1 mfifo, run_n 1000:
4.73 M/s
ignores over time/1 mfifo, run_n 10000:
8.74 M/s
ignores over time/1 mfifo, run_n 100000:
10.02 M/s
ignores over time/1 mfifo, run_n 1000000:
10.21 M/s
ignores over time/1 mfifo, run_n 10000000:
10.24 M/s
ignores over time/2 mfifos, run_n 100:
1.13 M/s
ignores over time/2 mfifos, run_n 1000:
5.87 M/s
ignores over time/2 mfifos, run_n 10000:
15.16 M/s
ignores over time/2 mfifos, run_n 100000:
19.60 M/s
ignores over time/2 mfifos, run_n 1000000:
20.37 M/s
ignores over time/2 mfifos, run_n 10000000:
20.48 M/s
ignores over time/4 mfifos, run_n 100:
0.97 M/s
ignores over time/4 mfifos, run_n 1000:
6.39 M/s
ignores over time/4 mfifos, run_n 10000:
23.24 M/s
ignores over time/4 mfifos, run_n 100000:
34.70 M/s
ignores over time/4 mfifos, run_n 1000000:
36.14 M/s
ignores over time/4 mfifos, run_n 10000000:
36.48 M/s
ignores over time/8 mfifos, run_n 100:
0.57 M/s
ignores over time/8 mfifos, run_n 1000:
4.52 M/s
ignores over time/8 mfifos, run_n 10000:
22.31 M/s
ignores over time/8 mfifos, run_n 100000:
57.38 M/s
ignores over time/8 mfifos, run_n 1000000:
67.79 M/s
ignores over time/8 mfifos, run_n 10000000:
67.22 M/s
time per ignore/1 mfifo, run_n 100:
854.89 ns
time per ignore/1 mfifo, run_n 1000:
211.47 ns
time per ignore/1 mfifo, run_n 10000:
114.37 ns
time per ignore/1 mfifo, run_n 100000:
99.78 ns
time per ignore/1 mfifo, run_n 1000000:
97.92 ns
time per ignore/1 mfifo, run_n 10000000:
97.64 ns
time per ignore/2 mfifos, run_n 100:
1765.63 ns
time per ignore/2 mfifos, run_n 1000:
340.58 ns
time per ignore/2 mfifos, run_n 10000:
131.91 ns
time per ignore/2 mfifos, run_n 100000:
102.05 ns
time per ignore/2 mfifos, run_n 1000000:
98.18 ns
time per ignore/2 mfifos, run_n 10000000:
97.66 ns
time per ignore/4 mfifos, run_n 100:
4136.69 ns
time per ignore/4 mfifos, run_n 1000:
626.31 ns
time per ignore/4 mfifos, run_n 10000:
172.11 ns
time per ignore/4 mfifos, run_n 100000:
115.29 ns
time per ignore/4 mfifos, run_n 1000000:
110.69 ns
time per ignore/4 mfifos, run_n 10000000:
109.65 ns
time per ignore/8 mfifos, run_n 100:
14116.69 ns
time per ignore/8 mfifos, run_n 1000:
1770.24 ns
time per ignore/8 mfifos, run_n 10000:
358.66 ns
time per ignore/8 mfifos, run_n 100000:
139.43 ns
time per ignore/8 mfifos, run_n 1000000:
118.01 ns
time per ignore/8 mfifos, run_n 10000000:
119.02 ns
(cd _build/default/test && ./test_rwlock.exe)
random seed: 168392629
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Rwlock sequential
[ ] 0 0 0 0 / 32 0.0s Rwlock sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Rwlock sequential
[ ] 0 0 0 0 / 32 0.0s Rwlock parallel
[ ] 1 0 0 1 / 32 1.2s Rwlock parallel
[ ] 2 0 0 2 / 32 4.2s Rwlock parallel
[ ] 3 0 0 3 / 32 4.8s Rwlock parallel
[ ] 4 0 0 4 / 32 5.3s Rwlock parallel
[ ] 5 0 0 5 / 32 5.8s Rwlock parallel
[ ] 6 0 0 6 / 32 6.4s Rwlock parallel
[ ] 7 0 0 7 / 32 7.0s Rwlock parallel
[ ] 8 0 0 8 / 32 7.1s Rwlock parallel
[ ] 10 0 0 10 / 32 7.3s Rwlock parallel
[ ] 11 0 0 11 / 32 7.6s Rwlock parallel
[ ] 12 0 0 12 / 32 7.8s Rwlock parallel
[ ] 14 0 0 14 / 32 7.9s Rwlock parallel
[ ] 15 0 0 15 / 32 8.0s Rwlock parallel
[ ] 16 0 0 16 / 32 8.2s Rwlock parallel
[ ] 17 0 0 17 / 32 10.7s Rwlock parallel
[ ] 18 0 0 18 / 32 11.0s Rwlock parallel
[ ] 19 0 0 19 / 32 11.5s Rwlock parallel
[ ] 20 0 0 20 / 32 11.8s Rwlock parallel
[ ] 21 0 0 21 / 32 16.2s Rwlock parallel
[ ] 22 0 0 22 / 32 16.3s Rwlock parallel
[ ] 25 0 0 25 / 32 17.0s Rwlock parallel
[ ] 26 0 0 26 / 32 19.1s Rwlock parallel
[ ] 27 0 0 27 / 32 19.3s Rwlock parallel
[ ] 28 0 0 28 / 32 19.5s Rwlock parallel
[✓] 32 0 0 32 / 32 19.5s Rwlock parallel
================================================================================
success (ran 2 tests)
random seed: 396295061
generated error fail pass / total time test name
[ ] 0 0 0 0 / 64 0.0s Rwlock sequential
[✓] 64 0 0 64 / 64 0.0s Rwlock sequential
[ ] 0 0 0 0 / 64 0.0s Rwlock parallel
[ ] 1 0 0 1 / 64 0.0s Rwlock parallel
[ ] 2 0 0 2 / 64 4.1s Rwlock parallel
[ ] 4 0 0 4 / 64 4.4s Rwlock parallel
[ ] 9 0 0 9 / 64 4.7s Rwlock parallel
[ ] 10 0 0 10 / 64 5.0s Rwlock parallel
[ ] 15 0 0 15 / 64 5.5s Rwlock parallel
[ ] 19 0 0 19 / 64 8.8s Rwlock parallel
[ ] 21 0 0 21 / 64 9.3s Rwlock parallel
[ ] 23 0 0 23 / 64 9.8s Rwlock parallel
[ ] 30 0 0 30 / 64 9.9s Rwlock parallel
[ ] 35 0 0 35 / 64 11.8s Rwlock parallel
[ ] 39 0 0 39 / 64 13.3s Rwlock parallel
[ ] 46 0 0 46 / 64 15.2s Rwlock parallel
[ ] 48 0 0 48 / 64 15.7s Rwlock parallel
[ ] 49 0 0 49 / 64 17.1s Rwlock parallel
[ ] 51 0 0 51 / 64 18.7s Rwlock parallel
[ ] 53 0 0 53 / 64 18.9s Rwlock parallel
[ ] 54 0 0 54 / 64 19.1s Rwlock parallel
[ ] 59 0 0 59 / 64 19.3s Rwlock parallel
[ ] 60 0 0 60 / 64 22.3s Rwlock parallel
[ ] 63 0 0 63 / 64 23.8s Rwlock parallel
[✓] 64 0 0 64 / 64 23.9s Rwlock parallel
================================================================================
success (ran 2 tests)
random seed: 516402848
generated error fail pass / total time test name
[ ] 0 0 0 0 / 36 0.0s Rwlock sequential
[✓] 36 0 0 36 / 36 0.0s Rwlock sequential
[ ] 0 0 0 0 / 36 0.0s Rwlock parallel
[ ] 1 0 0 1 / 36 3.0s Rwlock parallel
[ ] 2 0 0 2 / 36 3.1s Rwlock parallel
[ ] 3 0 0 3 / 36 5.8s Rwlock parallel
[ ] 5 0 0 5 / 36 7.4s Rwlock parallel
[ ] 7 0 0 7 / 36 7.8s Rwlock parallel
[ ] 8 0 0 8 / 36 8.6s Rwlock parallel
[ ] 11 0 0 11 / 36 11.3s Rwlock parallel
[ ] 12 0 0 12 / 36 12.0s Rwlock parallel
[ ] 16 0 0 16 / 36 13.5s Rwlock parallel
[ ] 19 0 0 19 / 36 13.6s Rwlock parallel
[ ] 20 0 0 20 / 36 16.9s Rwlock parallel
[ ] 21 0 0 21 / 36 18.4s Rwlock parallel
[ ] 23 0 0 23 / 36 18.6s Rwlock parallel
[ ] 24 0 0 24 / 36 20.2s Rwlock parallel
[ ] 25 0 0 25 / 36 20.4s Rwlock parallel
[ ] 27 0 0 27 / 36 22.0s Rwlock parallel
[ ] 32 0 0 32 / 36 22.1s Rwlock parallel
[ ] 33 0 0 33 / 36 22.3s Rwlock parallel
[ ] 34 0 0 34 / 36 24.9s Rwlock parallel
[✓] 36 0 0 36 / 36 24.9s Rwlock parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_mutex.exe)
random seed: 220324542
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mutex sequential
[ ] 0 0 0 0 / 32 0.0s Mutex sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Mutex sequential
[ ] 0 0 0 0 / 32 0.0s Mutex parallel
[ ] 1 0 0 1 / 32 0.8s Mutex parallel
[ ] 2 0 0 2 / 32 2.5s Mutex parallel
[ ] 3 0 0 3 / 32 4.0s Mutex parallel
[ ] 4 0 0 4 / 32 4.6s Mutex parallel
[ ] 5 0 0 5 / 32 5.1s Mutex parallel
[ ] 6 0 0 6 / 32 5.4s Mutex parallel
[ ] 7 0 0 7 / 32 6.0s Mutex parallel
[ ] 8 0 0 8 / 32 6.5s Mutex parallel
[ ] 9 0 0 9 / 32 6.8s Mutex parallel
[ ] 10 0 0 10 / 32 7.1s Mutex parallel
[ ] 11 0 0 11 / 32 9.3s Mutex parallel
[ ] 12 0 0 12 / 32 11.8s Mutex parallel
[ ] 13 0 0 13 / 32 12.0s Mutex parallel
[ ] 14 0 0 14 / 32 12.2s Mutex parallel
[ ] 15 0 0 15 / 32 12.4s Mutex parallel
[ ] 16 0 0 16 / 32 12.6s Mutex parallel
[ ] 17 0 0 17 / 32 12.7s Mutex parallel
[ ] 19 0 0 19 / 32 12.8s Mutex parallel
[ ] 20 0 0 20 / 32 13.0s Mutex parallel
[ ] 22 0 0 22 / 32 13.2s Mutex parallel
[ ] 23 0 0 23 / 32 13.3s Mutex parallel
[ ] 25 0 0 25 / 32 13.5s Mutex parallel
[ ] 27 0 0 27 / 32 13.9s Mutex parallel
[ ] 32 0 0 32 / 32 14.1s Mutex parallel
[✓] 32 0 0 32 / 32 14.1s Mutex parallel
================================================================================
success (ran 2 tests)
random seed: 925702109
generated error fail pass / total time test name
[ ] 0 0 0 0 / 64 0.0s Mutex sequential
[✓] 64 0 0 64 / 64 0.0s Mutex sequential
[ ] 0 0 0 0 / 64 0.0s Mutex parallel
[ ] 2 0 0 2 / 64 2.0s Mutex parallel
[ ] 7 0 0 7 / 64 2.1s Mutex parallel
[ ] 9 0 0 9 / 64 6.2s Mutex parallel
[ ] 10 0 0 10 / 64 6.4s Mutex parallel
[ ] 13 0 0 13 / 64 9.7s Mutex parallel
[ ] 14 0 0 14 / 64 9.8s Mutex parallel
[ ] 17 0 0 17 / 64 11.8s Mutex parallel
[ ] 19 0 0 19 / 64 11.9s Mutex parallel
[ ] 21 0 0 21 / 64 13.6s Mutex parallel
[ ] 26 0 0 26 / 64 13.9s Mutex parallel
[ ] 28 0 0 28 / 64 16.8s Mutex parallel
[ ] 31 0 0 31 / 64 17.6s Mutex parallel
[ ] 34 0 0 34 / 64 18.5s Mutex parallel
[ ] 36 0 0 36 / 64 20.1s Mutex parallel
[ ] 37 0 0 37 / 64 20.4s Mutex parallel
[ ] 43 0 0 43 / 64 20.5s Mutex parallel
[ ] 44 0 0 44 / 64 20.6s Mutex parallel
[ ] 49 0 0 49 / 64 21.4s Mutex parallel
[ ] 54 0 0 54 / 64 21.6s Mutex parallel
[ ] 58 0 0 58 / 64 23.1s Mutex parallel
[ ] 60 0 0 60 / 64 23.9s Mutex parallel
[✓] 64 0 0 64 / 64 24.0s Mutex parallel
================================================================================
success (ran 2 tests)
random seed: 511947027
generated error fail pass / total time test name
[ ] 0 0 0 0 / 55 0.0s Mutex sequential
[✓] 55 0 0 55 / 55 0.0s Mutex sequential
[ ] 0 0 0 0 / 55 0.0s Mutex parallel
[ ] 3 0 0 3 / 55 0.2s Mutex parallel
[ ] 7 0 0 7 / 55 0.5s Mutex parallel
[ ] 9 0 0 9 / 55 1.3s Mutex parallel
[ ] 11 0 0 11 / 55 1.4s Mutex parallel
[ ] 13 0 0 13 / 55 1.6s Mutex parallel
[ ] 14 0 0 14 / 55 2.4s Mutex parallel
[ ] 15 0 0 15 / 55 3.2s Mutex parallel
[ ] 17 0 0 17 / 55 3.4s Mutex parallel
[ ] 27 0 0 27 / 55 3.7s Mutex parallel
[ ] 28 0 0 28 / 55 5.1s Mutex parallel
[ ] 29 0 0 29 / 55 5.4s Mutex parallel
[ ] 30 0 0 30 / 55 8.3s Mutex parallel
[ ] 31 0 0 31 / 55 8.5s Mutex parallel
[ ] 38 0 0 38 / 55 8.7s Mutex parallel
[ ] 40 0 0 40 / 55 10.2s Mutex parallel
[ ] 43 0 0 43 / 55 10.6s Mutex parallel
[ ] 46 0 0 46 / 55 10.7s Mutex parallel
[ ] 52 0 0 52 / 55 11.2s Mutex parallel
[ ] 53 0 0 53 / 55 11.6s Mutex parallel
[ ] 54 0 0 54 / 55 13.1s Mutex parallel
[✓] 55 0 0 55 / 55 13.1s Mutex parallel
================================================================================
success (ran 2 tests)
random seed: 46885371
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mutex sequential
[✓] 32 0 0 32 / 32 0.0s Mutex sequential
[ ] 0 0 0 0 / 32 0.0s Mutex parallel
[ ] 3 0 0 3 / 32 0.4s Mutex parallel
[ ] 4 0 0 4 / 32 1.2s Mutex parallel
[ ] 5 0 0 5 / 32 1.3s Mutex parallel
[ ] 6 0 0 6 / 32 1.4s Mutex parallel
[ ] 7 0 0 7 / 32 2.8s Mutex parallel
[ ] 8 0 0 8 / 32 2.9s Mutex parallel
[ ] 10 0 0 10 / 32 3.6s Mutex parallel
[ ] 12 0 0 12 / 32 6.7s Mutex parallel
[ ] 19 0 0 19 / 32 6.9s Mutex parallel
[ ] 23 0 0 23 / 32 7.3s Mutex parallel
[ ] 26 0 0 26 / 32 7.5s Mutex parallel
[ ] 30 0 0 30 / 32 8.2s Mutex parallel
[ ] 32 0 0 32 / 32 8.4s Mutex parallel
[✓] 32 0 0 32 / 32 8.4s Mutex parallel
================================================================================
success (ran 2 tests)
random seed: 599321905
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mutex sequential
[✓] 32 0 0 32 / 32 0.0s Mutex sequential
[ ] 0 0 0 0 / 32 0.0s Mutex parallel
[ ] 3 0 0 3 / 32 1.5s Mutex parallel
[ ] 6 0 0 6 / 32 2.0s Mutex parallel
[ ] 7 0 0 7 / 32 2.4s Mutex parallel
[ ] 11 0 0 11 / 32 2.7s Mutex parallel
[ ] 16 0 0 16 / 32 4.2s Mutex parallel
[ ] 20 0 0 20 / 32 5.0s Mutex parallel
[ ] 21 0 0 21 / 32 6.3s Mutex parallel
[ ] 23 0 0 23 / 32 6.4s Mutex parallel
[ ] 27 0 0 27 / 32 7.2s Mutex parallel
[ ] 28 0 0 28 / 32 7.6s Mutex parallel
[ ] 29 0 0 29 / 32 9.0s Mutex parallel
[ ] 30 0 0 30 / 32 10.3s Mutex parallel
[✓] 32 0 0 32 / 32 10.4s Mutex parallel
================================================================================
success (ran 2 tests)
2025-05-02 09:07.07: Cancelling: Auto-cancelling job because it is no longer needed
Job cancelled