From owner-svn-src-all@FreeBSD.ORG Fri Apr 3 18:55:38 2015 Return-Path: Delivered-To: svn-src-all@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [8.8.178.115]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id 9718EA62; Fri, 3 Apr 2015 18:55:38 +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 6D7402CC; Fri, 3 Apr 2015 18:55:38 +0000 (UTC) Received: from ralph.baldwin.cx (pool-173-54-116-245.nwrknj.fios.verizon.net [173.54.116.245]) by bigwig.baldwin.cx (Postfix) with ESMTPSA id 31E3AB986; Fri, 3 Apr 2015 14:55:37 -0400 (EDT) From: John Baldwin To: Konstantin Belousov Subject: Re: svn commit: r280866 - in head/sys: amd64/amd64 i386/i386 Date: Fri, 03 Apr 2015 13:20:20 -0400 Message-ID: <3872682.8P88THCPIf@ralph.baldwin.cx> User-Agent: KMail/4.14.2 (FreeBSD/10.1-STABLE; KDE/4.14.2; amd64; ; ) In-Reply-To: <20150331183856.GT2379@kib.kiev.ua> References: <201503302013.t2UKDNCo093442@svn.freebsd.org> <3149031.gmIvmB3vKt@ralph.baldwin.cx> <20150331183856.GT2379@kib.kiev.ua> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" X-Greylist: Sender succeeded SMTP AUTH, not delayed by milter-greylist-4.2.7 (bigwig.baldwin.cx); Fri, 03 Apr 2015 14:55:37 -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.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: Fri, 03 Apr 2015 18:55:38 -0000 On Tuesday, March 31, 2015 09:38:56 PM Konstantin Belousov wrote: > On Tue, Mar 31, 2015 at 12:51:04PM -0400, John Baldwin wrote: > > I don't really know if we need to increase the delays or not. I have no idea > > what Intel's source for those numbers in the two documents are. I don't think > > I've ever seen a rationale for why they were chosen. > It might beia time to run BIST + some sloppiness for the actual initialization > code. Intel claims > > 9.1.2 Processor Built-In Self-Test (BIST) > > The overhead for performing a BIST varies between processor families. > For example, the BIST takes approximately 30 million processor clock > periods to execute on the Pentium 4 processor. This clock count is > model-specific; Intel reserves the right to change the number of periods > for any Intel 64 or IA-32 processor, without notification. Interesting. > > > > BTW, Linux seems to use the equivalent of 100 milliseconds for the > > lapic_ipi_wait() stage before doing the other delays (see > > native_safe_apic_wait_icr_idle() for the non-X2APIC case). > > My main observation is that we allow almost twice as much time for AP > to start in the xAPIC mode vs. x2APIC. But increasing the delays did > not helped the machines where it fails. I don't know that it's really twice. For INIT x2APIC waits 10000 us while the xAPIC case has gone from 10020 us to 10100 us. For the STARTUP it is a bit closer in that x2APIC is 200 us while xAPIC has gone from 220 us to 300 us. Granted, the xAPIC wait is actually variable and can be as small as the x2APIC wait of the pending bit clears immediately. -- John Baldwin