Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S935203AbYBVNqb (ORCPT ); Fri, 22 Feb 2008 08:46:31 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1763021AbYBVNqX (ORCPT ); Fri, 22 Feb 2008 08:46:23 -0500 Received: from ms-smtp-04.nyroc.rr.com ([24.24.2.58]:61473 "EHLO ms-smtp-04.nyroc.rr.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1762485AbYBVNqW (ORCPT ); Fri, 22 Feb 2008 08:46:22 -0500 Date: Fri, 22 Feb 2008 08:46:16 -0500 (EST) From: Steven Rostedt X-X-Sender: rostedt@gandalf.stny.rr.com To: Ingo Molnar cc: gregory.haskins@gmail.com, Gregory Haskins , a.p.zijlstra@chello.nl, tglx@linutronix.de, linux-rt-users@vger.kernel.org, linux-kernel@vger.kernel.org, bill.huey@gmail.com, kevin@hilman.org, cminyard@mvista.com, dsingleton@mvista.com, dwalker@mvista.com, npiggin@suse.de, dsaxena@plexity.net, ak@suse.de, gregkh@suse.de, sdietrich@novell.com, pmorreale@novell.com, mkohari@novell.com Subject: Re: [PATCH [RT] 05/14] rearrange rt_spin_lock sleep In-Reply-To: <20080222133541.GA8868@elte.hu> Message-ID: References: <20080221152504.4804.8724.stgit@novell1.haskins.net> <20080221152651.4804.4702.stgit@novell1.haskins.net> <47BECE30.8030100@gmail.com> <20080222133541.GA8868@elte.hu> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1069 Lines: 39 Gregory, I guess we should have just read Documentation/memory-barriers.text Here's the snippet: Any atomic operation that modifies some state in memory and returns information about the state (old or new) implies an SMP-conditional general memory barrier (smp_mb()) on each side of the actual operation (with the exception of explicit lock operations, described later). These include: xchg(); cmpxchg(); atomic_cmpxchg(); atomic_inc_return(); atomic_dec_return(); atomic_add_return(); atomic_sub_return(); atomic_inc_and_test(); atomic_dec_and_test(); atomic_sub_and_test(); atomic_add_negative(); atomic_add_unless(); test_and_set_bit(); test_and_clear_bit(); test_and_change_bit(); -- Steve -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/