[00:00:00] =>> Building devel/p5-EV [00:00:00] build started at 2026-04-01T02:36:04+02:00 [00:00:00] port directory: /usr/ports/devel/p5-EV [00:00:00] package name: p5-EV-4.34,1 [00:00:00] building for: FreeBSD pkg.mfl.dk 15.0-RELEASE-p1 FreeBSD 15.0-RELEASE-p1 amd64 [00:00:00] maintained by: vovkasm@gmail.com [00:00:00] port version: 4.34 [00:00:00] port revision: 0 [00:00:00] Makefile datestamp: Mar 28 22:30:30 2026 [00:00:00] Ports top last git commit: c6b0a9699f12f690cc20e84d5f1376ce073b3033 [00:00:00] Ports top unclean checkout: no [00:00:00] =>> Inspecting /usr/local/poudriere/data/.m/150amd64-local/ref//usr/ports/devel/p5-EV for modifications to git checkout... no [00:00:00] Port dir unclean checkout: no [00:00:00] Poudriere version: poudriere-git-3.4.99.20260303 [00:00:00] Host OSVERSION: 1500068 [00:00:00] Jail OSVERSION: 1500068 [00:00:00] Builder Id: 05 [00:00:00] Builder jail path: /usr/local/poudriere/data/.m/150amd64-local/05 [00:00:00] Ref jail path: /usr/local/poudriere/data/.m/150amd64-local/ref [00:00:00] Job Idx: 492 [00:00:00] Jail Id (no networking) : 15 [00:00:00] Jail Name (no networking): 150amd64-local-job-05 [00:00:00] Jail Id (networking) : 16 [00:00:00] Jail Name (networking) : 150amd64-local-job-05-n [00:00:00] [00:00:00] ---Begin Environment--- [00:00:00] SHELL=/bin/sh [00:00:00] OSVERSION=1500068 [00:00:00] UNAME_v=FreeBSD 15.0-RELEASE-p1 [00:00:00] UNAME_r=15.0-RELEASE-p1 [00:00:00] BLOCKSIZE=K [00:00:00] MAIL=/var/mail/root [00:00:00] MM_CHARSET=UTF-8 [00:00:00] LANG=C.UTF-8 [00:00:00] STATUS=1 [00:00:00] HOME=/root [00:00:00] PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin:/root/bin [00:00:00] MAKE_OBJDIR_CHECK_WRITABLE=0 [00:00:00] LOCALBASE=/usr/local [00:00:00] USER=root [00:00:00] POUDRIERE_NAME=poudriere-git [00:00:00] POUDRIERE_VERSION=3.4.99.20260303 [00:00:00] LC_COLLATE=C [00:00:00] POUDRIERE_BUILD_TYPE=bulk [00:00:00] PACKAGE_BUILDING=yes [00:00:00] SAVED_TERM=tmux-256color [00:00:00] OUTPUT_REDIRECTED_STDERR=4 [00:00:00] OUTPUT_REDIRECTED=1 [00:00:00] PWD=/usr/local/poudriere/data/.m/150amd64-local/05/.p [00:00:00] OUTPUT_REDIRECTED_STDOUT=3 [00:00:00] P_PORTS_FEATURES=FLAVORS SUBPACKAGES SELECTED_OPTIONS [00:00:00] MASTERNAME=150amd64-local [00:00:00] OLDPWD=/usr/local/poudriere/data/.m/150amd64-local/ref/.p/pool [00:00:00] POUDRIERE_PKGNAME=poudriere-git-3.4.99.20260303 [00:00:00] PREFIX=/usr/local [00:00:00] POUDRIEREPATH=/usr/local/bin/poudriere [00:00:00] ---End Environment--- [00:00:00] [00:00:00] ---Begin Poudriere Port Flags/Env--- [00:00:00] PORT_FLAGS= [00:00:00] PKGENV= [00:00:00] FLAVOR= [00:00:00] MAKE_ARGS= [00:00:00] ---End Poudriere Port Flags/Env--- [00:00:00] [00:00:00] ---Begin OPTIONS List--- [00:00:00] ---End OPTIONS List--- [00:00:00] [00:00:00] --MAINTAINER-- [00:00:00] vovkasm@gmail.com [00:00:00] --End MAINTAINER-- [00:00:00] [00:00:00] --PORTVERSION-- [00:00:00] 4.34 [00:00:00] --End PORTVERSION-- [00:00:00] [00:00:00] --PORTREVISION-- [00:00:00] 0 [00:00:00] --End PORTREVISION-- [00:00:00] [00:00:00] --CONFIGURE_ARGS-- [00:00:00] INSTALLDIRS="site" CC="cc" CCFLAGS="-O2 -pipe -fstack-protector-strong -fno-strict-aliasing " LD="cc" PREFIX="/usr/local" INSTALLPRIVLIB="/usr/local/lib" INSTALLARCHLIB="/usr/local/lib" [00:00:00] --End CONFIGURE_ARGS-- [00:00:00] [00:00:00] --CONFIGURE_ENV-- [00:00:00] PERL_MM_USE_DEFAULT="YES" ac_cv_path_PERL=/usr/local/bin/perl ac_cv_path_PERL_PATH=/usr/local/bin/perl PERL_USE_UNSAFE_INC=1 XDG_DATA_HOME=/wrkdirs/usr/ports/devel/p5-EV/work XDG_CONFIG_HOME=/wrkdirs/usr/ports/devel/p5-EV/work XDG_CACHE_HOME=/wrkdirs/usr/ports/devel/p5-EV/work/.cache HOME=/wrkdirs/usr/ports/devel/p5-EV/work TMPDIR="/tmp" PATH=/wrkdirs/usr/ports/devel/p5-EV/work/.bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin:/root/bin PKG_CONFIG_LIBDIR=/wrkdirs/usr/ports/devel/p5-EV/work/.pkgconfig:/usr/local/libdata/pkgconfig:/usr/local/share/pkgconfig:/usr/libdata/pkgconfig SHELL=/bin/sh CONFIG_SHELL=/bin/sh PERL_EXTUTILS_AUTOINSTALL="--skipdeps" PERL_MM_USE_DEFAULT="YES" [00:00:00] --End CONFIGURE_ENV-- [00:00:00] [00:00:00] --MAKE_ENV-- [00:00:00] PERL_USE_UNSAFE_INC=1 XDG_DATA_HOME=/wrkdirs/usr/ports/devel/p5-EV/work XDG_CONFIG_HOME=/wrkdirs/usr/ports/devel/p5-EV/work XDG_CACHE_HOME=/wrkdirs/usr/ports/devel/p5-EV/work/.cache HOME=/wrkdirs/usr/ports/devel/p5-EV/work TMPDIR="/tmp" PATH=/wrkdirs/usr/ports/devel/p5-EV/work/.bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin:/root/bin PKG_CONFIG_LIBDIR=/wrkdirs/usr/ports/devel/p5-EV/work/.pkgconfig:/usr/local/libdata/pkgconfig:/usr/local/share/pkgconfig:/usr/libdata/pkgconfig MK_DEBUG_FILES=no MK_KERNEL_SYMBOLS=no SHELL=/bin/sh NO_LINT=YES PREFIX=/usr/local LOCALBASE=/usr/local CC="cc" CFLAGS="-O2 -pipe -fstack-protector-strong -fno-strict-aliasing " CPP="cpp" CPPFLAGS="" LDFLAGS=" " LIBS="" CXX="c++" CXXFLAGS="-O2 -pipe -fstack-protector-strong -fno-strict-aliasing " BSD_INSTALL_PROGRAM="install -s -m 555" BSD_INSTALL_LIB="install -s -m 0644" BSD_INSTALL_SCRIPT="install -m 555" BSD_INSTALL_DATA="install -m 0644" BSD_INSTALL_MAN="install -m 444" [00:00:00] --End MAKE_ENV-- [00:00:00] [00:00:00] --PLIST_SUB-- [00:00:00] OSREL=15.0 PREFIX=%D LOCALBASE=/usr/local RESETPREFIX=/usr/local LIB32DIR=lib PERL_VERSION=5.42.2 PERL_VER=5.42 PERL5_MAN1=lib/perl5/site_perl/man/man1 PERL5_MAN3=lib/perl5/site_perl/man/man3 SITE_PERL=lib/perl5/site_perl SITE_ARCH=lib/perl5/site_perl/mach/5.42 DOCSDIR="share/doc/EV" EXAMPLESDIR="share/examples/EV" DATADIR="share/EV" WWWDIR="www/EV" ETCDIR="etc/EV" [00:00:00] --End PLIST_SUB-- [00:00:00] [00:00:00] --SUB_LIST-- [00:00:00] PREFIX=/usr/local LOCALBASE=/usr/local DATADIR=/usr/local/share/EV DOCSDIR=/usr/local/share/doc/EV EXAMPLESDIR=/usr/local/share/examples/EV WWWDIR=/usr/local/www/EV ETCDIR=/usr/local/etc/EV [00:00:00] --End SUB_LIST-- [00:00:00] [00:00:00] ---Begin make.conf--- [00:00:00] USE_PACKAGE_DEPENDS=yes [00:00:00] BATCH=yes [00:00:00] WRKDIRPREFIX=/wrkdirs [00:00:00] PORTSDIR=/usr/ports [00:00:00] PACKAGES=/packages [00:00:00] DISTDIR=/distfiles [00:00:00] FORCE_PACKAGE=yes [00:00:00] PACKAGE_BUILDING=yes [00:00:00] PACKAGE_BUILDING_FLAVORS=yes [00:00:00] #### /usr/local/etc/poudriere.d/make.conf #### [00:00:00] DEFAULT_VERSIONS+= ssl=openssl [00:00:00] DEFAULT_VERSIONS+= mysql=11.4m [00:00:00] DEFAULT_VERSIONS+= pgsql=17 [00:00:00] OPTIONS_SET+= LDAP [00:00:00] OPTIONS_SET+= QT6 [00:00:00] #OPTIONS_UNSET+= X11 [00:00:00] DEFAULT_VERSIONS+= php=8.4 [00:00:00] DEFAULT_VERSIONS+= samba=4.23 [00:00:00] graphics_cairo_UNSET+= XCB [00:00:00] x11-toolkits_gtk30_UNSET += ATK_BRIDGE COLORD [00:00:00] #ALLOW_UNSUPPORTED_SYSTEM= yes [00:00:00] CCACHE_DIR= /var/cache/ccache [00:00:00] WITH_CCACHE_BUILD= yes [00:00:00] #OVERLAYS+= /usr/local/share/sccache/overlay [00:00:00] #SCCACHE_DIR= /var/cache/ccache/sccache [00:00:00] [00:00:00] databases_redis_UNSET= PIE RELRO BIND_NOW [00:00:00] [00:00:00] WITHOUT_PIE_PORTS+= databases/redis [00:00:00] WITHOUT_RELRO_PORTS+= databases/redis [00:00:00] WITHOUT_BIND_NOW_PORTS+= databases/redis [00:00:00] WITH_CCACHE_BUILD=yes [00:00:00] CCACHE_DIR=/root/.ccache [00:00:00] #### Misc Poudriere #### [00:00:00] .include "/etc/make.conf.ports_env" [00:00:00] GID=0 [00:00:00] UID=0 [00:00:00] DISABLE_MAKE_JOBS=poudriere [00:00:00] ---End make.conf--- [00:00:00] --Resource limits-- [00:00:00] cpu time (seconds, -t) unlimited [00:00:00] file size (512-blocks, -f) unlimited [00:00:00] data seg size (kbytes, -d) 33554432 [00:00:00] stack size (kbytes, -s) 524288 [00:00:00] core file size (512-blocks, -c) unlimited [00:00:00] max memory size (kbytes, -m) unlimited [00:00:00] locked memory (kbytes, -l) unlimited [00:00:00] max user processes (-u) 58500 [00:00:00] open files (-n) 8192 [00:00:00] virtual mem size (kbytes, -v) unlimited [00:00:00] swap limit (kbytes, -w) unlimited [00:00:00] socket buffer size (bytes, -b) unlimited [00:00:00] pseudo-terminals (-p) unlimited [00:00:00] kqueues (-k) unlimited [00:00:00] umtx shared locks (-o) unlimited [00:00:00] pipebuf (-y) unlimited [00:00:00] --End resource limits-- [00:00:00] times start [shell] (user/sys/real): 0m0.008s 0m0.008s 1h34m40.000s [00:00:00] times start [child] (user/sys/real): 0m0.024s 0m0.627s 1h34m40.000s [00:00:00] =================================================== [00:00:00] ===== env: NO_DEPENDS=yes USER=root UID=0 GID=0 [00:00:00] ===> License ART10 GPLv1+ accepted by the user [00:00:00] =========================================================================== [00:00:00] =================================================== [00:00:00] ===== env: USE_PACKAGE_DEPENDS_ONLY=1 USER=root UID=0 GID=0 [00:00:00] ===> p5-EV-4.34,1 depends on file: /usr/local/sbin/pkg - not found [00:00:00] ===> Installing existing package /packages/All/pkg-2.6.2_1.pkg [00:00:00] [pkg.mfl.dk] Installing pkg-2.6.2_1... [00:00:00] [pkg.mfl.dk] Extracting pkg-2.6.2_1: .......... done [00:00:00] ===> p5-EV-4.34,1 depends on file: /usr/local/sbin/pkg - found [00:00:00] ===> Returning to build of p5-EV-4.34,1 [00:00:00] =========================================================================== [00:00:00] =================================================== [00:00:00] ===== env: USE_PACKAGE_DEPENDS_ONLY=1 USER=root UID=0 GID=0 [00:00:00] =========================================================================== [00:00:00] =================================================== [00:00:00] ===== env: NO_DEPENDS=yes USER=root UID=0 GID=0 [00:00:00] ===> License ART10 GPLv1+ accepted by the user [00:00:00] => EV-4.34.tar.gz doesn't seem to exist in /portdistfiles. [00:00:00] => Attempting to fetch https://cpan.metacpan.org/authors/id/M/ML/MLEHMANN/EV-4.34.tar.gz [00:00:01] EV-4.34.tar.gz 214 kB 23 MBps 00s [00:00:01] ===> Fetching all distfiles required by p5-EV-4.34,1 for building [00:00:01] =========================================================================== [00:00:01] =================================================== [00:00:01] ===== env: FETCH_REGET=0 NO_DEPENDS=yes USER=root UID=0 GID=0 [00:00:01] ===> License ART10 GPLv1+ accepted by the user [00:00:01] ===> Fetching all distfiles required by p5-EV-4.34,1 for building [00:00:01] => SHA256 Checksum OK for EV-4.34.tar.gz. [00:00:09] =========================================================================== [00:00:09] =================================================== [00:00:09] ===== env: USE_PACKAGE_DEPENDS_ONLY=1 USER=root UID=0 GID=0 [00:00:09] =========================================================================== [00:00:09] =================================================== [00:00:09] ===== env: NO_DEPENDS=yes USER=root UID=0 GID=0 [00:00:09] ===> License ART10 GPLv1+ accepted by the user [00:00:09] ===> Fetching all distfiles required by p5-EV-4.34,1 for building [00:00:09] ===> Extracting for p5-EV-4.34,1 [00:00:09] => SHA256 Checksum OK for EV-4.34.tar.gz. [00:00:09] =========================================================================== [00:00:09] =================================================== [00:00:09] ===== env: USE_PACKAGE_DEPENDS_ONLY=1 USER=root UID=0 GID=0 [00:00:09] =========================================================================== [00:00:09] =================================================== [00:00:09] ===== env: NO_DEPENDS=yes USER=root UID=0 GID=0 [00:00:09] ===> Patching for p5-EV-4.34,1 [00:00:09] ===> Applying FreeBSD patches for p5-EV-4.34,1 from /usr/ports/devel/p5-EV/files [00:00:09] =========================================================================== [00:00:09] =================================================== [00:00:09] ===== env: USE_PACKAGE_DEPENDS_ONLY=1 USER=root UID=0 GID=0 [00:00:09] ===> p5-EV-4.34,1 depends on package: p5-Canary-Stability>=0 - not found [00:00:09] ===> Installing existing package /packages/All/p5-Canary-Stability-2013_1.pkg [00:00:09] [pkg.mfl.dk] Installing p5-Canary-Stability-2013_1... [00:00:09] [pkg.mfl.dk] `-- Installing perl5-5.42.2... [00:00:09] [pkg.mfl.dk] `-- Extracting perl5-5.42.2: .......... done [00:00:10] [pkg.mfl.dk] Extracting p5-Canary-Stability-2013_1: ..... done [00:00:10] ===> p5-EV-4.34,1 depends on package: p5-Canary-Stability>=0 - found [00:00:10] ===> Returning to build of p5-EV-4.34,1 [00:00:10] ===> p5-EV-4.34,1 depends on package: p5-common-sense>=0 - not found [00:00:10] ===> Installing existing package /packages/All/p5-common-sense-3.75.pkg [00:00:10] [pkg.mfl.dk] Installing p5-common-sense-3.75... [00:00:10] [pkg.mfl.dk] Extracting p5-common-sense-3.75: ........ done [00:00:10] ===> p5-EV-4.34,1 depends on package: p5-common-sense>=0 - found [00:00:10] ===> Returning to build of p5-EV-4.34,1 [00:00:10] ===> p5-EV-4.34,1 depends on package: perl5>=5.42.r<5.43 - found [00:00:10] ===> p5-EV-4.34,1 depends on file: /usr/local/bin/ccache - not found [00:00:10] ===> Installing existing package /packages/All/ccache-3.7.12_9.pkg [00:00:10] [pkg.mfl.dk] Installing ccache-3.7.12_9... [00:00:10] [pkg.mfl.dk] Extracting ccache-3.7.12_9: .......... done [00:00:10] Create compiler links... [00:00:10] create symlink for cc [00:00:10] create symlink for cc (world) [00:00:10] create symlink for c++ [00:00:10] create symlink for c++ (world) [00:00:10] create symlink for CC [00:00:10] create symlink for CC (world) [00:00:10] create symlink for clang [00:00:10] create symlink for clang (world) [00:00:10] create symlink for clang++ [00:00:10] create symlink for clang++ (world) [00:00:10] ===== [00:00:10] Message from ccache-3.7.12_9: [00:00:10] [00:00:10] -- [00:00:10] NOTE: [00:00:10] Please read /usr/local/share/doc/ccache/ccache-howto-freebsd.txt for [00:00:10] information on using ccache with FreeBSD ports and src. [00:00:10] ===> p5-EV-4.34,1 depends on file: /usr/local/bin/ccache - found [00:00:10] ===> Returning to build of p5-EV-4.34,1 [00:00:10] =========================================================================== [00:00:10] =================================================== [00:00:10] ===== env: USE_PACKAGE_DEPENDS_ONLY=1 USER=root UID=0 GID=0 [00:00:10] =========================================================================== [00:00:11] =================================================== [00:00:11] ===== env: NO_DEPENDS=yes USER=root UID=0 GID=0 [00:00:11] ===> Configuring for p5-EV-4.34,1 [00:00:11] Attempt to call undefined import method with arguments ("EV" ...) via package "Canary::Stability" (Perhaps you forgot to load the package?) at ./Makefile.PL line 2. [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Welcome to EV configuration. If you are in a hurry, just press return here [00:00:11] and hope for the best. The defaults should usually do. [00:00:11] [00:00:11] Skip further questions and use defaults (y/n)? [y] y [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] POSIX optionally offers support for a monotonic clock source. EV [00:00:11] can take advantage of this clock source to detect time jumps more [00:00:11] reliably. Unfortunately, some systems are bound to be broken, so you can [00:00:11] disable this here: you can completely disable the detection and use of [00:00:11] the monotonic clock by answering 'n' here. Support for this clock type [00:00:11] will otherwise be autodetected at both compile- and runtime. (this setting [00:00:11] currently affects the use of nanosleep over select as well). [00:00:11] [00:00:11] Enable optional support for CLOCK_MONOTONIC (y/n)? [y] y [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] POSIX optionally offers support for a (potentially) high-resolution [00:00:11] realtime clock interface. In a good implementation, using it is faster [00:00:11] than the normal method of using gettimeofday. Unfortunately, this option [00:00:11] is also bound to be broken on some systems, and current EV versions do not [00:00:11] actually call gettimeofday very often, so it defaults to no. [00:00:11] [00:00:11] Prefer clock_gettime (CLOCK_REALTIME) over gettimeofday (y/n)? [n] n [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] EV can use various backends with various portability issues. The select [00:00:11] backend is the most portable and makes for a good fallback, but it can be [00:00:11] limited to a low number of file descriptors and/or might not compile. If [00:00:11] you have problems with compiling ev_select.c, you might try to play around [00:00:11] with disabling it here, or forcing it to use the fd_set provided by your [00:00:11] OS, via the next question. I highly recommend keeping it in. [00:00:11] [00:00:11] Enable select backend (y/n)? [y] y [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] The select backend can operate in two modes. One uses the system-provided [00:00:11] fd_set and is usually limited to 1024 file descriptors (64 on windows), [00:00:11] the other requires your header files to define NFDBITS and declare a [00:00:11] suitable fd_mask type. If you run into problems compiling ev_select.c, you [00:00:11] can try forcing the use of the system fd_set here. [00:00:11] [00:00:11] Force use of system fd_set for select backend (y/n)? [n] n [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] The second very portable backend is poll(2). It does not exist on windows [00:00:11] and various versions of Mac OS X (and on the other versions it simply [00:00:11] doesn't work), but works basically everywhere else. It is recommended to use [00:00:11] the default here unless you run into compilation problems in ev_poll.c. [00:00:11] [00:00:11] Enable poll backend (y/n)? [y] y [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Select and poll make it hard to write efficient servers, especially if the [00:00:11] number of active connections is much lower than the watched ones. GNU/Linux [00:00:11] systems have a more scalable method called "epoll", which EV can use. For [00:00:11] this to work, both your kernel and glibc have to support epoll, but if you [00:00:11] can compile it, the detection will be done at runtime, and EV will safely [00:00:11] fall back to using select when epoll isn't available. If unsure, accept [00:00:11] the default. [00:00:11] [00:00:11] Enable epoll backend (y/n)? [n] n [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Linux 4.18 introduced another event polling interface, this time using [00:00:11] the Linux AIO API. While this API is far superior to epoll and almost [00:00:11] rivals kqueue, it also suffers from the same issues as kqueue typically [00:00:11] does: only a subset of file types are supported (as of 4.19, I have seen [00:00:11] eventfd, pipes, sockets files and some devices, but no ttys). It also [00:00:11] is subject arbitrary system-wide limits imposed on it. Therefore, this [00:00:11] backend is not used by default, even when it is compiled in, and you have [00:00:11] to request it explicitly, e.g. with LIBEV_FLAGS=64. If unsure, accept the [00:00:11] default. [00:00:11] [00:00:11] Enable linux aio backend (y/n)? [n] n [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Linux 4.19 introduced another event polling interface, "io_uring". While [00:00:11] this API is far superior to epoll and almost rivals linuxaio, it also [00:00:11] suffers from the same issues as kqueue typically does: only a subset of [00:00:11] file types are supported (as of 5.2). It is also very buggy still, and [00:00:11] most importantly, very very slow for most workloads. Therefore, this [00:00:11] backend is not used by default, even when it is compiled in, and you have [00:00:11] to request it explicitly, e.g. with LIBEV_FLAGS=128. If unsure, accept the [00:00:11] default. [00:00:11] [00:00:11] Enable linux io_uring backend (y/n)? [n] n [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] EV can take advantage of kqueue on many BSD systems. Support for kqueue [00:00:11] will be detected at runtime, with a safe fallback to other methods when it [00:00:11] cannot be used. [00:00:11] [00:00:11] Note that kqueue is subtly broken on most operating systems, so by default [00:00:11] it won't be used on many platforms, but you can still create your own [00:00:11] event loop with kqueue backend if you ask specifically for it. [00:00:11] [00:00:11] Here is what we know: [00:00:11] [00:00:11] NetBSD: partially working in at least 3.1 and later. Yeah! :) [00:00:11] FreeBSD: broken on at least 6.2-STABLE, spotty in later versions, [00:00:11] sockets *likely* work, ptys definitely don't. [00:00:11] OpenBSD: reports indicate that it likely doesn't work [00:00:11] (similar problems as on FreeBSD). [00:00:11] OS X: completely, utterly broken on at least <= 10.6. [00:00:11] [00:00:11] Enable kqueue backend (y/n)? [y] y [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Similarly to the kqueue backend above, EV can take advantage of the [00:00:11] solaris 10 event port interface. Support for event ports will be detected [00:00:11] at runtime, with a safe fallback to other methods when it cannot be used. [00:00:11] [00:00:11] Enable event port backend (y/n)? [n] n [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] EV needs the functions pthread_atfork and clock_gettime. On most systems [00:00:11] you need some special libraries for this (such as -lrt and -lpthread). You [00:00:11] can specify additional libraries to provide these calls (and any other [00:00:11] required by EV) now, or accept the default. [00:00:11] [00:00:11] On GNU/Linux systems, EV uses the LSB 3.1 __register_atfork function [00:00:11] to avoid the dependency on libpthread, and directly uses the clock_gettime [00:00:11] syscall to avoid a dependency on librt. [00:00:11] [00:00:11] Extra libraries for pthread_atfork and clock_gettime? [-lpthread -lrt ] -lpthread -lrt [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] A backend of a different kind is the Linux inotify(7) interface, which can [00:00:11] be used to speed up (and reduce resource consumption) of stat watchers. If [00:00:11] you have the include file and libc support for it, it is usually a good [00:00:11] idea to enable it, as kernel availability is detected at runtime. [00:00:11] [00:00:11] Enable inotify support (y/n)? [y] y [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Another useful bit of functionality is the Linux eventfd, which is useful [00:00:11] for faster signal handling (don't care) and intra-thread communications [00:00:11] (more relevant). Kernel support for this will be probed at runtime, but [00:00:11] your libc must contain the necessary wrapper. Glibc 2.7 and later should [00:00:11] have this wrapper. [00:00:11] [00:00:11] Enable linux eventfd support (y/n)? [y] y [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Another sometimes useful bit of functionality is the Linux signalfd, which [00:00:11] is useful for faster signal handling (don't care). Kernel support for [00:00:11] this will be probed at runtime, but your libc must contain the necessary [00:00:11] wrapper. Glibc 2.7 and later should have this wrapper. [00:00:11] [00:00:11] Enable linux signalfd support (y/n)? [n] n [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Linux kernels can notify userspace about realtime clock timejumps [00:00:11] using timerfd. Libev by default will try to take advantage of this if [00:00:11] possible. You can completely disable the detection and use of timerfd for [00:00:11] this purpose by answering 'n' here. Support for timerfd will otherwise be [00:00:11] autodetected at both compile- and runtime. [00:00:11] [00:00:11] Enable optional support for timerfd to detect timejumps (y/n)? [y] y [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Libev contains numerous internal assert() invocations to check for [00:00:11] consistency and user errors. These are normally enabled, but most [00:00:11] perl builds disable this error reporting mechanism by default. You [00:00:11] can re-enable these asserts here. Enabling them might help you catch [00:00:11] programming bugs earlier, but might cause a small slowdown. Also, failures [00:00:11] will be reported by aboritng your program, instead of throwing a perl [00:00:11] exception. [00:00:11] [00:00:11] If unsure, enable this if you only use this perl installation for [00:00:11] development, and leave it off for use in production environments. [00:00:11] [00:00:11] Make sure assertions are enabled? (y/n)? [n] n [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Very rarely, people want to tweak EV even more, e.g. to exclude [00:00:11] or include certain watcher types or backends. This can be done by adding [00:00:11] extra -D options here, or via the EV_EXTRA_DEFS environment variable. [00:00:11] [00:00:11] For example, if you run into compilation problems because of missing memory [00:00:11] fences (or you just want extra performance), you can tell EV to not support [00:00:11] smp and threads via -DEV_NO_THREADS. [00:00:11] [00:00:11] Most people would just press enter. [00:00:11] [00:00:11] Any extra -D options? [] [00:00:11] [00:00:11] *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** [00:00:11] [00:00:11] [00:00:11] Checking if your kit is complete... [00:00:11] Looks good [00:00:11] Generating a Unix-style Makefile [00:00:11] Writing Makefile for EV [00:00:11] Writing MYMETA.yml and MYMETA.json [00:00:11] =========================================================================== [00:00:11] =================================================== [00:00:11] ===== env: NO_DEPENDS=yes USER=root UID=0 GID=0 [00:00:11] ===> Building for p5-EV-4.34,1 [00:00:11] cp EV/EVAPI.h blib/lib/EV/EVAPI.h [00:00:11] cp EV.pm blib/lib/EV.pm [00:00:11] cp libev/ev.h blib/lib/EV/ev.h [00:00:11] cp libev/ev.pod blib/lib/EV/libev.pod [00:00:11] cp EV/MakeMaker.pm blib/lib/EV/MakeMaker.pm [00:00:11] Running Mkbootstrap for EV () [00:00:11] chmod 644 "EV.bs" [00:00:11] "/usr/local/bin/perl5.42.2" -MExtUtils::Command::MM -e 'cp_nonempty' -- EV.bs blib/arch/auto/EV/EV.bs 644 [00:00:12] "/usr/local/bin/perl5.42.2" "/usr/local/lib/perl5/5.42/ExtUtils/xsubpp" -typemap '/usr/local/lib/perl5/5.42/ExtUtils/typemap' -typemap '/wrkdirs/usr/ports/devel/p5-EV/work/EV-4.34/typemap' EV.xs > EV.xsc [00:00:12] mv EV.xsc EV.c [00:00:12] cc -c -Ilibev -O2 -pipe -fstack-protector-strong -fno-strict-aliasing -O2 -pipe -fstack-protector-strong -fno-strict-aliasing -DVERSION=\"4.34\" -DXS_VERSION=\"4.34\" -DPIC -fPIC "-I/usr/local/lib/perl5/5.42/mach/CORE" -DEV_USE_REALTIME=0 -DEV_USE_SELECT=1 -DEV_USE_POLL=1 -DEV_USE_EPOLL=0 -DEV_USE_LINUXAIO=0 -DEV_USE_IOURING=0 -DEV_USE_KQUEUE=1 -DEV_USE_PORT=0 -DEV_USE_INOTIFY=1 -DEV_USE_EVENTFD=1 -DEV_USE_SIGNALFD=0 EV.c [00:00:16] rm -f blib/arch/auto/EV/EV.so [00:00:16] LD_RUN_PATH="/usr/lib" cc -shared -L/usr/local/lib/perl5/5.42/mach/CORE -lperl -L/usr/local/lib -fstack-protector-strong EV.o -o blib/arch/auto/EV/EV.so -lpthread -lrt [00:00:16] chmod 755 blib/arch/auto/EV/EV.so [00:00:17] Manifying 3 pod documents [00:00:17] =========================================================================== [00:00:17] =================================================== [00:00:17] ===== env: USE_PACKAGE_DEPENDS_ONLY=1 USER=root UID=0 GID=0 [00:00:17] ===> p5-EV-4.34,1 depends on package: p5-common-sense>=0 - found [00:00:17] ===> p5-EV-4.34,1 depends on package: perl5>=5.42.r<5.43 - found [00:00:17] =========================================================================== [00:00:17] =================================================== [00:00:17] ===== env: NO_DEPENDS=yes USER=root UID=0 GID=0 [00:00:17] ===> Staging for p5-EV-4.34,1 [00:00:17] ===> Generating temporary packing list [00:00:17] "/usr/local/bin/perl5.42.2" -MExtUtils::Command::MM -e 'cp_nonempty' -- EV.bs blib/arch/auto/EV/EV.bs 644 [00:00:17] Manifying 3 pod documents [00:00:17] Files found in blib/arch: installing files in blib/lib into architecture dependent library tree [00:00:17] Installing /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/mach/5.42/auto/EV/EV.so [00:00:17] Installing /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/mach/5.42/EV.pm [00:00:17] Installing /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/mach/5.42/EV/libev.pod [00:00:17] Installing /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/mach/5.42/EV/EVAPI.h [00:00:17] Installing /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/mach/5.42/EV/ev.h [00:00:17] Installing /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/mach/5.42/EV/MakeMaker.pm [00:00:17] Installing /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/man/man3/EV::libev.3 [00:00:17] Installing /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/man/man3/EV.3 [00:00:17] Installing /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/man/man3/EV::MakeMaker.3 [00:00:17] /usr/bin/strip /wrkdirs/usr/ports/devel/p5-EV/work/stage/usr/local/lib/perl5/site_perl/mach/5.42/auto/EV/EV.so [00:00:17] ====> Compressing man pages (compress-man) [00:00:30] =========================================================================== [00:00:30] =================================================== [00:00:30] ===== env: 'PKG_NOTES=ports_top_git_hash ports_top_checkout_unclean port_checkout_unclean' 'PKG_NOTE_ports_top_git_hash=c6b0a9699f12f690cc20e84d5f1376ce073b3033' 'PKG_NOTE_ports_top_checkout_unclean=no' 'PKG_NOTE_port_checkout_unclean=no' NO_DEPENDS=yes USER=root UID=0 GID=0 [00:00:30] ===> Building packages for p5-EV-4.34,1 [00:00:30] ===> Building p5-EV-4.34,1 [00:00:46] =========================================================================== [00:00:46] =>> Cleaning up wrkdir [00:00:46] ===> Cleaning for p5-EV-4.34,1 [00:00:46] build of devel/p5-EV | p5-EV-4.34,1 ended at 2026-04-01T02:36:50+02:00 [00:00:46] build time: 00:00:52 [00:00:46] times end [shell] (user/sys/real): 0m0.040s 0m0.013s 0m52.000s [00:00:46] times end [child] (user/sys/real): 0m7.548s 0m1.951s 0m52.000s