From owner-svn-src-all@FreeBSD.ORG Tue Feb 10 15:43:14 2015 Return-Path: Delivered-To: svn-src-all@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id 4250762A; Tue, 10 Feb 2015 15:43:14 +0000 (UTC) Received: from smtp3.ore.mailhop.org (smtp3.ore.mailhop.org [54.149.88.251]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 19C37E10; Tue, 10 Feb 2015 15:43:13 +0000 (UTC) Received: from [73.34.117.227] (helo=ilsoft.org) by smtp3.ore.mailhop.org with esmtpsa (TLSv1.2:DHE-RSA-AES256-GCM-SHA384:256) (Exim 4.82) (envelope-from ) id 1YLCy0-0002b7-4H; Tue, 10 Feb 2015 15:43:12 +0000 Received: from revolution.hippie.lan (revolution.hippie.lan [172.22.42.240]) by ilsoft.org (8.14.9/8.14.9) with ESMTP id t1AFh9NR081932; Tue, 10 Feb 2015 08:43:09 -0700 (MST) (envelope-from ian@freebsd.org) X-Mail-Handler: DuoCircle Outbound SMTP X-Originating-IP: 73.34.117.227 X-Report-Abuse-To: abuse@duocircle.com (see https://support.duocircle.com/support/solutions/articles/5000540958-duocircle-standard-smtp-abuse-information for abuse reporting information) X-MHO-User: U2FsdGVkX19DtXoobPm6gQbvIC+dlQaK Message-ID: <1423582989.80968.16.camel@freebsd.org> Subject: Re: svn commit: r278479 - in head: etc sys/kern From: Ian Lepore To: Adrian Chadd Date: Tue, 10 Feb 2015 08:43:09 -0700 In-Reply-To: References: <201502092313.t19NDpoS083043@svn.freebsd.org> <1516483.e0EXgdk9ur@ralph.baldwin.cx> Content-Type: text/plain; charset="us-ascii" X-Mailer: Evolution 3.12.8 FreeBSD GNOME Team Port Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Cc: "svn-src-head@freebsd.org" , "svn-src-all@freebsd.org" , "src-committers@freebsd.org" , Rui Paulo , John Baldwin X-BeenThere: svn-src-all@freebsd.org X-Mailman-Version: 2.1.18-1 Precedence: list List-Id: "SVN commit messages for the entire src tree \(except for " user" and " projects" \)" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 10 Feb 2015 15:43:14 -0000 On Tue, 2015-02-10 at 07:06 -0800, Adrian Chadd wrote: > On 10 February 2015 at 06:16, John Baldwin wrote: > > On Monday, February 09, 2015 11:13:51 PM Rui Paulo wrote: > >> Author: rpaulo > >> Date: Mon Feb 9 23:13:50 2015 > >> New Revision: 278479 > >> URL: https://svnweb.freebsd.org/changeset/base/278479 > >> > >> Log: > >> Notify devd(8) when a process crashed. > >> > >> This change implements a notification (via devctl) to userland when > >> the kernel produces coredumps after a process has crashed. > >> devd can then run a specific command to produce a human readable crash > >> report. The command is most usually a helper that runs gdb/lldb > >> commands on the file/coredump pair. It's possible to use this > >> functionality for implementing automatic generation of crash reports. > >> > >> devd(8) will be notified of the full path of the binary that crashed and > >> the full path of the coredump file. > > > > I think this is a very useful feature and I think this is fine to be in the > > tree as-is for now. My only note is that this is a bit of feature creep for > > devd (this isn't a device notification, this is a system event notification). > > As such, I think it might be worth thinking if we (collectively) want to think > > about having a separate framework at all for system event notification. You > > could possibly publish other interesting events this way. For example, Isilon > > currently has a patch to log(9) Witness LORs. I personally think it's a bit > > hackish and potentially unreliable. A much nicer interface if you want to > > capture such things would be to publish an event for each logged LOR instead. > > Machine checks are another example of something that might be nice to publish > > (though you could possibly make the case that those would not be inappropriate > > to publish via devd since actual hardware is involved). Disk and PCI errors > > are another class of thing that it would be nice to publish in an easier to > > programmaticaly parse manner. > > Cool, so someone's going to add multi-subscriber support to /dev/devctl ? > I don't see how you get that from the foregoing at all. Doing fan-out in the kernel is hard, and doing it in userland is easier, so the existing devd model could be an appropriate one to follow for a general "kernel events which are not hardware events" system. > I think devd grows these things because it's easier than teaching the > devctl interface to support multiple listeners. Until recently, devd only grew additional support for things which are device-related, modulo the zfs stuff that I don't know much about. I was under the impression that that also was device-related in some way, such as zfs reporting on device errors or attach/remove and things related to that (like health of the pool(s) affected by the device change). Maybe the zfs stuff was the beginning of the mission creep and still had enough of a device-related fig leaf to not look like creep. But there's no disguising the fact that post-processing core dumps has absolutely nothing to do with devices. -- Ian