Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 20 Jun 2017 20:57:28 +0200
From:      "O. Hartmann" <ohartmann@walstatt.org>
To:        "O. Hartmann" <ohartmann@walstatt.org>
Cc:        Andriy Gapon <avg@FreeBSD.org>, svn-src-head@freebsd.org, svn-src-all@freebsd.org, src-committers@freebsd.org
Subject:   Re: svn commit: r320153 - in head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs: . sys
Message-ID:  <20170620205728.55f7d1f3@thor.intern.walstatt.dynvpn.de>
In-Reply-To: <20170620205502.443284f7@thor.intern.walstatt.dynvpn.de>
References:  <201706201655.v5KGtUDS034789@repo.freebsd.org> <20170620205502.443284f7@thor.intern.walstatt.dynvpn.de>

next in thread | previous in thread | raw e-mail | index | archive | help
--Sig_/.PRtHx7.aeeXLmQSlJSCFMO
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: quoted-printable

Am Tue, 20 Jun 2017 20:55:02 +0200
"O. Hartmann" <ohartmann@walstatt.org> schrieb:

> Am Tue, 20 Jun 2017 16:55:30 +0000 (UTC)
> Andriy Gapon <avg@FreeBSD.org> schrieb:
>=20
> > Author: avg
> > Date: Tue Jun 20 16:55:30 2017
> > New Revision: 320153
> > URL: https://svnweb.freebsd.org/changeset/base/320153
> >=20
> > Log:
> >   revert r315852 which introduced zio_buf_alloc_nowait for use in vdev_=
queue_aggregate
> >  =20
> >   I think that the change is still good, but reconciling it with a plan=
ned
> >   merge of the ARC buf data scatter-ization is a bit more tedious
> >   than I can handle.
> >  =20
> >   MFC after:	17 days
> >=20
> > Modified:
> >   head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zio.h
> >   head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/vdev_queue.c
> >   head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zio.c
> >=20
> > Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zio.h
> > =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D
> > --- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zio.h	Tue J=
un 20
> > 16:45:48 2017	(r320152) +++
> > head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zio.h	Tue Jun 20
> > 16:55:30 2017	(r320153) @@ -555,7 +555,6 @@ extern zio_t
> > *zio_unique_parent(zio_t *cio); extern void zio_add_child(zio_t *pio, z=
io_t *cio);=20
> >  extern void *zio_buf_alloc(size_t size);
> > -extern void *zio_buf_alloc_nowait(size_t size);
> >  extern void zio_buf_free(void *buf, size_t size);
> >  extern void *zio_data_buf_alloc(size_t size);
> >  extern void zio_data_buf_free(void *buf, size_t size);
> >=20
> > Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/vdev_queu=
e.c
> > =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D
> > --- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/vdev_queue.c	Tu=
e Jun 20
> > 16:45:48 2017	(r320152) +++
> > head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/vdev_queue.c	Tue Ju=
n 20
> > 16:55:30 2017	(r320153) @@ -647,7 +647,6 @@ static zio_t *
> > vdev_queue_aggregate(vdev_queue_t *vq, zio_t *zio) {
> >  	zio_t *first, *last, *aio, *dio, *mandatory, *nio;
> > -	void *abuf;
> >  	uint64_t maxgap =3D 0;
> >  	uint64_t size;
> >  	boolean_t stretch;
> > @@ -766,12 +765,8 @@ vdev_queue_aggregate(vdev_queue_t *vq, zio_t *zio)
> >  	size =3D IO_SPAN(first, last);
> >  	ASSERT3U(size, <=3D, SPA_MAXBLOCKSIZE);
> > =20
> > -	abuf =3D zio_buf_alloc_nowait(size);
> > -	if (abuf =3D=3D NULL)
> > -		return (NULL);
> > -
> >  	aio =3D zio_vdev_delegated_io(first->io_vd, first->io_offset,
> > -	    abuf, size, first->io_type, zio->io_priority,
> > +	    zio_buf_alloc(size), size, first->io_type, zio->io_priority,
> >  	    flags | ZIO_FLAG_DONT_CACHE | ZIO_FLAG_DONT_QUEUE,
> >  	    vdev_queue_agg_io_done, NULL);
> >  	aio->io_timestamp =3D first->io_timestamp;
> >=20
> > Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zio.c
> > =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D
> > --- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zio.c	Tue Jun 20
> > 16:45:48 2017	(r320152) +++
> > head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zio.c	Tue Jun 20 16=
:55:30
> > 2017	(r320153) @@ -272,33 +272,18 @@ zio_fini(void)
> >   * useful to inspect ZFS metadata, but if possible, we should avoid ke=
eping
> >   * excess / transient data in-core during a crashdump.
> >   */
> > -static void *
> > -zio_buf_alloc_impl(size_t size, boolean_t canwait)
> > +void *
> > +zio_buf_alloc(size_t size)
> >  {
> >  	size_t c =3D (size - 1) >> SPA_MINBLOCKSHIFT;
> >  	int flags =3D zio_exclude_metadata ? KM_NODEBUG : 0;
> > =20
> >  	VERIFY3U(c, <, SPA_MAXBLOCKSIZE >> SPA_MINBLOCKSHIFT);
> > =20
> > -	if (zio_use_uma) {
> > -		return (kmem_cache_alloc(zio_buf_cache[c],
> > -		    canwait ? KM_PUSHPAGE : KM_NOSLEEP));
> > -	} else {
> > -		return (kmem_alloc(size,
> > -		    (canwait ? KM_SLEEP : KM_NOSLEEP) | flags));
> > -	}
> > -}
> > -
> > -void *
> > -zio_buf_alloc(size_t size)
> > -{
> > -	return (zio_buf_alloc_impl(size, B_TRUE));
> > -}
> > -
> > -void *
> > -zio_buf_alloc_nowait(size_t size)
> > -{
> > -	return (zio_buf_alloc_impl(size, B_FALSE));
> > +	if (zio_use_uma)
> > +		return (kmem_cache_alloc(zio_buf_cache[c], KM_PUSHPAGE));
> > +	else
> > +		return (kmem_alloc(size, KM_SLEEP|flags));
> >  }
> > =20
> >  /*
> > _______________________________________________
> > svn-src-head@freebsd.org mailing list
> > https://lists.freebsd.org/mailman/listinfo/svn-src-head
> > To unsubscribe, send any mail to "svn-src-head-unsubscribe@freebsd.org"=
 =20
>=20
> Running r320138, which is stable for me, My systems crash immediately whe=
n booting with
> r320158. Since I use ZFS compiled into the kernel and it seems to be the =
only change so
> far of importance involving the kernel, I suspect the ZFS changes to be t=
he source of
> the crash.
>=20
> At the moment, I have no debugging kernel running, so this guess is more =
out of the
> blue.
>=20
> Kind regards,
> Oliver
>=20

I meant r320156, not this one 9r320153) :-( Sorry. Hit the wrong line.

--=20
O. Hartmann

Ich widerspreche der Nutzung oder =C3=9Cbermittlung meiner Daten f=C3=BCr
Werbezwecke oder f=C3=BCr die Markt- oder Meinungsforschung (=C2=A7 28 Abs.=
 4 BDSG).

--Sig_/.PRtHx7.aeeXLmQSlJSCFMO
Content-Type: application/pgp-signature
Content-Description: OpenPGP digital signature

-----BEGIN PGP SIGNATURE-----

iLUEARMKAB0WIQQZVZMzAtwC2T/86TrS528fyFhYlAUCWUlwGAAKCRDS528fyFhY
lF+TAgCTduvR692gA5twjOTDwV3nKycgrS/XY5yt/q0rRYywjC7BW+aGZdRCorCv
PoL2t6rgRoQNGciCa5Lt/+xgvDANAf9/aNGMkvshViP4twitq+6SaVbHaOZdDine
kHtLoBp9R/AybK8bZk9gfyOpcuNZuNPr3W4TEk80ydTuGYfXiGsb
=abtP
-----END PGP SIGNATURE-----

--Sig_/.PRtHx7.aeeXLmQSlJSCFMO--



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