From nobody Sat Jan 1 02:18:56 2022 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 6B5071910573 for ; Sat, 1 Jan 2022 02:19:08 +0000 (UTC) (envelope-from marklmi@yahoo.com) Received: from sonic308-8.consmr.mail.gq1.yahoo.com (sonic308-8.consmr.mail.gq1.yahoo.com [98.137.68.32]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 4JQm0V473cz3k21 for ; Sat, 1 Jan 2022 02:19:06 +0000 (UTC) (envelope-from marklmi@yahoo.com) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=yahoo.com; s=s2048; t=1641003538; bh=K9616ueUMG8bLwhVDd+sTkqfJYjVtyvtc7AQAXAeiFE=; h=Subject:From:In-Reply-To:Date:Cc:References:To:From:Subject:Reply-To; b=Wdfg72VZzdp2VhXV8UBOllWl1X3RlgmOKuZ/qtIByzu/T/I6XVPFyAMFMByy0d8xSWjz4SGiQ2ewpIQV/n4GSvModPbrRDzUKnEA4hZMdtJcEBeK8JfYaOoLWiR7Tg6qC/6i6nGigUzSpFLVxPoYDPpKaIBL1gyl68GZe9AbwqbFxqp2ITyl8aOQzrEge1WyOx7hTpBfYJtsdHekCO6RNG0w3NX+ke4HybkRra9iBwjDNoKFGXkzoq/rSNGPDO7/3y00Ucqxk4ea9BrrPtqtF7kSsUOk3Gi60ces944zbO4VRX81wr2SY6NELtfuY19ef0d+jMPrDZQvWedJhL/LLw== X-SONIC-DKIM-SIGN: v=1; a=rsa-sha256; c=relaxed/relaxed; d=yahoo.com; s=s2048; t=1641003538; bh=QCnd/Ejeaa4EZ8CyYrLCInYuLgYpB0lrKzrc8EmVvAt=; h=X-Sonic-MF:Subject:From:Date:To:From:Subject; b=Sr1By5lxRK7x9p9BPu1MPw8Pjr54s0nF+0NbH5XJ24mn/R2ugYZebAvbV3yEArpsbJSnFWEEkVBts/Fpc4xU6zEjMsyiYUnLo3x33Z+OEbo02DoKgrBG6MPQXHtSVNkbzPBe5+n9xRQl64anWQU3+phMfAp5nnxn0jzmBBP3/FRbu6ZgdcxdQ94xlgkJW3SwQa9vbMtOjDsmobh7cSDAwfMW90G1raqHnbtPW1URLNBKyW3uqnsEWJ55qaxJLhXGvsv8rTCpIGeEMERai+AERMUCAYxcGwqQ7t7weFSXYidvVf1C+6BByogiqtO0tyysjUUbVnPD0lB1CdV1OMEAfw== X-YMail-OSG: 8FNWZsUVM1n1tucRwVR.nsxN7rrssGGvxH_fd83M8A8TibB65jWgcOY0fPZEGLF vyGkigJIRz_bGoPZAoz9Di.3fTg.BgQshwv4qTJWRbeWaA6_k3NPTUGSQN3vETuRDhGw8gtH4gWm Wa7blRQYC4nZBNZD7QJkj9VLpqffFtnJ5Jj291UIcf2E7dhYVMng_L3ohkjrlgVTdBqcMaKLe7LH LkYvgLeLxR3HAAfFWiFaCV6bmfCV.ShHBI9MRfgtbLZdJhMRlqybwnWDX42zSR7.dx54fLRZYDI2 CCLn9gbtkRa3zxDTXKCSSQ8Ium2Huv7a1HYIjdgsx9BBUpoXNFSgTDiAcr0R7NKWNTW0.w2YqF.r MierVu7jv_T0neaWd2mB9RgGpp0R1UZJ2iJS1FBAxxq0sW4J9D0TBsoiD3dDkQQISZh1KMXH0gMF 3nKP75qw_EVXtTjIdw66G4.bPY_dimtb8jo7CeqIpdKtViU6chnee1g4iYW2fdJIErhw8Dg4370Z MLs3bZcrwlhzekbZNTCl12XWarPfVNDgg9t8ZPdlxTF2fhcq66pkf98zbD7vLm3.b4gclJY.piCH .9Z3q6urdnK4bhpLkXgOCJAOG6O4KIhxzDJlDgQspF5bU_2d9JryfVhRK7_zBVT4gwLBsB5Tt2Du VfJe9_6zg1R2RjZZydLPCpQQfUYklJUI29RouKn8XzEQgFTtPn4RElKUVsObaDjxKZRGbtun8yjP cTjXZ7bwaGYDR1srjfE5Dnhi1IL_GFc3AhK.bdyRiRZU9aHFqNvP9ARwNzwmd9_aCcZobwaSVvHx 7CRavz2Nub39NOEu3Yu.HoJNE0_1IvKIVx.hrDZ0Zvg8dWb9hoIHTZ_AL.IEzpm6O8yUr67qtkZW 0nkCmhdBciBt_9LtnmG2GAgkGS8HLdCrutV5xhnnEaY6noPlq_8Dr.oh3pRkxxniVbh7G5Ohrgp0 May_klHQbtWuHN3IvetK5PfBNa94T6IFcU.1Mzj_T18ohaU3XpUd_Y7Ua82.YirFQ_lS41brPmCW ObNauIkrdfp205uZgrJo_FoKirUhFmqTPq5G6xUsCACi_b3LOwwf0xD198mPtmo7bXSauavdT6HQ VNGLIDHAOT42QkNNEkpp9j_hL3QqI36ttrx0f074rE5dteuZm15REItEjBP4Kd2GFS1UU5IZ05v1 etmI74wixglJ0ZloDugV.W.Dg2.h1Ec9hWZ2OjRQiD4vc21OJz6yEQWHprVVtkH2eAf3yUbhrO27 dgvs2mjUwpl3W05fk9DORO3v5mMzy_keS8J7Na119MybjJYnaLoQomUC7uDLfRQRhFVLrNP53Iav aJJjWFjGS9PD9aExRgdpO0bapjDAzGVP23hmTmywwy137qa7rUB7VKCQqySSnjv1pbjlspxZwb8f AoaYSHEpfgXww9pHcMjl87zS3IJolf9iRtAxGkUcWmm6vS.e1hXyTE0qXCa9Yb5hQ9qhbo6r4Di2 ki5harEmHSrsmBQAFY0p7kUKkF8Tx8rvOa.cEVusaSEPoV4dRBr6.Vim4qnwh_I6p2yVk_kCZjEH DLiMWwmUmbs3n69VoR57YDXBlXk.wUJfTVo1J3Jg0S1gwJ39Pbpktn.oNQfJSa9h5V08nkLTc7gL XeSMEEaBQkjTtabt7PSqzGFvXgslpF_vk95tFxUUeY7eSW0ErcbVHTJrPliYOlhFJxhoC_sepd0I PBSTGacnoWTf4U10hKo8bIgKMxVZY_JQfdW40bkNDst.SECJ5uS_kMEYP4kX1nAXtdPT8SjW7Vfs LJxd4xNYmxpnN6KhyIj5IBx.v16qkYLjVv_O.rwreJlqZu4e2qvr8CNhCN4hPFaEoqDV._PCaxrJ ahoCxANuY3NnMio9ux0h2X0G2hENnYjG9pb0yFQCzCjrPoQefAFRqUl0kWm_.Lio9LLob5899HMF DX0zBh29L7qdWIAdggBLqvGR4WsowQpxwncHNslCtFpJj9Jvg9vSJZ3k12K5qi2XoncpLer2R3Ca rEf2zRxV4lCPYFrfav6fiaCpi9cGJykiv4tdE2spixXl400YnVPDYpy3g2rpQsZHmUX1TWzSLtE0 86cNMIKVf1uVSebhZS1K6eV9YZdJw.tMwAelNKpv80RVrIWf5UWsvBWzEVlL5R4inr4CsJx8rtK5 ibTe4OaSmukCyLvJIp4Kbj5H8B6evCvt6mOckyEku1fCKQnDnSPdz4vsQr.CtZP.Asw4vl_9Frph WIBzsSpIrzI2ErEvjCYeKWsCSmhTzj6fRZtKlDLX7G5E- X-Sonic-MF: Received: from sonic.gate.mail.ne1.yahoo.com by sonic308.consmr.mail.gq1.yahoo.com with HTTP; Sat, 1 Jan 2022 02:18:58 +0000 Received: by kubenode524.mail-prod1.omega.gq1.yahoo.com (VZM Hermes SMTP Server) with ESMTPA ID e29680bae811a39c9f7f9095852e448e; Sat, 01 Jan 2022 02:18:57 +0000 (UTC) Content-Type: text/plain; charset=us-ascii 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 (Mac OS X Mail 14.0 \(3654.120.0.1.13\)) Subject: Re: git: 5e6a2d6eb220 - main - Reapply: move libc++ from /usr/lib to /lib [add /usr/lib/libc++.so.1 -> ../../lib/libc++.so.1 ?] In-Reply-To: <82BE340A-321C-43F3-AD7B-2E8466ADA17F@yahoo.com> Date: Fri, 31 Dec 2021 18:18:56 -0800 Cc: Dimitry Andric , Ed Maste , freebsd-current , "dev-commits-src-main@freebsd.org" Content-Transfer-Encoding: quoted-printable Message-Id: <595C5A0E-B024-46EE-883E-2FCA6ADFE171@yahoo.com> References: <45118DB4-F8C4-4F96-9CAA-5DC5DCFFEB7E@yahoo.com> <3140C5F6-495F-441C-AA6B-542F3BC53B62@yahoo.com> <5F8AF0B2-3AF3-4BE4-B5D1-9030F2605FFD@yahoo.com> <5a24eb16-078f-15c5-dcd4-ecef33d15ac7@FreeBSD.org> <03AF30DA-A632-4223-908C-9F5250D82079@yahoo.com> <76FC7AFB-DA78-4A44-BC74-4477C9E11413@yahoo.com> <82BE340A-321C-43F3-AD7B-2E8466ADA17F@yahoo.com> To: John Baldwin X-Mailer: Apple Mail (2.3654.120.0.1.13) X-Rspamd-Queue-Id: 4JQm0V473cz3k21 X-Spamd-Bar: - Authentication-Results: mx1.freebsd.org; dkim=pass header.d=yahoo.com header.s=s2048 header.b=Wdfg72VZ; dmarc=pass (policy=reject) header.from=yahoo.com; spf=pass (mx1.freebsd.org: domain of marklmi@yahoo.com designates 98.137.68.32 as permitted sender) smtp.mailfrom=marklmi@yahoo.com X-Spamd-Result: default: False [-1.49 / 15.00]; TO_DN_EQ_ADDR_SOME(0.00)[]; TO_DN_SOME(0.00)[]; FREEMAIL_FROM(0.00)[yahoo.com]; MV_CASE(0.50)[]; R_SPF_ALLOW(-0.20)[+ptr:yahoo.com]; RCPT_COUNT_FIVE(0.00)[5]; DKIM_TRACE(0.00)[yahoo.com:+]; DMARC_POLICY_ALLOW(-0.50)[yahoo.com,reject]; FROM_EQ_ENVFROM(0.00)[]; MIME_TRACE(0.00)[0:+]; FREEMAIL_ENVFROM(0.00)[yahoo.com]; ASN(0.00)[asn:36647, ipnet:98.137.64.0/20, country:US]; RCVD_TLS_LAST(0.00)[]; SUBJECT_HAS_QUESTION(0.00)[]; DWL_DNSWL_NONE(0.00)[yahoo.com:dkim]; MID_RHS_MATCH_FROM(0.00)[]; ARC_NA(0.00)[]; R_DKIM_ALLOW(-0.20)[yahoo.com:s=s2048]; NEURAL_HAM_MEDIUM(-1.00)[-1.000]; FROM_HAS_DN(0.00)[]; NEURAL_SPAM_SHORT(1.00)[1.000]; NEURAL_HAM_LONG(-0.99)[-0.995]; MIME_GOOD(-0.10)[text/plain]; TO_MATCH_ENVRCPT_SOME(0.00)[]; RCVD_IN_DNSWL_NONE(0.00)[98.137.68.32:from]; RWL_MAILSPIKE_POSSIBLE(0.00)[98.137.68.32:from]; RCVD_COUNT_TWO(0.00)[2] Reply-To: marklmi@yahoo.com From: Mark Millard via freebsd-current X-Original-From: Mark Millard X-ThisMailContainsUnwantedMimeParts: N On 2021-Dec-31, at 17:46, Mark Millard wrote: > On 2021-Dec-31, at 15:04, John Baldwin wrote: >=20 >> On 12/31/21 2:59 PM, Mark Millard wrote: >>> On 2021-Dec-31, at 14:28, Mark Millard wrote: >>>> On 2021-Dec-30, at 14:04, John Baldwin wrote: >>>>=20 >>>>> On 12/30/21 1:09 PM, Mark Millard wrote: >>>>>> On 2021-Dec-30, at 13:05, Mark Millard wrote: >>>>>>> This asks a question in a different direction that my prior >>>>>>> reports about my builds vs. Cy's reported build. >>>>>>>=20 >>>>>>> Background: >>>>>>>=20 >>>>>>> = /usr/obj/BUILDs/main-amd64-nodbg-clang/usr/main-src/amd64.amd64/tmp/usr/li= b/libc++.so:GROUP ( /lib/libc++.so.1 /usr/lib/libcxxrt.so >>>>>>> and: >>>>>>> lrwxr-xr-x 1 root wheel 23 Dec 29 13:17:01 2021 = /usr/lib/libcxxrt.so -> ../../lib/libcxxrt.so.1 >>>>>>>=20 >>>>>>> Why did libc++.so.1 not get a: >>>>>>>=20 >>>>>>> /usr/lib/libc++.so.1 -> ../../lib/libc++.so.1 >>>>>> I forgot to remove the .1 on the left hand side: >>>>>> /usr/lib/libc++.so -> ../../lib/libc++.so.1 >>>>>=20 >>>>> Because for libc++.so we don't just symlink to the current version = of the library >>>>> (as we do for most other shared libraries) to tell the compiler = what to link against >>>>> for -lc++, instead we use a linker script that tells the compiler = to link against >>>>> both of those libraries when -lc++ is encountered. >>>>=20 >>>> A better identification of what looks odd to me is the >>>> path variations in: >>>>=20 >>>> # more /usr/lib/libc++.so >>> Another not great day on my part: That path alone makes >>> the mix of /lib/ and /usr/lib/ use involved, given the >>> reference to /lib/libc++.so.1 . That would still be true >>> if the other path had been /lib/libcxxrt.so . >>=20 >> /usr/lib/libc++.so is only used by the compiler/linker when linking a = binary. >> The resulting binary has the associated paths (/lib/libc++.so.1 and >> /usr/lib/libcxxrt.so.1) in its DT_NEEDED. So it is fine for the .so = to be >> in /usr/lib. This is the same with /usr/lib/libc.so vs = /lib/libc.so.7. >>=20 >> However, your point about libcxxrt.so.1 is valid. It needs to also = be moved >> to /lib if libc++.so.1 is moved to /lib. Doing so will also require = yet another >> depend-clean.sh fixup (well, probably just adjusting the one I added = to >> check the libcxxrt path instead of libc++ path). >=20 > Hmm. Looking (now after having updated so /lib/libc++.so.1 > is in use, not that this is any different here): >=20 > # ls -Tld /lib/libcxx* /usr/lib/libcxx* > -r--r--r-- 1 root wheel 131656 Dec 31 14:19:49 2021 = /lib/libcxxrt.so.1 > -r--r--r-- 1 root wheel 355764 Dec 24 15:19:42 2021 = /usr/lib/libcxxrt.a > lrwxr-xr-x 1 root wheel 23 Dec 31 14:19:49 2021 = /usr/lib/libcxxrt.so -> ../../lib/libcxxrt.so.1 >=20 > # more /usr/lib/libc++.so=20 > /* $FreeBSD$ */ > GROUP ( /lib/libc++.so.1 /usr/lib/libcxxrt.so ) >=20 > So: no actual reference to /usr/lib/libcxxrt.so.1 but > a reference in the DT_NEEDED to /usr/lib/libcxxrt.so ? >=20 > May be just /usr/lib/libc++.so needs different text in order > for DT_NEEDED to have different text related to libcxxrt in > future build activities, avoiding /usr/lib/ ? >=20 >=20 > For reference: >=20 > # uname -apKU > FreeBSD amd64_ZFS 14.0-CURRENT FreeBSD 14.0-CURRENT #27 = main-n252090-5650d340ad66-dirty: Fri Dec 31 06:00:41 PST 2021 = root@amd64_ZFS:/usr/obj/BUILDs/main-amd64-nodbg-clang/usr/main-src/amd64.a= md64/sys/GENERIC-NODBG amd64 amd64 1400046 1400046 >=20 In a aarch64 context I looked at an old executable via ldd -a : # ldd -a bt /usr/home/root/c_tests/bt: libexecinfo.so.1 =3D> /usr/lib/libexecinfo.so.1 (0x41c19000) libc++.so.1 =3D> /lib/libc++.so.1 (0x42484000) libcxxrt.so.1 =3D> /lib/libcxxrt.so.1 (0x43038000) libm.so.5 =3D> /lib/libm.so.5 (0x44a4c000) libc.so.7 =3D> /lib/libc.so.7 (0x439ce000) /usr/lib/libexecinfo.so.1: libelf.so.2 =3D> /lib/libelf.so.2 (0x4581e000) libgcc_s.so.1 =3D> /lib/libgcc_s.so.1 (0x46e4f000) libc.so.7 =3D> /lib/libc.so.7 (0x439ce000) /lib/libc++.so.1: libcxxrt.so.1 =3D> /lib/libcxxrt.so.1 (0x43038000) libgcc_s.so.1 =3D> /lib/libgcc_s.so.1 (0x46e4f000) libc.so.7 =3D> /lib/libc.so.7 (0x439ce000) /lib/libcxxrt.so.1: libgcc_s.so.1 =3D> /lib/libgcc_s.so.1 (0x46e4f000) libc.so.7 =3D> /lib/libc.so.7 (0x439ce000) /lib/libm.so.5: libc.so.7 =3D> /lib/libc.so.7 (0x439ce000) /lib/libelf.so.2: libc.so.7 =3D> /lib/libc.so.7 (0x439ce000) /lib/libgcc_s.so.1: libc.so.7 =3D> /lib/libc.so.7 (0x439ce000) Looks like something already deals with finding /lib/libcxxrt.so.1 . But it is not obvious what path it started with and how much processing was done (or when) to end up with /lib/libc++.so.1 showing. But there is still a /usr/lib/ reference overall: /usr/lib/libexecinfo.so.1 But this is because the old program turned out to be an old experiment: # more bt.c=20 // bt.c // from releng/12 (12.2?) context (pre-llvm12), but not releng/13 : // # cc -o bt bt.c -lexecinfo // # ./bt // Rerun in llvm12 context, such as main after the switch: crash. #include int main() { void *addrlist[100]; backtrace(addrlist, 100); } Although, for some reason, the executable was dated 2021-Jul-15, not that I remember why I'd rebuilt it then. # file bt bt: ELF 64-bit LSB executable, ARM aarch64, version 1 (SYSV), = dynamically linked, interpreter /libexec/ld-elf.so.1, for FreeBSD 14.0 = (1400025), FreeBSD-style, with debug_info, not stripped nm -a bt shows: entry: 0 d_tag: DT_NEEDED d_val: libexecinfo.so.1 None of the DT_NEEDED entries had paths shown. The only /usr/lib/ reference was: entry: 65 st_name: /usr/lib/crti.o st_value: 0 st_size: 0 st_info: STT_FILE STB_LOCAL st_shndx: 65521 Overall: backtrace requires /usr/lib/ accessibility for main-n252090-5650d340ad66 in order to access /usr/lib/libexecinfo.so.1 . For reference: # uname -apKU FreeBSD CA72_16Gp_ZFS 14.0-CURRENT FreeBSD 14.0-CURRENT #34 = main-n252090-5650d340ad66-dirty: Fri Dec 31 06:30:22 PST 2021 = root@CA72_16Gp_ZFS:/usr/obj/BUILDs/main-CA72-nodbg-clang/usr/main-src/arm6= 4.aarch64/sys/GENERIC-NODBG-CA72 arm64 aarch64 1400046 1400046 =3D=3D=3D Mark Millard marklmi at yahoo.com