From nobody Sun Jan 21 19:52:04 2024 X-Original-To: freebsd-hackers@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 4TJ3sW1x5lz57cKM for ; Sun, 21 Jan 2024 19:52:15 +0000 (UTC) (envelope-from wlosh@bsdimp.com) Received: from mail-ed1-x52f.google.com (mail-ed1-x52f.google.com [IPv6:2a00:1450:4864:20::52f]) (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 4TJ3sV50xPz4hS3 for ; Sun, 21 Jan 2024 19:52:14 +0000 (UTC) (envelope-from wlosh@bsdimp.com) Authentication-Results: mx1.freebsd.org; none Received: by mail-ed1-x52f.google.com with SMTP id 4fb4d7f45d1cf-55a87dfc3b5so1340632a12.3 for ; Sun, 21 Jan 2024 11:52:14 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bsdimp-com.20230601.gappssmtp.com; s=20230601; t=1705866733; x=1706471533; 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=rFxVAqoAQ6hMiTWUHBw1nE9DLkd23Ws8wEj3wt/5zik=; b=LHAznMlIZYFnDJYgnz6bPQNp9P2X2XbWlOgIVtN+289+6HbqJL1UwcjbZHw+QxRY41 E5QCmS66zzaU9TPOT4ARkfq2AyFos96zQLZ6lx82va8hFmQa8FLFXXGUyuP7vm1BKq1V JqoLHkqupDI0Y8fMPs6Tpvm2n0sl7Psrr6pcirFdVOEup3m4As4jJdxjWqS4i8wuZxLn ZYLcOzZHUqIDXEtbnQ27Ay/MW/DsJpys9u50ZNMBLDEvG/Sv9aEHEr+IHHBMF6hSM9UC DlwzA9VavStQm2Q4XQ+85T27JYY4Tf18eR6ZPX5VRsHBC++PMOGVDzudP7mSpcV1qV79 D8vw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1705866733; x=1706471533; 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=rFxVAqoAQ6hMiTWUHBw1nE9DLkd23Ws8wEj3wt/5zik=; b=H3YgPeOaeHq79UEUlLKNFtiGxjjg47OkpeCgF/PH3RkxP/wqn/HAEiitkQMNaDwDBN V/QGH9ZAa68JGIVr75TM69g5s8dfmoyhH9SNiO0YouM2Wb+qdIs2oVXoT0WkSCxF06DZ CdXzyeqwyPLTk4uBD2oQrRr8afAyMzDhh//kP9gY7tAELOdTKbi4G45QjRgKP4B95VFH zt4FRc+cpZcX/DwS/t0kMFDrvbKlg3is5L0xLjkwYYaHIvYH0Rw1JmvxQAYDjHuBQNiT m4qz8/sE6S299hjnbU11rVZZR+4h5oq4gK2jjxGhJPbaTlbGqnKyAELj1h/eqz+JX6Y4 eWeA== X-Gm-Message-State: AOJu0Yxivjq9513cs8/s/3d0c5O7X3DOLbSbfviKWvCBQJC4OBv7LPk2 ZB2u5xrndlmkRIMUzKW9/PB4R/2qojZep/Wd6FcSd4szlK7L+iqsJyDuHHaHKcaGfJRlfL/X6zp 1tON6tTX7SbtlsH6+wLLzx3+rzFGnOLlXfiq99g== X-Google-Smtp-Source: AGHT+IFUQMku7bB7dVZd5XJjhHJYjT/WbYkb2qT+GDd1l8UtBA0DT4iRdfGArTAZF+9oH1MiyjW/MAiMWk9lVcNWrSk= X-Received: by 2002:aa7:c553:0:b0:55a:db1:3bf7 with SMTP id s19-20020aa7c553000000b0055a0db13bf7mr1626621edr.26.1705866733347; Sun, 21 Jan 2024 11:52:13 -0800 (PST) List-Id: Technical discussions relating to FreeBSD List-Archive: https://lists.freebsd.org/archives/freebsd-hackers List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-freebsd-hackers@freebsd.org MIME-Version: 1.0 References: <1673801705774097@mail.yandex.ru> <202401210751.40L7pWEF011188@critter.freebsd.dk> <40bc1694-ee00-431b-866e-396e9d5c07a2@m5p.com> <202401211626.40LGQDim013134@critter.freebsd.dk> <4EF67303-A995-457A-990F-A4972C23EA80@FreeBSD.org> In-Reply-To: <4EF67303-A995-457A-990F-A4972C23EA80@FreeBSD.org> From: Warner Losh Date: Sun, 21 Jan 2024 12:52:04 -0700 Message-ID: Subject: Re: The Case for Rust (in the base system) To: Kristof Provost Cc: Poul-Henning Kamp , Alan Somers , George Mitchell , freebsd-hackers@freebsd.org Content-Type: multipart/alternative; boundary="000000000000acf412060f7a0c63" X-Rspamd-Queue-Id: 4TJ3sV50xPz4hS3 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)[]; TAGGED_RCPT(0.00)[freebsd]; ASN(0.00)[asn:15169, ipnet:2a00:1450::/32, country:US] --000000000000acf412060f7a0c63 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable On Sun, Jan 21, 2024 at 9:41=E2=80=AFAM Kristof Provost wr= ote: > On 21 Jan 2024, at 17:26, Poul-Henning Kamp wrote: > > Alan Somers writes: > >> * " can't be implemented unless written in rust" > >> > >> I don't think anybody has claimed this yet. But I _have_ made a > similar claim, > >> that some things can't be written in C. I'll elaborate on the project > that > >> started this thread: the fusefs test suite. When I designed the fusef= s > test > >> suite, I based it around the priniciple of Mocking. [...] > > > > Why would such a test-tool live in src rather than ports ? > > > It=E2=80=99s entirely reasonable for the test code to live in the same re= pository > as the code it tests. > > Doing otherwise would make life harder (e.g. how do you establish if a > test failure is expected with a given src version) for no good reason. > > I suspect we may be working with different views of what a test tool does > here. You may be thinking more along the lines of something like iperf, > while I=E2=80=99m thinking more of test like this one: > https://cgit.freebsd.org/src/commit?id=3D4c84c69ba308b7758d07dc8845b13922= ed667e02 > > I=E2=80=99ll take the opportunity to point out that there=E2=80=99s prece= dent for using > non-base languages in tests (e.g. Python, for the test linked above), so > using Rust code for in-tree tests looks like a reasonable way to get our > toes wet, without immediately painting ourselves into a corner if it > doesn=E2=80=99t work out. > Exactly. There will be 0 rust in base until we can build rust binaries in some way. I maintain that the first step for that is using a curated external toolchain. Tests are a good place to start because they let us stand up the tooling we need for rust, find out what the problems are, and maybe get something useful too w/o committing "all in" to rust. It's the put up or shut up moment: If the rust advocate can't be bothered to even stand this up (and I'm happy to help with that effort for the build bits) then there will be 0 rust in base because nobody cared. If that is stood up and we get tests, we'll have more data to know if it is wise to expand the experiment or close it down. In addition to being in line with tests in Python, this is in line with adapting risky technology that we've done in the past: We tried it out, kept what worked and junked what didn't. It's a risk for those wanting rust: it may be a failed experiment in which case their time is wasted. The hypothesis is that rust is useful and that tests written in rust will be easier / faster / better enough to justify the extra hassle. Let's test that hypothesis. Tests are easy enough to rewrite or do without should that hypothesis prove to be flawed. Even if all the cool kids are doing it, it doesn't mean the cool kids are wrong. We should not reject the hypothesis on that basis alone. The only way to know is to try it out and there's enough out-of-tree rust things in ports to suggest the next logical step is to put the hooks in needed to use an external toolchain to build something. This is a watered down version of write cvsupd, to be honest, but one that's testable, measurable, specific and finite. It gives us data for any follow on choices. Warner --000000000000acf412060f7a0c63 Content-Type: text/html; charset="UTF-8" Content-Transfer-Encoding: quoted-printable


=
On Sun, Jan 21, 2024 at 9:41=E2=80=AF= AM Kristof Provost <kp@freebsd.org= > wrote:
On 2= 1 Jan 2024, at 17:26, Poul-Henning Kamp wrote:
> Alan Somers writes:
>> * "<something> can't be implemented unless written = in rust"
>>
>> I don't think anybody has claimed this yet.=C2=A0 But I _have_= made a similar claim,
>> that some things can't be written in C.=C2=A0 I'll elabora= te on the project that
>> started this thread: the fusefs test suite.=C2=A0 When I designed = the fusefs test
>> suite, I based it around the priniciple of Mocking. [...]
>
> Why would such a test-tool live in src rather than ports ?
>
It=E2=80=99s entirely reasonable for the test code to live in the same repo= sitory as the code it tests.

Doing otherwise would make life harder (e.g. how do you establish if a test= failure is expected with a given src version) for no good reason.

I suspect we may be working with different views of what a test tool does h= ere. You may be thinking more along the lines of something like iperf, whil= e I=E2=80=99m thinking more of test like this one: https://cgit.freebsd.org/src/commit?id=3D= 4c84c69ba308b7758d07dc8845b13922ed667e02

I=E2=80=99ll take the opportunity to point out that there=E2=80=99s precede= nt for using non-base languages in tests (e.g. Python, for the test linked = above), so using Rust code for in-tree tests looks like a reasonable way to= get our toes wet, without immediately painting ourselves into a corner if = it doesn=E2=80=99t work out.

Exactly. T= here will be 0 rust in base until we can build rust binaries in some way. I= maintain that the first step for that is using a curated external toolchai= n. Tests are a good place to start because they let us stand up the tooling= we need for rust, find out what the problems are, and maybe get something = useful too w/o committing "all in" to rust. It's the put up o= r shut up moment: If the rust advocate can't be bothered to even stand = this up (and I'm happy to help with that effort for the build bits) the= n there will be 0 rust in base because nobody cared. If that is stood up an= d we get tests, we'll have more data to know if it is wise to expand th= e experiment or close it down. In addition to being in line with tests in P= ython, this is in line with adapting risky technology that we've done i= n the past: We tried it out, kept what worked and junked what didn't. I= t's a risk for those wanting rust: it may be a failed experiment in whi= ch case their time is wasted. The hypothesis is that rust is useful and tha= t tests written in rust will be easier / faster / better enough to justify = the extra hassle. Let's test that hypothesis. Tests are easy enough to = rewrite or do without should that hypothesis prove to be flawed.
=
Even if all the cool kids are doing it, it doesn't mean = the cool kids are wrong. We should not reject the hypothesis on that basis = alone. The only way to know is to try it out and there's enough out-of-= tree rust things in ports to suggest the next logical step is to put the ho= oks in needed to use an external toolchain to build something. This is a wa= tered down version of write cvsupd, to be honest, but one that's testab= le, measurable, specific and finite. It gives us data for any follow on cho= ices.

Warner
--000000000000acf412060f7a0c63--