Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 17 Jun 2020 10:15:53 -0500
From:      Kyle Evans <kevans@freebsd.org>
To:        Mateusz Guzik <mjg@freebsd.org>
Cc:        src-committers <src-committers@freebsd.org>, svn-src-all <svn-src-all@freebsd.org>,  svn-src-head <svn-src-head@freebsd.org>
Subject:   Re: svn commit: r361967 - head/sys/kern
Message-ID:  <CACNAnaHLmwemMtHLNA5QwCbFxnEkVc7D-kw1TCqNLh3v5QMJQw@mail.gmail.com>
In-Reply-To: <202006091517.059FHNS9050196@repo.freebsd.org>
References:  <202006091517.059FHNS9050196@repo.freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, Jun 9, 2020 at 10:17 AM Mateusz Guzik <mjg@freebsd.org> wrote:
>
> Author: mjg
> Date: Tue Jun  9 15:17:23 2020
> New Revision: 361967
> URL: https://svnweb.freebsd.org/changeset/base/361967
>
> Log:
>   Assert on pg_jobc state.
>
>   Stolen from NetBSD.
>
> Modified:
>   head/sys/kern/kern_proc.c
>
> Modified: head/sys/kern/kern_proc.c
> ==============================================================================
> --- head/sys/kern/kern_proc.c   Tue Jun  9 14:20:16 2020        (r361966)
> +++ head/sys/kern/kern_proc.c   Tue Jun  9 15:17:23 2020        (r361967)
> @@ -751,9 +751,11 @@ pgadjustjobc(struct pgrp *pgrp, int entering)
>  {
>
>         PGRP_LOCK(pgrp);
> -       if (entering)
> +       if (entering) {
> +               MPASS(pgrp->pg_jobc >= 0);
>                 pgrp->pg_jobc++;
> -       else {
> +       } else {
> +               MPASS(pgrp->pg_jobc > 0);
>                 --pgrp->pg_jobc;
>                 if (pgrp->pg_jobc == 0)
>                         orphanpg(pgrp);

We seem to be doing something wrong here, but I'm still working on
reproducing it on a machine that actually has usable swap configured
to get a dump. I've hit one of these asserts just from hitting the
power button to shutoff from within xfce (hitting the latter branch
with pgrp->pg_jobc == 0 IIRC) and another laptop panicked sometime
overnight -- I wasn't able to catch the second one at all, because
it's hooked up to a switch that loses its mind once that laptop
panicks and it had to be rebooted before I could attend to it to
revive network for the other machines on the switch.

Thanks,

Kyle Evans



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CACNAnaHLmwemMtHLNA5QwCbFxnEkVc7D-kw1TCqNLh3v5QMJQw>