Build:
- 0
2026-01-21 10:32.50: New job: Build using linux-x86_64 in
[https://github.com/mirage/mirage-skeleton.git#refs/pull/418/head (8382633e9753bcc0d7bccf55fe10a1844a3aa93f)]
OBuilder spec:
((from ocaml/opam:debian-13-ocaml-5.3)
(user (uid 1000) (gid 1000))
(workdir /home/opam)
(run (shell "sudo chown opam:opam /home/opam"))
(run (shell "sudo ln -f /usr/bin/opam-2.4 /usr/bin/opam && opam update"))
(run (network host)
(shell "opam repo add opam https://github.com/ocaml/opam-repository.git#10a02a697b08f6d78a6c4c2cb9a76136afc7776d"))
(run (cache (download-cache (target /home/opam/.opam/download-cache)))
(network host)
(shell "sudo apt-get update && opam install -y \"mirage>=4\""))
(copy (src .) (dst /src/))
(env MODE xen)
(workdir /src/)
(run (shell "opam exec -- make configure"))
(env MIRAGE_EXTRA_REPOS opam-overlays:https://github.com/dune-universe/opam-overlays.git#12731a6f86d7c452a94c72106fa9d3327988582d,mirage-opam-overlays:https://github.com/dune-universe/mirage-opam-overlays.git#eddcd1bc7e035392596b603d23dde67a88e6f6bc)
(run (network host)
(shell "opam exec -- make lock"))
(run (cache (download-cache (target /home/opam/.opam/download-cache)))
(network host)
(shell "sudo apt-get update && opam exec -- make depends"))
(run (shell "opam monorepo list -l mirage.opam.locked"))
(run (cache (download-cache (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam exec -- make pull"))
(env DUNE_CACHE enabled)
(env DUNE_CACHE_TRANSPORT direct)
(run (cache (dune-build-cache (target /home/opam/.cache/dune)))
(network host)
(shell "opam exec -- make build"))
)
2026-01-21 10:32.50: Using cache hint "mirage-ci-skeleton-debian-13-ocaml-5.3"
2026-01-21 10:32.50: Waiting for resource in pool OCluster
2026-01-21 10:32.50: Waiting for worker…
2026-01-21 10:33.45: Got resource from pool OCluster
Building on eumache
All commits already cached
HEAD is now at 8382633 Pass dhcp to resolver_dns
(from ocaml/opam:debian-13-ocaml-5.3)
Unable to find image 'ocaml/opam:debian-13-ocaml-5.3' locally
debian-13-ocaml-5.3: Pulling from ocaml/opam
2ca1bfae7ba8: Already exists
3baeae2ed4cf: Already exists
b254ca288623: Already exists
745976a04e35: Already exists
a516242b2337: Already exists
9bb526cd9631: Already exists
3737e8f76884: Already exists
6a8811ebcb2c: Already exists
386dffb80382: Already exists
e04d691eea35: Already exists
bb72c0d1c3f0: Already exists
3a56fcb872cd: Already exists
5abffa2313de: Already exists
7ed80bc2b055: Already exists
87c92835260d: Already exists
5624e0ee5ca5: Already exists
96e54dc9b357: Already exists
96e54dc9b357: Already exists
7c484d393436: Already exists
16b8d7610542: Already exists
c5ac47ffe6ef: Already exists
00cfb259c8ac: Already exists
4f4fb700ef54: Already exists
4658a16b5264: Already exists
7c82a6a00032: Already exists
b76e2612fc73: Already exists
da0741a07551: Already exists
102a21125d73: Already exists
d244b294335f: Already exists
e47a432b94fb: Already exists
6ee7cce1e23d: Already exists
2475e9cbd3e5: Already exists
4f8aac8ae1e5: Already exists
3e59226f7823: Already exists
6d429b9a6ce7: Already exists
dc8bbbd9edf9: Already exists
66ec5629681d: Already exists
74661ee64965: Already exists
b3088c441ac7: Already exists
11be3e645e01: Already exists
e9a0ff031006: Already exists
02e67148461a: Already exists
8486a827c317: Already exists
eddafbbeb04f: Already exists
aeded2468226: Pulling fs layer
71fec2cb049c: Pulling fs layer
f4e0bcb9515f: Pulling fs layer
d024c0c60c1e: Pulling fs layer
d024c0c60c1e: Waiting
71fec2cb049c: Verifying Checksum
71fec2cb049c: Download complete
f4e0bcb9515f: Verifying Checksum
f4e0bcb9515f: Download complete
d024c0c60c1e: Verifying Checksum
d024c0c60c1e: Download complete
aeded2468226: Retrying in 5 seconds
aeded2468226: Retrying in 4 seconds
aeded2468226: Retrying in 3 seconds
aeded2468226: Retrying in 2 seconds
aeded2468226: Retrying in 1 second
aeded2468226: Verifying Checksum
aeded2468226: Download complete
aeded2468226: Pull complete
71fec2cb049c: Pull complete
f4e0bcb9515f: Pull complete
d024c0c60c1e: Pull complete
Digest: sha256:fd1eb4736db0c792f8ceb9e85641e9762a5f2561151e63515ff00b1b11f8db6f
Status: Downloaded newer image for ocaml/opam:debian-13-ocaml-5.3
2026-01-21 10:34.20 ---> saved as "348716d62ad55d1c2ba7493d00b0882cc64fc042d724a06a1599e8ba58d890e2"
/: (user (uid 1000) (gid 1000))
/: (workdir /home/opam)
/home/opam: (run (shell "sudo chown opam:opam /home/opam"))
2026-01-21 10:34.20 ---> saved as "24883da7c3bfb9b4beffcac7267b86c1389006a753d78f6b386a3c4fd0e70458"
/home/opam: (run (shell "sudo ln -f /usr/bin/opam-2.4 /usr/bin/opam && opam update"))
This 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 package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2026-01-21 10:35.03 ---> saved as "e0d08704d663585a0eeeaa1114187809c41cb285481ac9f5195ea2884586d4b3"
/home/opam: (run (network host)
(shell "opam repo add opam https://github.com/ocaml/opam-repository.git#10a02a697b08f6d78a6c4c2cb9a76136afc7776d"))
[opam] Initialised
[NOTE] Repository opam has been added to the selections of switch 5.3 only.
Run `opam repository add opam --all-switches|--set-default' to use it in all existing switches, or in newly created switches, respectively.
2026-01-21 10:35.26 ---> saved as "e41ee3fa217d4cc2a331556309ec3b45a3450d9393b7d33f502d37bcce066da4"
/home/opam: (run (cache (download-cache (target /home/opam/.opam/download-cache)))
(network host)
(shell "sudo apt-get update && opam install -y \"mirage>=4\""))
Hit:1 http://deb.debian.org/debian trixie InRelease
Get:2 http://deb.debian.org/debian trixie-updates InRelease [47.3 kB]
Get:3 http://deb.debian.org/debian-security trixie-security InRelease [43.4 kB]
Get:4 http://deb.debian.org/debian-security trixie-security/main amd64 Packages [96.3 kB]
Fetched 187 kB in 0s (863 kB/s)
Reading package lists...
The following actions will be performed:
=== install 28 packages
- install angstrom 0.16.1 [required by emile, uri]
- install astring 0.8.5 [required by mirage]
- install base64 3.5.2 [required by emile]
- install bigstringaf 0.10.0 [required by emile]
- install bos 0.2.1 [required by mirage]
- install cmdliner 2.1.0 [required by mirage]
- install conf-pkg-config 4 [required by opam-monorepo]
- install csexp 1.5.2 [required by dune-configurator]
- install domain-name 0.5.0 [required by ipaddr]
- install dune 3.21.0 [required by mirage]
- install dune-configurator 3.21.0 [required by bigstringaf]
- install emile 1.1 [required by mirage]
- install fmt 0.11.0 [required by mirage]
- install fpath 0.7.3 [required by mirage]
- install ipaddr 5.6.1 [required by mirage]
- install logs 0.10.0 [required by mirage]
- install macaddr 5.6.1 [required by ipaddr]
- install mirage 4.10.4
- install ocaml-syntax-shims 1.0.0 [required by angstrom]
- install ocamlbuild 0.16.1 [required by astring, bos]
- install ocamlfind 1.9.8 [required by astring, bos]
- install opam-monorepo 0.4.3 [required by mirage]
- install pecu 0.7 [required by emile]
- install rresult 0.7.0 [required by mirage]
- install stringext 1.6.0 [required by uri]
- install topkg 1.1.1 [required by astring, bos]
- install uri 4.4.0 [required by mirage]
- install uutf 1.0.4 [required by emile]
The following system packages will first need to be installed:
pkg-config
<><> Handling external dependencies <><><><><><><><><><><><><><><><><><><><><><>
opam believes some required external dependencies are missing. opam can:
> 1. Run apt-get to install them (may need root/sudo access)
2. Display the recommended apt-get command and wait while you run it manually (e.g. in another terminal)
3. Continue anyway, and, upon success, permanently register that this external dependency is present, but not detectable
4. Abort the installation
[1/2/3/4] 1
+ /usr/bin/sudo "apt-get" "install" "-qq" "-yy" "pkg-config"
- Selecting previously unselected package libpkgconf3:amd64.
- (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 ... 20654 files and directories currently installed.)
- Preparing to unpack .../libpkgconf3_1.8.1-4_amd64.deb ...
- Unpacking libpkgconf3:amd64 (1.8.1-4) ...
- Selecting previously unselected package pkgconf-bin.
- Preparing to unpack .../pkgconf-bin_1.8.1-4_amd64.deb ...
- Unpacking pkgconf-bin (1.8.1-4) ...
- Selecting previously unselected package pkgconf:amd64.
- Preparing to unpack .../pkgconf_1.8.1-4_amd64.deb ...
- Unpacking pkgconf:amd64 (1.8.1-4) ...
- Selecting previously unselected package pkg-config:amd64.
- Preparing to unpack .../pkg-config_1.8.1-4_amd64.deb ...
- Unpacking pkg-config:amd64 (1.8.1-4) ...
- Setting up libpkgconf3:amd64 (1.8.1-4) ...
- Setting up pkgconf-bin (1.8.1-4) ...
- Setting up pkgconf:amd64 (1.8.1-4) ...
- Setting up pkg-config:amd64 (1.8.1-4) ...
- Processing triggers for libc-bin (2.41-12+deb13u1) ...
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved angstrom.0.16.1 (cached)
-> retrieved astring.0.8.5 (cached)
-> retrieved base64.3.5.2 (cached)
-> retrieved bigstringaf.0.10.0 (cached)
-> retrieved bos.0.2.1 (cached)
-> retrieved csexp.1.5.2 (cached)
-> retrieved cmdliner.2.1.0 (cached)
-> installed conf-pkg-config.4
-> retrieved domain-name.0.5.0 (cached)
-> retrieved emile.1.1 (cached)
-> retrieved fmt.0.11.0 (cached)
-> retrieved fpath.0.7.3 (cached)
-> retrieved ipaddr.5.6.1, macaddr.5.6.1 (cached)
-> retrieved logs.0.10.0 (cached)
-> retrieved ocaml-syntax-shims.1.0.0 (cached)
-> retrieved ocamlbuild.0.16.1 (cached)
-> retrieved mirage.4.10.4 (cached)
-> retrieved ocamlfind.1.9.8 (cached)
-> retrieved pecu.0.7 (cached)
-> retrieved rresult.0.7.0 (cached)
-> retrieved stringext.1.6.0 (cached)
-> retrieved topkg.1.1.1 (cached)
-> retrieved uri.4.4.0 (cached)
-> retrieved uutf.1.0.4 (cached)
-> retrieved dune.3.21.0, dune-configurator.3.21.0 (cached)
-> retrieved opam-monorepo.0.4.3 (cached)
-> installed cmdliner.2.1.0
-> installed ocamlbuild.0.16.1
-> installed ocamlfind.1.9.8
-> installed topkg.1.1.1
-> installed rresult.0.7.0
-> installed uutf.1.0.4
-> installed fmt.0.11.0
-> installed astring.0.8.5
-> installed fpath.0.7.3
-> installed logs.0.10.0
-> installed bos.0.2.1
-> installed dune.3.21.0
-> installed base64.3.5.2
-> installed csexp.1.5.2
-> installed domain-name.0.5.0
-> installed macaddr.5.6.1
-> installed ocaml-syntax-shims.1.0.0
-> installed pecu.0.7
-> installed stringext.1.6.0
-> installed ipaddr.5.6.1
-> installed dune-configurator.3.21.0
-> installed bigstringaf.0.10.0
-> installed angstrom.0.16.1
-> installed emile.1.1
-> installed uri.4.4.0
-> installed opam-monorepo.0.4.3
-> installed mirage.4.10.4
Done.
# To update the current shell environment, run: eval $(opam env)
2026-01-21 10:38.08 ---> saved as "247390ee56825e3e7dc5aaf550af786f7b56a6405c27840a3b74eb09c8cc7423"
/home/opam: (copy (src .) (dst /src/))
2026-01-21 10:38.09 ---> saved as "1e01c581b6d72bf75e949fc02a20cc8750e9165d161b1c2d5f58059c17129ed2"
/home/opam: (env MODE xen)
/home/opam: (workdir /src/)
/src/: (run (shell "opam exec -- make configure"))
mirage configure -f tutorial/noop/config.ml -t xen
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f tutorial/hello/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f tutorial/hello-key/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f tutorial/local-library/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f tutorial/lwt/echo_server/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f tutorial/lwt/heads1/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f tutorial/lwt/heads2/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f tutorial/lwt/timeout1/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f tutorial/lwt/timeout2/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f tutorial/app_info/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f device-usage/clock/config.ml -t xen
adding unit argument to 'start ()' (to delay execution)
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f device-usage/conduit_server/config.ml -t xen
Successfully configured the unikernel. Now run 'make' (or more fine-grained steps: 'make all', 'make depends', or 'make lock').
mirage configure -f device-usage/http-fetch/config.ml -t xen
File "device-usage/http-fetch/config.ml", line 9, characters 22-40:
9 | let dhcp_requests = make_dhcp_requests () in
^^^^^^^^^^^^^^^^^^
Error: Unbound value "make_dhcp_requests"
run ['dune' 'build' 'device-usage/http-fetch/config.exe' '--root' '.'
'--workspace' 'device-usage/http-fetch/mirage/dune-workspace.config']: exited with 1
make: *** [Makefile:60: device-usage/http-fetch-configure] Error 1
"/usr/bin/env" "bash" "-c" "opam exec -- make configure" failed with exit status 2
2026-01-21 10:38.25: Job failed: Failed: Build failed