From owner-freebsd-arch@FreeBSD.ORG Thu Nov 25 02:36:46 2010 Return-Path: Delivered-To: freebsd-arch@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id A82F01065694; Thu, 25 Nov 2010 02:36:46 +0000 (UTC) (envelope-from kabaev@gmail.com) Received: from mail-qw0-f54.google.com (mail-qw0-f54.google.com [209.85.216.54]) by mx1.freebsd.org (Postfix) with ESMTP id 3973C8FC0C; Thu, 25 Nov 2010 02:36:45 +0000 (UTC) Received: by qwb8 with SMTP id 8so442062qwb.13 for ; Wed, 24 Nov 2010 18:36:45 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:received:received:date:from:to:cc:subject :message-id:in-reply-to:references:x-mailer:mime-version :content-type; bh=ktgSnwTTnfqILV4flf6rVAL3cxy6ZL1etkBt4lfJdFw=; b=tl7KjVRwPEbu9FFsDwX1Ash9cfiMsYk16lg+57lYy3mAKjJiBnjZ2U3Ixbg6fTMpPD 3Yl1j04v4gIWoV1RL9iaT+0zY1nqTkee/0FssuqfUvQWKWjS4RULb+Xb10s6ZUWtv+CA Q+nqJtH4zDH89kGabQ/w8MH1gz7+RK43y4GAk= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=date:from:to:cc:subject:message-id:in-reply-to:references:x-mailer :mime-version:content-type; b=X7PY3UPdfM3O8aHNSCCpft+r505PbrBamvWDq00XGJM9XZPucm1uuLZm0meiD/SyKH aV3/S2+afvCANXN8hd4RMgGUiS52UMhUmN4CJBHfeNTULSXH1NOw53SfaRtBEUj56vgn JojjB2IWBHGM33sm1ShVHEKrKyYAhuYDa1Yp4= Received: by 10.229.222.194 with SMTP id ih2mr141144qcb.140.1290652605310; Wed, 24 Nov 2010 18:36:45 -0800 (PST) Received: from kan.dnsalias.net (c-24-63-226-98.hsd1.ma.comcast.net [24.63.226.98]) by mx.google.com with ESMTPS id t17sm151424qcp.38.2010.11.24.18.36.44 (version=SSLv3 cipher=RC4-MD5); Wed, 24 Nov 2010 18:36:44 -0800 (PST) Date: Wed, 24 Nov 2010 21:36:27 -0500 From: Alexander Kabaev To: mdf@FreeBSD.org Message-ID: <20101124213627.2d95840f@kan.dnsalias.net> In-Reply-To: References: <20101124184934.35b6766a@kan.dnsalias.net> X-Mailer: Claws Mail 3.7.6 (GTK+ 2.20.1; amd64-portbld-freebsd9.0) Mime-Version: 1.0 Content-Type: multipart/signed; micalg=PGP-SHA1; boundary="Sig_/vvhl+h.8WdHpfPo9wmi7wz0"; protocol="application/pgp-signature" Cc: freebsd-arch@freebsd.org Subject: Re: LOR with sysctl lock X-BeenThere: freebsd-arch@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussion related to FreeBSD architecture List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 25 Nov 2010 02:36:46 -0000 --Sig_/vvhl+h.8WdHpfPo9wmi7wz0 Content-Type: text/plain; charset=KOI8-R Content-Transfer-Encoding: quoted-printable On Wed, 24 Nov 2010 17:23:04 -0800 mdf@FreeBSD.org wrote: > On Wed, Nov 24, 2010 at 3:49 PM, Alexander Kabaev > wrote: > > On Wed, 24 Nov 2010 11:53:58 -0800 > > mdf@FreeBSD.org wrote: > > > >> The sysctl lock can cause "random" LOR warnings. =9AThese usually > >> show on reboot/shutdown when sysctl_ctx_free() is called by a > >> kernel module, since the mod handler is called with the module > >> lock. =9AThe reason for the LOR is that, at least theoretically, the > >> sysctl lock is the first lock in any hierarchy, because a > >> SYSCTL_PROC handler can take any locks it wants, and will be > >> called with the sysctl lock held shared. > >> > >> The below patch will fix the problem generically and with no > >> changes to other code. =9AI slightly prefer this to an explicit > >> sysctl_ctx_free_sched(9), because many times code doesn't know if > >> some caller holds *any* lock at all; this is especially true for > >> mod handlers who shouldn't be expected to know how FreeBSD locks > >> calls to the handler. > >> > >> I also note that the return value from sysctl_ctx_free(9) is almost > >> never checked on CURRENT, and the only places it is, the value is > >> merely used to print a warning. =9AThe only exception is > >> canbus_detach() in pc98/pc98/canbus.c. =9ASo I wonder if > >> sysctl_ctx_free(9) should return void and print a warning itself. > >> > >> Patch: > >> http://people.freebsd.org/~mdf/0001-Proposed-patch-to-fix-LORs-with-sy= sctl-lock.patch > >> > >> If there are no objections, I'd like to commit this next week. > >> > >> Thanks, > >> matthew > > > > Correct me if I am wrong, but doesn't this open a race where, say, > > device detach routine destroys the device softc and schedules sysctl > > context to be destroyed asynchronously via task queue? Since sysctl > > entries are still visible in between the point where softc is > > destroyed and the point where task queue picks the sysctl destroy > > task up, can any access to said sysctls potentially operate on now > > freed softc data? >=20 > D'oh, yeah. >=20 > I'm thinking of something a little more grand, now, that increments a > hold count on the sysctl oid and releases the lock before calling the > handler. This would prevent the LOR, and allow sysctl_ctx_free(9) to > be run in-line, but it would then have to wait for any in progress > sysctl calls to an oid to drain. >=20 > I think this will work out; I'm planning to work on the code over the > Thanksgiving holiday and have something ready in a few days. >=20 > Thanks, > matthew This sounds like a useful strategy, but I think you are attacking wrong problem here. The linker running initialization code code under lock is problematic and something like mutex to protect linker module lists and some kind of gate with global flag allowing only one thread into module load/unload code path should address the same annoying LOR as well and possibly many more. Having sysctl handlers running outside of sysctl lock is still a very worthwhile goal IMHO. --=20 Alexander Kabaev --Sig_/vvhl+h.8WdHpfPo9wmi7wz0 Content-Type: application/pgp-signature; name=signature.asc Content-Disposition: attachment; filename=signature.asc -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.16 (FreeBSD) iD8DBQFM7cu7Q6z1jMm+XZYRAgnAAKCuWEnBWpjGsVJudCxgALnWnz/8zgCfcUHZ hccRwnOS/3g0PFurSdJbHe4= =oH2w -----END PGP SIGNATURE----- --Sig_/vvhl+h.8WdHpfPo9wmi7wz0--