From nobody Mon Mar 03 11:06:41 2025 X-Original-To: freebsd-current@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4Z5wxR3yNLz5pFG6 for ; Mon, 03 Mar 2025 11:06:51 +0000 (UTC) (envelope-from fuz@fuz.su) Received: from fuz.su (fuz.su [IPv6:2001:41d0:8:e508::1]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (2048 bits) client-digest SHA256) (Client CN "fuz.su", Issuer "fuz.su" (not verified)) by mx1.freebsd.org (Postfix) with ESMTPS id 4Z5wxP6bGLz3R8y for ; Mon, 03 Mar 2025 11:06:49 +0000 (UTC) (envelope-from fuz@fuz.su) Authentication-Results: mx1.freebsd.org; dkim=none; dmarc=none; spf=pass (mx1.freebsd.org: domain of fuz@fuz.su designates 2001:41d0:8:e508::1 as permitted sender) smtp.mailfrom=fuz@fuz.su Received: from fuz.su (localhost [127.0.0.1]) by fuz.su (8.18.1/8.18.1) with ESMTPS id 523B6gYB091280 (version=TLSv1.3 cipher=TLS_AES_256_GCM_SHA384 bits=256 verify=NO) for ; Mon, 3 Mar 2025 12:06:42 +0100 (CET) (envelope-from fuz@fuz.su) Received: (from fuz@localhost) by fuz.su (8.18.1/8.18.1/Submit) id 523B6g1B091279 for freebsd-current@freebsd.org; Mon, 3 Mar 2025 12:06:42 +0100 (CET) (envelope-from fuz) Date: Mon, 3 Mar 2025 12:06:41 +0100 From: Robert Clausecker To: freebsd-current@freebsd.org Subject: Re: Creating poudriere jail fails with libmd.so.6 not found Message-ID: References: List-Id: Discussions about the use of FreeBSD-current List-Archive: https://lists.freebsd.org/archives/freebsd-current List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-freebsd-current@FreeBSD.org MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable In-Reply-To: X-Spamd-Result: default: False [-0.98 / 15.00]; NEURAL_SPAM_LONG(0.88)[0.880]; NEURAL_HAM_MEDIUM(-0.87)[-0.871]; NEURAL_HAM_SHORT(-0.69)[-0.689]; R_SPF_ALLOW(-0.20)[+a]; MIME_GOOD(-0.10)[text/plain]; FROM_HAS_DN(0.00)[]; RCPT_COUNT_ONE(0.00)[1]; ASN(0.00)[asn:16276, ipnet:2001:41d0::/32, country:FR]; MIME_TRACE(0.00)[0:+]; FREEFALL_USER(0.00)[fuz]; MISSING_XM_UA(0.00)[]; MID_RHS_MATCH_FROM(0.00)[]; MLMMJ_DEST(0.00)[freebsd-current@freebsd.org]; DMARC_NA(0.00)[fuz.su]; RCVD_COUNT_TWO(0.00)[2]; FROM_EQ_ENVFROM(0.00)[]; R_DKIM_NA(0.00)[]; TO_DN_NONE(0.00)[]; PREVIOUSLY_DELIVERED(0.00)[freebsd-current@freebsd.org]; TO_MATCH_ENVRCPT_ALL(0.00)[]; RCVD_TLS_LAST(0.00)[]; ARC_NA(0.00)[] X-Rspamd-Queue-Id: 4Z5wxP6bGLz3R8y X-Spamd-Bar: / Hi Matthias, Am Mon, Mar 03, 2025 at 08:05:04AM +0100 schrieb Matthias Apitz: > I tried to create a new jail in my CURRENT from March 1 > This fails with: >=20 > # poudriere jail -c -j 150-CURRENT -m src=3D/usr/src >=20 > [00:00:00] Creating 150-CURRENT fs at /usr/local/poudriere/jails/150-CURR= ENT... done > [00:00:01] Copying /usr/src to /usr/local/poudriere/jails/150-CURRENT/usr= /src... done > [00:02:31] Starting make installworld > --- installworld --- > make[1]: "/usr/obj/usr/src/amd64.amd64/toolchain-metadata.mk" line 1: Usi= ng cached toolchain metadata from build at jet on Sat Mar 1 20:51:42 CET 2= 025 > --- _installcheck_world --- > -------------------------------------------------------------- > >>> Install check world started on Sun Mar 2 22:04:40 CET 2025 > -------------------------------------------------------------- > --- installworld --- > mkdir -p /tmp/install.APjSa9v82y > progs=3D$(for prog in [ awk cap_mkdb cat chflags chmod chown cmp cp date= echo egrep find grep id install ln make mkdir mtree mv pwd_mkdb rm sed = services_mkdb sh sort strip sysctl test time true uname wc tzsetup makewhat= is ; do if progpath=3D`env PATH=3D/usr/obj/usr/src/amd64.amd64/tmp/bin:/us= r/obj/usr/src/amd64.amd64/tmp/usr/sbin:/usr/obj/usr/src/amd64.amd64/tmp/usr= /bin:/usr/obj/usr/src/amd64.amd64/tmp/legacy/usr/sbin:/usr/obj/usr/src/amd6= 4.amd64/tmp/legacy/usr/bin:/usr/obj/usr/src/amd64.amd64/tmp/legacy/bin:/usr= /obj/usr/src/amd64.amd64/tmp/legacy/usr/libexec::/sbin:/bin:/usr/sbin:/usr/= bin which $prog`; then echo $progpath; else echo "Required tool $prog no= t found in PATH ("/usr/obj/usr/src/amd64.amd64/tmp/bin:/usr/obj/usr/src/amd= 64.amd64/tmp/usr/sbin:/usr/obj/usr/src/amd64.amd64/tmp/usr/bin:/usr/obj/usr= /src/amd64.amd64/tmp/legacy/usr/sbin:/usr/obj/usr/src/amd64.amd64/tmp/legac= y/usr/bin:/usr/obj/usr/src/amd64.amd64/tmp/legacy/bin:/usr/obj/usr/src/amd6= 4.amd64/tmp/legacy/usr/libexec::/sbin:/bin:/usr/sbin:/usr/bin")." >&2; exi= t 1; fi; done); if [ -z "" ] ; then libs=3D$(ldd -f "%o %p\n" -f "%o %p= \n" $progs 2>/dev/null | sort -u | grep -Ev '\[.*]' | while read line; do = $line; if [ "$2 $3" !=3D "not found" ]; then echo $2; else echo "Requi= red library $1 not found." >&2; exit 1; fi; done); fi; cp $libs $progs= /tmp/install.APjSa9v82y > Required library libmd.so.6 not found. > *** [installworld] Error code 1 >=20 > make[1]: stopped making "installworld" in /usr/src > make[1]: 1 error >=20 > make[1]: stopped making "installworld" in /usr/src >=20 > make: stopped making "installworld" in /usr/src > [00:02:32] Error: /usr/local/share/poudriere/jail.sh:installworld:12:Fail= ed to 'make installworld' > [00:02:32] Error while creating jail, cleaning up. > [00:02:32] Removing 150-CURRENT jail... done > [00:02:34] Cleaning 150-CURRENT data... done >=20 > I investigated the problem and the old libmd.so.6 is used by some > binaries in /usr/obj/usr/src/amd64.amd64/tmp/legacy/usr/sbin/mtree > which the 'make buildworld' copied to this place from the underlying old > system: >=20 > # ldd /usr/obj/usr/src/amd64.amd64/tmp/legacy/usr/sbin/mtree | grep libmd= =2Eso.6 > libmd.so.6 =3D> not found (0) > # ldd /usr/obj/usr/src/amd64.amd64/tmp/legacy/usr/sbin/sort | grep libmd.= so.6 > libmd.so.6 =3D> not found (0) > # ls -l /usr/obj/usr/src/amd64.amd64/tmp/legacy/usr/sbin/mtree /usr/obj/u= sr/src/amd64.amd64/tmp/legacy/usr/sbin/sort > -r-xr-xr-x 1 root wheel 65392 Aug 6 2023 /usr/obj/usr/src/amd64.amd64/= tmp/legacy/usr/sbin/mtree > -r-xr-xr-x 1 root wheel 62544 Aug 6 2023 /usr/obj/usr/src/amd64.amd64/= tmp/legacy/usr/sbin/sort >=20 > Aug 6, 2023 the 14-CURRENT was setup where I built the now 15-CURRENT on > March 2: >=20 > # uname -a > FreeBSD jet 15.0-CURRENT FreeBSD 15.0-CURRENT #0 main-n275738-7ee310c80ea= 7: Sun Mar 2 01:13:00 CET 2025 guru@jet:/usr/obj/usr/src/amd64.amd64/s= ys/GENERIC amd64 >=20 > What would be the correct way to fix this? Re-run 'make buildworld' > again? Or copying the shared lib libmd.so.6 into place? The simplest solution is to clear the object directory and do a fresh world= build. libmd.so.6 was turned into libmd.so.7 as part of a recent API change. It s= hould also work to link libmd.so.7 to libmd.so.6. Yours, Robert Clausecker --=20 () ascii ribbon campaign - for an encoding-agnostic world /\ - against html email - against proprietary attachments