From nobody Sun May 12 15:28:29 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 4Vcmjl1bpLz5KCmG for ; Sun, 12 May 2024 15:28:43 +0000 (UTC) (envelope-from wlosh@bsdimp.com) Received: from mail-lf1-x12b.google.com (mail-lf1-x12b.google.com [IPv6:2a00:1450:4864:20::12b]) (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 4Vcmjk6sv6z4KZ4 for ; Sun, 12 May 2024 15:28:42 +0000 (UTC) (envelope-from wlosh@bsdimp.com) Authentication-Results: mx1.freebsd.org; none Received: by mail-lf1-x12b.google.com with SMTP id 2adb3069b0e04-51f3761c96aso4095951e87.3 for ; Sun, 12 May 2024 08:28:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bsdimp-com.20230601.gappssmtp.com; s=20230601; t=1715527721; x=1716132521; 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=5Gk+rpmYFC5wAfbmMHFf7iZXwXAUf96HL5UNHOTFS1U=; b=xdeI+C7jV6coyZpmjjlw6pNW04Fwr/JQxWLo9biSKGxBMAdgRbZalPRdkwaNss2YZT +eUr4C5msh/NSjl7S9Qp/+eV+7y7Hty8Eb9mtZfjrEn3tzvnqzRtmXNBBB+X+i+58HVo 8WAGQa+lgKxZLCYr5k9W0j0X9vA5BkcnVpELb3U0VKUM+tSRmvxvzMfzzq5B2JwWDeyg 9Ct+ky52MvoGyxrq3EKOXoS8NnKj5G+RlyyFejW1trJW310NmrNLznfW/o/w2oOGhLC+ LbIn6bbaO+T6uJ5Gatr1OaBGjWsg5gVttF9A24XWfHs4QPBr+QwfCFhR7ALPW6GS0QE0 /nFw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1715527721; x=1716132521; 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=5Gk+rpmYFC5wAfbmMHFf7iZXwXAUf96HL5UNHOTFS1U=; b=feAFH58Md+xHybsW+VgqWSEribGqVv0Mwaio9EFryL0P6nMbVqcn6efPsaojzWcu+x AxQ12Zmr0Jc722+UAx6WfC1lSCAqn/BT4pK7l41VlrHD5KeeDeAMbqoufUqhLnCYHTkP +cUSkEUXgGBCdf2P9Nc7f0AjnL3S/OHViXSlsIwnDJsQyyWqOGPstGcwNB1VugUhVbMp Ogl4ExS3HFPHgjoJAgGjmCB5ZrSMF6bt5G0pfMOFSvmfgJkR6uQ4+jywT2QjNtZrZ+Rm UZad/s03MVtE5CyFzQVW+3lcXxbBQoDS6QqFVsyvs0xMWcyVrTrIaY94Gx1JeTq+GZWK jWWA== X-Forwarded-Encrypted: i=1; AJvYcCVfSJDZ6euwUEWZgYXnP/+bGMkeN2JZurqp5W6GsCcWGiobt416yECdH9ynjqaEqhgrlVaAoyZh18pgwS/H9t5kT8LSd2rayOCyMRqi116X3w== X-Gm-Message-State: AOJu0Yxg1L2g6iUPQfjD+133fPmjqFx/RqvRJfqEGiUjvv6FagdaFoKe y+iY1rx86xBmiJJyl/bqlLQ5UaLv9ZQBgfnfPYkeVVfb6+4QWkzyiUbA2rHJuRtAfcRxJXoo7aE 98WKCR7jUsr/kN85apLxpx5YzM1R6iWBZzXV1BQ== X-Google-Smtp-Source: AGHT+IFWsGaNX8Yx0ntVP8sZJRPz2KaVAuIW6Dn1GcjLKLPRA7pwEDkbDyhHBHJ0dtXs00Stuw+72I9GxVPKWoQ6n90= X-Received: by 2002:a05:6512:3987:b0:51a:f48d:7b31 with SMTP id 2adb3069b0e04-5220fc6e5e9mr7997300e87.13.1715527720556; Sun, 12 May 2024 08:28:40 -0700 (PDT) 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: X-BeenThere: dev-commits-src-main@freebsd.org Sender: owner-dev-commits-src-main@FreeBSD.org MIME-Version: 1.0 References: <202405111939.44BJdIE5045793@gitrepo.freebsd.org> In-Reply-To: From: Warner Losh Date: Sun, 12 May 2024 09:28:29 -0600 Message-ID: Subject: Re: git: 099a81a4173b - main - linprocfs: Add support for proc/sysvipc/{msg,sem,shm} To: Konstantin Belousov Cc: Warner Losh , src-committers@freebsd.org, dev-commits-src-all@freebsd.org, dev-commits-src-main@freebsd.org Content-Type: multipart/alternative; boundary="00000000000062fc600618436ce4" 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] X-Rspamd-Queue-Id: 4Vcmjk6sv6z4KZ4 --00000000000062fc600618436ce4 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable On Sun, May 12, 2024 at 5:36=E2=80=AFAM Konstantin Belousov wrote: > On Sat, May 11, 2024 at 07:39:18PM +0000, Warner Losh wrote: > > The branch main has been updated by imp: > > > > URL: > https://cgit.FreeBSD.org/src/commit/?id=3D099a81a4173bc5b121e50d4e27ea5fa= fdda8475b > > > > commit 099a81a4173bc5b121e50d4e27ea5fafdda8475b > > Author: Ricardo Branco > > AuthorDate: 2024-05-04 13:38:20 +0000 > > Commit: Warner Losh > > CommitDate: 2024-05-11 19:37:47 +0000 > > > > linprocfs: Add support for proc/sysvipc/{msg,sem,shm} > > > > Signed-off-by: Ricardo Branco > > Reviewed by: imp > > Pull Request: https://github.com/freebsd/freebsd-src/pull/1218 > > --- > > sys/compat/linprocfs/linprocfs.c | 182 > +++++++++++++++++++++++++++++++++++++++ > > 1 file changed, 182 insertions(+) > > > > diff --git a/sys/compat/linprocfs/linprocfs.c > b/sys/compat/linprocfs/linprocfs.c > > index 391d5f679ee5..a877d4065c18 100644 > > --- a/sys/compat/linprocfs/linprocfs.c > > +++ b/sys/compat/linprocfs/linprocfs.c > > @@ -126,6 +126,9 @@ > > #define P2K(x) ((x) << (PAGE_SHIFT - 10)) /* pages to kbyte= s > */ > > #define TV2J(x) ((x)->tv_sec * 100UL + (x)->tv_usec / 10000) > > > > +/* Value defined in sys/kern/sysv_shm.c */ > > +#define SHMSEG_ALLOCATED 0x0800 > > + > > /** > > * @brief Mapping of ki_stat in struct kinfo_proc to the linux state > > * > > @@ -2092,6 +2095,176 @@ linprocfs_domax_map_cnt(PFS_FILL_ARGS) > > return (0); > > } > > > > +/* > > + * Filler function for proc/sysvipc/msg > > + */ > > +static int > > +linprocfs_dosysvipc_msg(PFS_FILL_ARGS) > > +{ > > + struct msqid_kernel *msqids; > > + u_long id, msgmni; > > + size_t sz; > > + int error; > > + > > + sbuf_printf(sb, > > + "%10s %10s %4s %10s %10s %5s %5s %5s %5s %5s %5s %10s %10s > %10s\n", > > + "key", "msqid", "perms", "cbytes", "qnum", "lspid", "lrpid", > > + "uid", "gid", "cuid", "cgid", "stime", "rtime", "ctime"); > > + > > +again: > > + msgmni =3D msginfo.msgmni; > > + sz =3D sizeof(struct msqid_kernel) * msgmni; > > + msqids =3D malloc(sz, M_TEMP, M_NOWAIT); > Why M_NOWAIT? What does prevent us from waiting there? > Oh, I missed that in my review. It should just be wait. You are right. > > + if (msqids =3D=3D NULL) > > + return (ENOMEM); > > + if (msgmni !=3D msginfo.msgmni) { > What prevents msginfo.msgmni from changing again? Otherwise, why this > check > is needed? > > (Same questions for other two similar places trimmed below). > I found other races that I commented on, but missed these somehow. I'd also bucketed the PR as simple, not in need of closer review by others, which I'll bias towards wider review more in the future. I've backed this out, as well as my "fixes" to it. You are of course correct on the uintmax_t thing... I'd internalized that rule only for [u]intXX_t, but of course it applies across the board. I don't know what I was thinking. I'll work with the submitter to tighten these things up, providing additional interfaces if necessary. Should I add you to the reviews once the preliminaries and mechanical issues are dealt with? Warner --00000000000062fc600618436ce4 Content-Type: text/html; charset="UTF-8" Content-Transfer-Encoding: quoted-printable


=
On Sun, May 12, 2024 at 5:36=E2=80=AF= AM Konstantin Belousov <kostikbel= @gmail.com> wrote:
On Sat, May 11, 2024 at 07:39:18PM +0000, Warner Losh wrote:
> The branch main has been updated by imp:
>
> URL: https://= cgit.FreeBSD.org/src/commit/?id=3D099a81a4173bc5b121e50d4e27ea5fafdda8475b<= /a>
>
> commit 099a81a4173bc5b121e50d4e27ea5fafdda8475b
> Author:=C2=A0 =C2=A0 =C2=A0Ricardo Branco <
rbranco@suse.de>
> AuthorDate: 2024-05-04 13:38:20 +0000
> Commit:=C2=A0 =C2=A0 =C2=A0Warner Losh <imp@FreeBSD.org>
> CommitDate: 2024-05-11 19:37:47 +0000
>
>=C2=A0 =C2=A0 =C2=A0linprocfs: Add support for proc/sysvipc/{msg,sem,sh= m}
>=C2=A0 =C2=A0 =C2=A0
>=C2=A0 =C2=A0 =C2=A0Signed-off-by: Ricardo Branco <rbranco@suse.de>
>=C2=A0 =C2=A0 =C2=A0Reviewed by: imp
>=C2=A0 =C2=A0 =C2=A0Pull Request: https://github= .com/freebsd/freebsd-src/pull/1218
> ---
>=C2=A0 sys/compat/linprocfs/linprocfs.c | 182 +++++++++++++++++++++++++= ++++++++++++++
>=C2=A0 1 file changed, 182 insertions(+)
>
> diff --git a/sys/compat/linprocfs/linprocfs.c b/sys/compat/linprocfs/l= inprocfs.c
> index 391d5f679ee5..a877d4065c18 100644
> --- a/sys/compat/linprocfs/linprocfs.c
> +++ b/sys/compat/linprocfs/linprocfs.c
> @@ -126,6 +126,9 @@
>=C2=A0 #define P2K(x) ((x) << (PAGE_SHIFT - 10))=C2=A0 =C2=A0 =C2= =A0 =C2=A0 =C2=A0 =C2=A0 /* pages to kbytes */
>=C2=A0 #define TV2J(x)=C2=A0 =C2=A0 =C2=A0 ((x)->tv_sec * 100UL + (x= )->tv_usec / 10000)
>=C2=A0
> +/* Value defined in sys/kern/sysv_shm.c */
> +#define SHMSEG_ALLOCATED=C2=A0 =C2=A0 =C2=A00x0800
> +
>=C2=A0 /**
>=C2=A0 =C2=A0* @brief Mapping of ki_stat in struct kinfo_proc to the li= nux state
>=C2=A0 =C2=A0*
> @@ -2092,6 +2095,176 @@ linprocfs_domax_map_cnt(PFS_FILL_ARGS)
>=C2=A0 =C2=A0 =C2=A0 =C2=A0return (0);
>=C2=A0 }
>=C2=A0
> +/*
> + * Filler function for proc/sysvipc/msg
> + */
> +static int
> +linprocfs_dosysvipc_msg(PFS_FILL_ARGS)
> +{
> +=C2=A0 =C2=A0 =C2=A0struct msqid_kernel *msqids;
> +=C2=A0 =C2=A0 =C2=A0u_long id, msgmni;
> +=C2=A0 =C2=A0 =C2=A0size_t sz;
> +=C2=A0 =C2=A0 =C2=A0int error;
> +
> +=C2=A0 =C2=A0 =C2=A0sbuf_printf(sb,
> +=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0"%10s %10s %4s=C2=A0 %10s %10s= %5s %5s %5s %5s %5s %5s %10s %10s %10s\n",
> +=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0"key", "msqid",= "perms", "cbytes", "qnum", "lspid"= , "lrpid",
> +=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0"uid", "gid", &= quot;cuid", "cgid", "stime", "rtime", &q= uot;ctime");
> +
> +again:
> +=C2=A0 =C2=A0 =C2=A0msgmni =3D msginfo.msgmni;
> +=C2=A0 =C2=A0 =C2=A0sz =3D sizeof(struct msqid_kernel) * msgmni;
> +=C2=A0 =C2=A0 =C2=A0msqids =3D malloc(sz, M_TEMP, M_NOWAIT);
Why M_NOWAIT?=C2=A0 What does prevent us from waiting there?

Oh, I missed that in my review. It should just be wai= t. You are right.
=C2=A0
> +=C2=A0 =C2=A0 =C2=A0if (msqids =3D=3D NULL)
> +=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0return (ENOMEM);
> +=C2=A0 =C2=A0 =C2=A0if (msgmni !=3D msginfo.msgmni) {
What prevents msginfo.msgmni from changing again?=C2=A0 Otherwise, why this= check
is needed?

(Same questions for other two similar places trimmed below).

I found other races that I commented on, but missed t= hese somehow. I'd also bucketed the PR as simple, not in need of closer= review by others, which I'll bias towards wider review more in the fut= ure.

I've backed this out, as well as my "= ;fixes" to it. You are of course correct on the uintmax_t thing... I&#= 39;d internalized that rule only for [u]intXX_t, but of course it applies a= cross the board. I don't know what I was thinking. I'll work with t= he submitter to tighten these things up, providing additional interfaces if= necessary. Should I add you to the reviews once the preliminaries and mech= anical issues are dealt with?

Warner
--00000000000062fc600618436ce4--