Date: Wed, 20 Jan 2010 18:05:54 +0200 From: David Naylor <naylor.b.david@gmail.com> To: gary.jennejohn@freenet.de Cc: freebsd-current@freebsd.org Subject: Re: stacked unionfs freeze and crash FreeBSD Message-ID: <201001201805.57798.naylor.b.david@gmail.com> In-Reply-To: <20100120162821.3f53af6a@ernst.jennejohn.org> References: <201001201543.15818.naylor.b.david@gmail.com> <20100120162821.3f53af6a@ernst.jennejohn.org>
next in thread | previous in thread | raw e-mail | index | archive | help
--nextPart20388899.MH42N7fnO0
Content-Type: multipart/mixed;
boundary="Boundary-01=_inyVL6GVTrfFMMh"
Content-Transfer-Encoding: 7bit
--Boundary-01=_inyVL6GVTrfFMMh
Content-Type: Text/Plain;
charset="us-ascii"
Content-Transfer-Encoding: quoted-printable
Content-Disposition: inline
On Wednesday 20 January 2010 17:28:21 Gary Jennejohn wrote:
> On Wed, 20 Jan 2010 15:43:12 +0200 David Naylor wrote:
> > Hi,
> >
> > The attached script, that uses stacked unionfs, causes FreeBSD-9 (cvsup
> > yesterday) to freeze and FreeBSD-8 (cvsup two days ago) to crash:
> >
> > Fatal double fault
> > rip-0xffffffff81e4c1
> > rsp=3D0xffffff80b133ef50
> > rbp=3D0xffffff80b133f150
> > cupid =3D 2; apic id =3D 02
> > panic: double fault
> > cpuid =3D 2
> > uptime: 1h44m35s
> > cannot dump. Device not defined or unavailable
> >
> >
> > Both systems use the stock GENERIC kernel, i.e. -9 had full diagnostics
> > built in (and was run under VirtualBox) and -8 had no diagnostics (and
> > was run native).
> >
> > A LOR is produces prior to freezing under -9 (quiet a time prior). See
> > kern/141950.
> >
> > The script uses unionfs to build ports (in an attempt to create a
> > tinderbox without the need to delete and/or extract packages). To use
> > the script to:
> >
> > # mkdir /tmp/localbase /tmp/builddir
> > # env LOCALBASE=3D/tmp/localbase BUILDDIR=3D/tmp/builddir
> > ./ports-union-builder.sh
>=20
> Is your /tmp big enough?
I was actually using /home, didn't think people wanted to contaminate that=
=20
directory. Plenty of space. =20
> > This will try build everything for x11/xorg.
> >
> > Is it possible that VirtualBox is interfering in getting usable
> > diagnostics for -9
>=20
> Who knows? You might try posting your shell script so others can give
> it a whirl on a "real" 9-current system.
I did attach the script. Guess mailer ate it, again. I'll try again... =20
> > and how can I setup a dump device for -8. Currently I have:
> >
> > # swapinfo
> > Device 1K-blocks Used Avail Capacity
> > /dev/ad4s1b 8388608 0 8388608 0%
> > /dev/ad8s1b 8388608 0 8388608 0%
> > Total 16777216 0 16777216 0%
>=20
> Do you have dumpdev defined in /etc/rc.conf and/or do you see
> /dev/dumpdev? Having /dev/dumpdev indicates that dumpon succeeded.
No I haven't and no I don't. I thought it automatically used swap? =20
I'll 'activate' it and post the results. =20
> Do you have less than 8GB of memory? See dumpon(8) for restrictions.
I have 6GB. =20
--Boundary-01=_inyVL6GVTrfFMMh
Content-Type: text/plain; charset="ISO-8859-1"; name="ports-union-builder.txt"
Content-Transfer-Encoding: 7bit
Content-Disposition: attachment;
filename="ports-union-builder.txt"
#!/bin/sh
BUILDDIR=${BUILDDIR:-/usr/build}
LOCALBASE=${LOCALBASE:-/usr/local}
PORTSDIR=${PORTSDIR:-/usr/ports}
PORT_DBDIR=${PKG_DBDIR:-$BUILDDIR/db_ports}
PKG_DBDIR=${PKG_DBDIR:-$BUILDDIR/db_pkg}
PACKAGES=${PACKAGES:-$BUILDDIR/packages}
MAKE="env LOCALBASE=$LOCALBASE PORTSDIR=$PORTSDIR PORT_DBDIR=$PORT_DBDIR PKG_DBDIR=$PKG_DBDIR PACKAGES=$PACKAGES make"
set -e
mkdir -p $BUILDDIR $LOCALBASE $PKG_DBDIR $PACKAGES
port2name() {
echo $1 | sed 's|[/.-]|_|g'
}
port2pkg() {
local pkg_name=
local port=
port=$1; shift
eval pkg_name=PKG$(port2name $port)
eval pkg=\$$pkg_name
if [ -z "$pkg" ]
then
pkg=$($MAKE -C $port -V PKGNAME)
eval $pkg_name=$pkg
fi
}
depends() {
local depend=
local depends_name=
local _deps=
local name=
local port=
port=$1
eval depends_name=DEPEND$(port2name $port)
eval deps=\"\$$depends_name\"
if [ -z "$deps" ]
then
echo "Getting dependancies for $port" > /dev/stderr
depend_list="$($MAKE -C $port -V BUILD_DEPENDS -V LIB_DEPENDS -V RUN_DEPENDS)"
for depend in $depend_list
do
name=$(echo $depend | cut -f 2 -d ':')
depends $name
_deps="$_deps $deps $name"
done
deps=$(for depend in $_deps
do
echo $depend
done | sort -u)
depends_name=$depends_name
eval $depends_name=\"$deps \"
fi
}
build() {
local _deps=
local dep=
local port=
port=$1
depends $port
_deps="$deps"
for dep in $_deps
do
port2pkg $dep
if [ ! -d $BUILDDIR/$pkg ]
then
if ! build $dep
then
echo "Port $port failed due to dependancy $dep"
return 255
fi
fi
done
echo "Building port $port..."
for pkg in $_deps
do
port2pkg $pkg
mount -t unionfs -r -o noatime $BUILDDIR/$pkg $LOCALBASE
done
port2pkg $port
mkdir -p $BUILDDIR/$pkg
mount -t unionfs -o noatime $BUILDDIR/$pkg $LOCALBASE
set +e
trap "true" INT TERM EXIT
$MAKE -C $port clean build install package -DNO_DEPENDS -DBATCH
status=$?
trap - INT TERM EXIT
set -e
umount $LOCALBASE
for pkg in $(echo $_deps | sort -r)
do
#port2pkg $pkg
umount $LOCALBASE
done
if [ $status -ne 0 ]
then
echo "Port $port failed to build"
rm -rf $BUILDDIR/$pkg || (chflags -R 0 $BUILDDIR/$pkg; rm -rf $BUILDDIR/$pkg)
else
$MAKE -C $port clean
fi
return $status
}
build /usr/ports/x11/xorg
--Boundary-01=_inyVL6GVTrfFMMh--
--nextPart20388899.MH42N7fnO0
Content-Type: application/pgp-signature; name=signature.asc
Content-Description: This is a digitally signed message part.
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v2.0.13 (FreeBSD)
iEYEABECAAYFAktXKeUACgkQUaaFgP9pFrIk7wCcDx86bUEgStouDH3kPTtSB+Vc
/dQAn1fpKB81Svy1F2UJr9O4WN8hxBt9
=nFC2
-----END PGP SIGNATURE-----
--nextPart20388899.MH42N7fnO0--
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201001201805.57798.naylor.b.david>
