aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBoqun Feng <boqun.feng@gmail.com>2015-08-26 07:52:46 -0400
committerIngo Molnar <mingo@kernel.org>2015-09-13 04:35:46 -0400
commit84567995612258c23bc55795575babe7ef605dd9 (patch)
tree69ae01847597ccd3e759b87dc5d11b457839298f
parentc7ef92cea98bc468bbc8e67b6e49d7365dc69482 (diff)
locking/atomics, cmpxchg: Privatize the inclusion of asm/cmpxchg.h
After commit: 654672d4ba1a ("locking/atomics: Add _{acquire|release|relaxed}() variants of some atomic operations") Architectures may only provide {cmp,}xchg_relaxed definitions in asm/cmpxchg.h. Other variants, such as {cmp,}xchg, may be built in linux/atomic.h, which means simply including asm/cmpxchg.h may not get the definitions of all the{cmp,}xchg variants. Therefore, we should privatize the inclusions of asm/cmpxchg.h to keep it only included in arch/* and replace the inclusions outside with linux/atomic.h Signed-off-by: Boqun Feng <boqun.feng@gmail.com> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Acked-by: Will Deacon <will.deacon@arm.com> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Aybuke Ozdemir <aybuke.147@gmail.com> Cc: Chris Brannon <chris@the-brannons.com> Cc: Davidlohr Bueso <dave@stgolabs.net> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Jonathan Corbet <corbet@lwn.net> Cc: Kirk Reiser <kirk@reisers.ca> Cc: Kishon Vijay Abraham I <kishon@ti.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Samuel Thibault <samuel.thibault@ens-lyon.org> Cc: Shradha Shah <sshah@solarflare.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: William Hubbs <w.d.hubbs@gmail.com> Cc: devel@driverdev.osuosl.org Cc: linux-net-drivers@solarflare.com Cc: speakup@linux-speakup.org Link: http://lkml.kernel.org/r/1440589966-26280-1-git-send-email-boqun.feng@gmail.com Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r--Documentation/atomic_ops.txt4
-rw-r--r--drivers/net/ethernet/sfc/mcdi.c2
-rw-r--r--drivers/phy/phy-rcar-gen2.c3
-rw-r--r--drivers/staging/speakup/selection.c2
4 files changed, 7 insertions, 4 deletions
diff --git a/Documentation/atomic_ops.txt b/Documentation/atomic_ops.txt
index b19fc34efdb1..c9d1cacb4395 100644
--- a/Documentation/atomic_ops.txt
+++ b/Documentation/atomic_ops.txt
@@ -542,6 +542,10 @@ The routines xchg() and cmpxchg() must provide the same exact
542memory-barrier semantics as the atomic and bit operations returning 542memory-barrier semantics as the atomic and bit operations returning
543values. 543values.
544 544
545Note: If someone wants to use xchg(), cmpxchg() and their variants,
546linux/atomic.h should be included rather than asm/cmpxchg.h, unless
547the code is in arch/* and can take care of itself.
548
545Spinlocks and rwlocks have memory barrier expectations as well. 549Spinlocks and rwlocks have memory barrier expectations as well.
546The rule to follow is simple: 550The rule to follow is simple:
547 551
diff --git a/drivers/net/ethernet/sfc/mcdi.c b/drivers/net/ethernet/sfc/mcdi.c
index 98d172b04f71..a9b9460de0d6 100644
--- a/drivers/net/ethernet/sfc/mcdi.c
+++ b/drivers/net/ethernet/sfc/mcdi.c
@@ -9,7 +9,7 @@
9 9
10#include <linux/delay.h> 10#include <linux/delay.h>
11#include <linux/moduleparam.h> 11#include <linux/moduleparam.h>
12#include <asm/cmpxchg.h> 12#include <linux/atomic.h>
13#include "net_driver.h" 13#include "net_driver.h"
14#include "nic.h" 14#include "nic.h"
15#include "io.h" 15#include "io.h"
diff --git a/drivers/phy/phy-rcar-gen2.c b/drivers/phy/phy-rcar-gen2.c
index 6e0d9fa8e1d1..c7a05996d5c1 100644
--- a/drivers/phy/phy-rcar-gen2.c
+++ b/drivers/phy/phy-rcar-gen2.c
@@ -17,8 +17,7 @@
17#include <linux/phy/phy.h> 17#include <linux/phy/phy.h>
18#include <linux/platform_device.h> 18#include <linux/platform_device.h>
19#include <linux/spinlock.h> 19#include <linux/spinlock.h>
20 20#include <linux/atomic.h>
21#include <asm/cmpxchg.h>
22 21
23#define USBHS_LPSTS 0x02 22#define USBHS_LPSTS 0x02
24#define USBHS_UGCTRL 0x80 23#define USBHS_UGCTRL 0x80
diff --git a/drivers/staging/speakup/selection.c b/drivers/staging/speakup/selection.c
index 98af3b1f2d2a..aa5ab6c80ed4 100644
--- a/drivers/staging/speakup/selection.c
+++ b/drivers/staging/speakup/selection.c
@@ -7,7 +7,7 @@
7#include <linux/workqueue.h> 7#include <linux/workqueue.h>
8#include <linux/tty.h> 8#include <linux/tty.h>
9#include <linux/tty_flip.h> 9#include <linux/tty_flip.h>
10#include <asm/cmpxchg.h> 10#include <linux/atomic.h>
11 11
12#include "speakup.h" 12#include "speakup.h"
13 13