From nobody Fri Jan 19 18:36:08 2024 X-Original-To: dev-commits-src-main@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 4TGpGs4bydz576wR for ; Fri, 19 Jan 2024 18:36:21 +0000 (UTC) (envelope-from wlosh@bsdimp.com) Received: from mail-ed1-x534.google.com (mail-ed1-x534.google.com [IPv6:2a00:1450:4864:20::534]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (2048 bits) client-digest SHA256) (Client CN "smtp.gmail.com", Issuer "GTS CA 1D4" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4TGpGs0866z4gKk for ; Fri, 19 Jan 2024 18:36:21 +0000 (UTC) (envelope-from wlosh@bsdimp.com) Authentication-Results: mx1.freebsd.org; none Received: by mail-ed1-x534.google.com with SMTP id 4fb4d7f45d1cf-559533e2503so1149380a12.1 for ; Fri, 19 Jan 2024 10:36:20 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bsdimp-com.20230601.gappssmtp.com; s=20230601; t=1705689380; x=1706294180; darn=freebsd.org; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc:subject:date:message-id:reply-to; bh=ITjVZRcx6VKjuN1hK6cWuF5KCQrtlHqD7IJ31OEygU0=; b=1lkv4bzPqwGH4Dd223tYtZonv/vaph6GMKKFBq34yy6FjnRndGh7a2VmMSJEiP3ona rJOu2flD2t0LfRSnjwNdmggafueMqHrAUM5aUxS1yVn54iHU4VzaFZWFnClAYS3ssfzx RsfFEeo/cg8P9S3Lj7LMxqU6drwCbV8gX7DvU5SZdHEjozuygrn9KYzaAm8j1JhFhy+d /ZK0LBucr8w4M81av2uKk4SxfYjk6ABiveCljim/zXTHbipLS/6XkFcOoMLlICmPCsCP F/xwEgJXuymApUXHeb1tM7R/036yvxUeiklcRzpNuUTDbMvPxqjbhlJHNyhCWOestyna qkPA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1705689380; x=1706294180; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=ITjVZRcx6VKjuN1hK6cWuF5KCQrtlHqD7IJ31OEygU0=; b=G5FWaU7ZOK9P2OgVmQWdfaEhPrSGQxWnGPM21Xapzd8VaPQH9mafYJT+9IePCkXmaX laJlfRey0Lg6uzpq3wI5dc86W/gDLlqygZGJpTTG5IkLxIAPmv5dldgg+aE6Z/MO4Zl6 68E5sx18u+Dv2Lt8LGbumz5OznmE/AzYigEtLPPdOBknM82rMZid3vlrqhcZe1ipbTlw xEl0se2p3kbKCPJs2x9lhfAbNSYYZQHGzU3ZJ4tNXW5qNjSMet4LedUn7p9AREbInk7i JSJk5jUdx707/knHyBkPOGyznD3SdiSGKCexmbO1mQWU3yWe31OlYPzuHiX/6DDyhegD nZCA== X-Gm-Message-State: AOJu0YxVcMMmpBsElx0wvVPR4gM3L1QLhc2Vb900ahs2ShSe0hkbZHoR YpdyswZWteED9rz0mRO1eHFJ1OveYGCO6Nwwg3yK2UZoa4N/s3agUcHSVGqzIsfMjzG03bsl+03 RAzEkUCzJDn+2DrDZHsDfn6vg7udjGfnUWcTD0Q== X-Google-Smtp-Source: AGHT+IHJY2+Iu5/ZCrQhN30ZiNCuSASP+yxwATfMVVQ3sv7C0arcFaEGGwNJUmVc3lt98Z3OItIYbE6qOWMXRbDN1Ck= X-Received: by 2002:a05:6402:1497:b0:55a:4e80:5b0e with SMTP id e23-20020a056402149700b0055a4e805b0emr93671edv.68.1705689379727; Fri, 19 Jan 2024 10:36:19 -0800 (PST) List-Id: Commit messages for the main branch of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-main List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-main@freebsd.org X-BeenThere: dev-commits-src-main@freebsd.org MIME-Version: 1.0 References: <2A5657AE-C55D-492A-9013-9CFE1F80ED9C@gmail.com> In-Reply-To: <2A5657AE-C55D-492A-9013-9CFE1F80ED9C@gmail.com> From: Warner Losh Date: Fri, 19 Jan 2024 11:36:08 -0700 Message-ID: Subject: Re: git: 8bae22bbbe65 - main - fusefs: prefer new/delete over malloc/free To: Enji Cooper Cc: John Baldwin , Alan Somers , src-committers@freebsd.org, dev-commits-src-all@freebsd.org, dev-commits-src-main@freebsd.org Content-Type: multipart/alternative; boundary="000000000000937bef060f50c177" X-Rspamd-Queue-Id: 4TGpGs0866z4gKk X-Spamd-Bar: ---- X-Rspamd-Pre-Result: action=no action; module=replies; Message is reply to one we originated X-Spamd-Result: default: False [-4.00 / 15.00]; REPLY(-4.00)[]; ASN(0.00)[asn:15169, ipnet:2a00:1450::/32, country:US] --000000000000937bef060f50c177 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable On Fri, Jan 19, 2024 at 11:24=E2=80=AFAM Enji Cooper wrote: > > > On Jan 19, 2024, at 10:15, John Baldwin wrote: > > > > =EF=BB=BFOn 1/19/24 7:38 AM, Alan Somers wrote: > >>> On Fri, Jan 19, 2024 at 6:56=E2=80=AFAM Alan Somers > wrote: > >>> > >>> On Thu, Jan 18, 2024 at 10:32=E2=80=AFPM Enji Cooper > wrote: > >>>> > >>>> > >>>>> On Jan 17, 2024, at 2:50=E2=80=AFPM, Alan Somers > wrote: > >>>>> > >>>>> The branch main has been updated by asomers: > >>>>> > >>>>> URL: > https://cgit.FreeBSD.org/src/commit/?id=3D8bae22bbbe6571da9259e0d43ffa8a5= 6f4b3e171 > >>>>> > >>>>> commit 8bae22bbbe6571da9259e0d43ffa8a56f4b3e171 > >>>>> Author: Alan Somers > >>>>> AuthorDate: 2024-01-15 23:49:47 +0000 > >>>>> Commit: Alan Somers > >>>>> CommitDate: 2024-01-17 22:49:41 +0000 > >>>>> > >>>>> fusefs: prefer new/delete over malloc/free > >>>>> > >>>>> MFC after: 2 weeks > >>>>> Reviewed by: kib > >>>>> Differential Revision: https://reviews.freebsd.org/D43464 > >>>> > >>>> Why not use smart pointers instead? > >>>> -Enji > >>> > >>> Only because this stuff all evolved from C code. Smart pointers woul= d > >>> certainly work. > >> Actually, TBH it's because I'm not real great with C++. It's a > >> difficult language, and after 2016 I stopped even trying to improve my > >> C++ skills. Instead, I've been focusing on Rust. Even when I wrote > >> these tests in 2019, I strongly considered using Rust instead of C++. > >> In the end, the only thing that forced me to use C++ is because I > >> wanted them to live in the base system, rather than in ports. > >> I still dream about the day when Rust is allowed in the base system. > >> If it were, then in addition to these tests, I would've converted > >> gstat to Rust (rather than add sysutils/gstat-rs to ports), added the > >> nfs-exporter (instead of putting it in net-mgmt/nfs-exporter), added a > >> ctl-exporter (which is impossible to do in ports, so I had to do that > >> one in C), and converted tools/regression/fsx in place (instead of > >> putting in devel/fsx-rs). Maybe a couple of other things, too. Like > >> ztop, or the geom-exporter that I have half-written. I've also been > >> tempted to rewrite zfsd in Rust. > >> Alas, I sense that there is little appetite for bringing Rust into > contrib. > > > > Brooks' opinion is that to support Rust in base we probably need to > require > > always using an external toolchain as otherwise we would need to keep t= wo > > copies of LLVM in base. > > Based on my recent adventures with this, I concur. Our version of LLVM in > base is not compatible with the copy rust needs, so rust would always nee= d > to be bootstrapped with world. > > It would need to be a full toolchain as well to build all of the rust > targets. Using llvm built for a single target would only function as the > initial bootstrap toolchain. > > Finally, the bootstrap compiler (via rustup) has tight requirements aroun= d > versioning and is precompiled for the host. It turns into a nightmare if > new syscall support is added or if compat support is required to run the > binary=E2=80=A6 > > We=E2=80=99d be better off importing golang instead of rust. > I have no problems supporting rust via an external toolchain, but I'd also view that support to be provisional: Show us what can be done better and the niggling issues that one hits around toolchain stuff somehow is paid for with something that's way cooler than we could otherwise have. Tests seem like a natural first step in that. I mean, if we can't even support tests without it being a hassle, then it's a complete no-go. If we can, then what else can we support? For more ambitious things, there's always ports and the base / ports distinction is likely to fade somewhat as pkgbase becomes more mature. Warner --000000000000937bef060f50c177 Content-Type: text/html; charset="UTF-8" Content-Transfer-Encoding: quoted-printable


=
On Fri, Jan 19, 2024 at 11:24=E2=80= =AFAM Enji Cooper <yaneurabeya@= gmail.com> wrote:

> On Jan 19, 2024, at 10:15, John Baldwin <jhb@freebsd.org> wrote:
>
> =EF=BB=BFOn 1/19/24 7:38 AM, Alan Somers wrote:
>>> On Fri, Jan 19, 2024 at 6:56=E2=80=AFAM Alan Somers <asomers@freebsd.org&= gt; wrote:
>>>
>>> On Thu, Jan 18, 2024 at 10:32=E2=80=AFPM Enji Cooper <yaneurabeya@gmail.com= > wrote:
>>>>
>>>>
>>>>> On Jan 17, 2024, at 2:50=E2=80=AFPM, Alan Somers <a= somers@FreeBSD.org> wrote:
>>>>>
>>>>> The branch main has been updated by asomers:
>>>>>
>>>>> URL: https://cgit.FreeBSD.org/src/commit/?id=3D8bae22bbbe6571da9259e0d43= ffa8a56f4b3e171
>>>>>
>>>>> commit 8bae22bbbe6571da9259e0d43ffa8a56f4b3e171
>>>>> Author:=C2=A0 =C2=A0 =C2=A0Alan Somers <asomers@Fre= eBSD.org>
>>>>> AuthorDate: 2024-01-15 23:49:47 +0000
>>>>> Commit:=C2=A0 =C2=A0 =C2=A0Alan Somers <asomers@Fre= eBSD.org>
>>>>> CommitDate: 2024-01-17 22:49:41 +0000
>>>>>
>>>>>=C2=A0 =C2=A0 fusefs: prefer new/delete over malloc/fre= e
>>>>>
>>>>>=C2=A0 =C2=A0 MFC after:=C2=A0 =C2=A0 =C2=A0 2 weeks >>>>>=C2=A0 =C2=A0 Reviewed by:=C2=A0 =C2=A0 kib
>>>>>=C2=A0 =C2=A0 Differential Revision: https://r= eviews.freebsd.org/D43464
>>>>
>>>> Why not use smart pointers instead?
>>>> -Enji
>>>
>>> Only because this stuff all evolved from C code.=C2=A0 Smart p= ointers would
>>> certainly work.
>> Actually, TBH it's because I'm not real great with C++.=C2= =A0 It's a
>> difficult language, and after 2016 I stopped even trying to improv= e my
>> C++ skills.=C2=A0 Instead, I've been focusing on Rust.=C2=A0 E= ven when I wrote
>> these tests in 2019, I strongly considered using Rust instead of C= ++.
>> In the end, the only thing that forced me to use C++ is because I<= br> >> wanted them to live in the base system, rather than in ports.
>> I still dream about the day when Rust is allowed in the base syste= m.
>> If it were, then in addition to these tests, I would've conver= ted
>> gstat to Rust (rather than add sysutils/gstat-rs to ports), added = the
>> nfs-exporter (instead of putting it in net-mgmt/nfs-exporter), add= ed a
>> ctl-exporter (which is impossible to do in ports, so I had to do t= hat
>> one in C), and converted tools/regression/fsx in place (instead of=
>> putting in devel/fsx-rs).=C2=A0 Maybe a couple of other things, to= o.=C2=A0 Like
>> ztop, or the geom-exporter that I have half-written.=C2=A0 I'v= e also been
>> tempted to rewrite zfsd in Rust.
>> Alas, I sense that there is little appetite for bringing Rust into= contrib.
>
> Brooks' opinion is that to support Rust in base we probably need t= o require
> always using an external toolchain as otherwise we would need to keep = two
> copies of LLVM in base.

Based on my recent adventures with this, I concur. Our version of LLVM in b= ase is not compatible with the copy rust needs, so rust would always need t= o be bootstrapped with world.

It would need to be a full toolchain as well to build all of the rust targe= ts. Using llvm built for a single target would only function as the initial= bootstrap toolchain.

Finally, the bootstrap compiler (via rustup) has tight requirements around = versioning and is precompiled for the host. It turns into a nightmare if ne= w syscall support is added or if compat support is required to run the bina= ry=E2=80=A6

We=E2=80=99d be better off importing golang instead of rust.

I have no problems supporting rust via an external to= olchain, but I'd also view that support
to be provisional: Sh= ow us what can be done better and the niggling issues that one hits
around toolchain stuff somehow is paid for with something that's way= cooler than we could
otherwise have. Tests seem like a natural f= irst step in that. I mean, if we can't even support
tests wit= hout it being a hassle, then it's a complete no-go. If we can, then wha= t else can we
support? For more ambitious things, there's alw= ays ports and the base / ports distinction is
likely to fade some= what as pkgbase becomes more mature.

Warner
<= /div>
--000000000000937bef060f50c177--