From owner-freebsd-arch@FreeBSD.ORG Wed Aug 20 16:00:41 2014 Return-Path: Delivered-To: freebsd-arch@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [8.8.178.115]) (using TLSv1 with cipher ADH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id 6B09A71C; Wed, 20 Aug 2014 16:00:41 +0000 (UTC) Received: from bigwig.baldwin.cx (bigwig.baldwin.cx [IPv6:2001:470:1f11:75::1]) (using TLSv1 with cipher DHE-RSA-CAMELLIA256-SHA (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 40B66307F; Wed, 20 Aug 2014 16:00:41 +0000 (UTC) Received: from jhbbsd.localnet (unknown [209.249.190.124]) by bigwig.baldwin.cx (Postfix) with ESMTPSA id 28E96B9CA; Wed, 20 Aug 2014 12:00:40 -0400 (EDT) From: John Baldwin To: Bruce Evans Subject: Re: [PATCH 0/2] plug capability races Date: Wed, 20 Aug 2014 11:11:47 -0400 User-Agent: KMail/1.13.5 (FreeBSD/8.4-CBSD-20140415; KDE/4.5.5; amd64; ; ) References: <1408064112-573-1-git-send-email-mjguzik@gmail.com> <201408151031.45967.jhb@freebsd.org> <20140816102840.V1007@besplex.bde.org> In-Reply-To: <20140816102840.V1007@besplex.bde.org> MIME-Version: 1.0 Content-Type: Text/Plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit Message-Id: <201408201111.47601.jhb@freebsd.org> X-Greylist: Sender succeeded SMTP AUTH, not delayed by milter-greylist-4.2.7 (bigwig.baldwin.cx); Wed, 20 Aug 2014 12:00:40 -0400 (EDT) Cc: Robert Watson , Mateusz Guzik , Konstantin Belousov , Johan Schuijt , freebsd-arch@freebsd.org X-BeenThere: freebsd-arch@freebsd.org X-Mailman-Version: 2.1.18-1 Precedence: list List-Id: Discussion related to FreeBSD architecture List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 20 Aug 2014 16:00:41 -0000 On Friday, August 15, 2014 9:34:59 pm Bruce Evans wrote: > On Fri, 15 Aug 2014, John Baldwin wrote: > > > One thing I would like to see is for the timecounter code to be adapted to use > > the seq API instead of doing it by hand (the timecounter code is also missing > > barriers due to doing it by hand). > > Locking in the timecounter code is poor (1), but I fear a general mechanism > would be slower. Also, the timecounter code now extends into userland, > so purely kernel locking cannot work for it. The userland part is > more careful about locking than the kernel. It has memory barriers and > other pessimizations which were intentionally left out of the kernel > locking for timecounters. If these barriers are actually necessary, then > they give the silly situation that there are less races for userland > timecounting than kernel timecounting provided userland mostly does > direct accesses instead of syscalls and kernel uses of timecounters are > are infrequent enough to not race often with the userland accesses. Yes, the userland code is more correct here. The barriers are indeed missing in the kernel part, and adding them should give something equivalant to a correctly working seq API as it is doing the same thing. -- John Baldwin