From owner-freebsd-smp Tue Feb 1 18:55:39 2000 Delivered-To: freebsd-smp@freebsd.org Received: from fw.wintelcom.net (ns1.wintelcom.net [209.1.153.20]) by builder.freebsd.org (Postfix) with ESMTP id 4F2154018 for ; Tue, 1 Feb 2000 18:55:38 -0800 (PST) Received: (from bright@localhost) by fw.wintelcom.net (8.9.3/8.9.3) id TAA25922; Tue, 1 Feb 2000 19:21:07 -0800 (PST) Date: Tue, 1 Feb 2000 19:21:07 -0800 From: Alfred Perlstein To: Matthew Dillon Cc: Chee Wei Ng , freebsd-smp@FreeBSD.ORG Subject: Re: MPrellock_edx Message-ID: <20000201192107.I24609@fw.wintelcom.net> References: <20000202010550.16864.qmail@web112.yahoomail.com> <20000201175008.F24609@fw.wintelcom.net> <200002020230.SAA93312@apollo.backplane.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii X-Mailer: Mutt 1.0.1i In-Reply-To: <200002020230.SAA93312@apollo.backplane.com>; from dillon@apollo.backplane.com on Tue, Feb 01, 2000 at 06:30:35PM -0800 Sender: owner-freebsd-smp@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.org * Matthew Dillon [000201 18:56] wrote: > I discussed this issue with Linus after someone from the linux kernel > group brought it up. Basically we have adopted the same thing that linux > uses. > > Under Intel, the following is true: > > * Writes are buffered but are committed to memory in the same > order they were issued. Thus write<->write conflicts are not > an issue. > > * Speculative reads may occur, but they occur from main memory > into the L1 cache and thus still adhere to L1 cache protocols. > Thus speculative reads are not an issue. > > * The cpu may reorder non-conflicting reads. A non-conflicting > read may be reordered from *before* a write to *after* a write, > or from *after* a write to *before* a write. > > This is an issue. This is the ONLY issue with intel hardware. > > The purpose of the locked instruction is to prevent any possibility > of reads being reordered from to after the MP lock is released. ^ before ? So instead of releasing the lock and then writing the the locked object, you could read from the locked object, release the lock then the read actually happens after the lock release. You're not potentially spamming someone else's critical section, but actually possibly extending your own critical section beyond the point where you've released the lock violating your own critical section? -Alfred To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-smp" in the body of the message