From owner-svn-src-all@FreeBSD.ORG Wed Jul 10 18:05:48 2013 Return-Path: Delivered-To: svn-src-all@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by hub.freebsd.org (Postfix) with ESMTP id 54A98C11; Wed, 10 Jul 2013 18:05:48 +0000 (UTC) (envelope-from jhb@freebsd.org) Received: from bigwig.baldwin.cx (bigwig.baldwin.cx [IPv6:2001:470:1f11:75::1]) by mx1.freebsd.org (Postfix) with ESMTP id 2FFDC117A; Wed, 10 Jul 2013 18:05:48 +0000 (UTC) Received: from jhbbsd.localnet (unknown [209.249.190.124]) by bigwig.baldwin.cx (Postfix) with ESMTPSA id 3288DB948; Wed, 10 Jul 2013 14:05:45 -0400 (EDT) From: John Baldwin To: Marcel Moolenaar Subject: Re: svn commit: r253161 - head/sys/dev/uart Date: Wed, 10 Jul 2013 14:05:43 -0400 User-Agent: KMail/1.13.5 (FreeBSD/8.2-CBSD-20110714-p25; KDE/4.5.5; amd64; ; ) References: <201307101742.r6AHgKOm024113@svn.freebsd.org> In-Reply-To: <201307101742.r6AHgKOm024113@svn.freebsd.org> MIME-Version: 1.0 Content-Type: Text/Plain; charset="utf-8" Content-Transfer-Encoding: 7bit Message-Id: <201307101405.44158.jhb@freebsd.org> X-Greylist: Sender succeeded SMTP AUTH, not delayed by milter-greylist-4.2.7 (bigwig.baldwin.cx); Wed, 10 Jul 2013 14:05:45 -0400 (EDT) Cc: svn-src-head@freebsd.org, svn-src-all@freebsd.org, src-committers@freebsd.org X-BeenThere: svn-src-all@freebsd.org X-Mailman-Version: 2.1.14 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: Wed, 10 Jul 2013 18:05:48 -0000 On Wednesday, July 10, 2013 1:42:20 pm Marcel Moolenaar wrote: > Author: marcel > Date: Wed Jul 10 17:42:20 2013 > New Revision: 253161 > URL: http://svnweb.freebsd.org/changeset/base/253161 > > Log: > Protect against broken hardware. In this particular case, protect against > H/W not de-asserting the interrupt at all. On x86, and because of the > following conditions, this results in a hard hang with interrupts disabled: > 1. The uart(4) driver uses a spin lock to protect against concurrent > access to the H/W. Spin locks disable and restore interrupts. > 2. Restoring the interrupt on x86 always writes the flags register. Even > if we're restoring the interrupt from disabled to disabled. > 3. The x86 CPU has a short window in which interrupts are enabled when the > flags register is written. Do you have proof of this? I have never seen anything like this documented. It would be fundamentally broken if true. In fact, if anything the evidence I have seen is the exact opposite: that Intel is very careful to prevent races of this sort. Specifically, Intel CPUs have long had a feature of disabling interrupts for the instruction following POP SS to permit atomic loads of SS:ESP (for code that doesn't use LSS). I highly doubt your claim is true. In fact, I think you might be confused by the VME bits (VIP and VIF). The POPF instruction is documented to clear VIP and VIF, but those flags only matter when operating in virtual 86 mode. They are not relevant to our kernel. I think you need to find a real explanation for the hang you are seeing. -- John Baldwin