mm,x86,um: move CMPXCHG_DOUBLE config option
Move CMPXCHG_DOUBLE and rename it to HAVE_CMPXCHG_DOUBLE so architectures can simply select the option if it is supported. Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com> Acked-by: Christoph Lameter <cl@linux.com> Cc: Pekka Enberg <penberg@kernel.org> Cc: Ingo Molnar <mingo@elte.hu> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: "H. Peter Anvin" <hpa@zytor.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
4156153c4d
commit
2565409fc0
@ -196,4 +196,7 @@ config HAVE_ALIGNED_STRUCT_PAGE
|
|||||||
config HAVE_CMPXCHG_LOCAL
|
config HAVE_CMPXCHG_LOCAL
|
||||||
bool
|
bool
|
||||||
|
|
||||||
|
config HAVE_CMPXCHG_DOUBLE
|
||||||
|
bool
|
||||||
|
|
||||||
source "kernel/gcov/Kconfig"
|
source "kernel/gcov/Kconfig"
|
||||||
|
@ -62,6 +62,7 @@ config X86
|
|||||||
select ANON_INODES
|
select ANON_INODES
|
||||||
select HAVE_ALIGNED_STRUCT_PAGE if SLUB && !M386
|
select HAVE_ALIGNED_STRUCT_PAGE if SLUB && !M386
|
||||||
select HAVE_CMPXCHG_LOCAL if !M386
|
select HAVE_CMPXCHG_LOCAL if !M386
|
||||||
|
select HAVE_CMPXCHG_DOUBLE
|
||||||
select HAVE_ARCH_KMEMCHECK
|
select HAVE_ARCH_KMEMCHECK
|
||||||
select HAVE_USER_RETURN_NOTIFIER
|
select HAVE_USER_RETURN_NOTIFIER
|
||||||
select ARCH_BINFMT_ELF_RANDOMIZE_PIE
|
select ARCH_BINFMT_ELF_RANDOMIZE_PIE
|
||||||
|
@ -309,9 +309,6 @@ config X86_INTERNODE_CACHE_SHIFT
|
|||||||
config X86_CMPXCHG
|
config X86_CMPXCHG
|
||||||
def_bool X86_64 || (X86_32 && !M386)
|
def_bool X86_64 || (X86_32 && !M386)
|
||||||
|
|
||||||
config CMPXCHG_DOUBLE
|
|
||||||
def_bool y
|
|
||||||
|
|
||||||
config X86_L1_CACHE_SHIFT
|
config X86_L1_CACHE_SHIFT
|
||||||
int
|
int
|
||||||
default "7" if MPENTIUM4 || MPSC
|
default "7" if MPENTIUM4 || MPSC
|
||||||
|
@ -6,10 +6,6 @@ menu "UML-specific options"
|
|||||||
|
|
||||||
menu "Host processor type and features"
|
menu "Host processor type and features"
|
||||||
|
|
||||||
config CMPXCHG_DOUBLE
|
|
||||||
bool
|
|
||||||
default n
|
|
||||||
|
|
||||||
source "arch/x86/Kconfig.cpu"
|
source "arch/x86/Kconfig.cpu"
|
||||||
|
|
||||||
endmenu
|
endmenu
|
||||||
|
@ -366,7 +366,8 @@ static inline bool __cmpxchg_double_slab(struct kmem_cache *s, struct page *page
|
|||||||
const char *n)
|
const char *n)
|
||||||
{
|
{
|
||||||
VM_BUG_ON(!irqs_disabled());
|
VM_BUG_ON(!irqs_disabled());
|
||||||
#if defined(CONFIG_CMPXCHG_DOUBLE) && defined(CONFIG_HAVE_ALIGNED_STRUCT_PAGE)
|
#if defined(CONFIG_HAVE_CMPXCHG_DOUBLE) && \
|
||||||
|
defined(CONFIG_HAVE_ALIGNED_STRUCT_PAGE)
|
||||||
if (s->flags & __CMPXCHG_DOUBLE) {
|
if (s->flags & __CMPXCHG_DOUBLE) {
|
||||||
if (cmpxchg_double(&page->freelist, &page->counters,
|
if (cmpxchg_double(&page->freelist, &page->counters,
|
||||||
freelist_old, counters_old,
|
freelist_old, counters_old,
|
||||||
@ -400,7 +401,8 @@ static inline bool cmpxchg_double_slab(struct kmem_cache *s, struct page *page,
|
|||||||
void *freelist_new, unsigned long counters_new,
|
void *freelist_new, unsigned long counters_new,
|
||||||
const char *n)
|
const char *n)
|
||||||
{
|
{
|
||||||
#if defined(CONFIG_CMPXCHG_DOUBLE) && defined(CONFIG_HAVE_ALIGNED_STRUCT_PAGE)
|
#if defined(CONFIG_HAVE_CMPXCHG_DOUBLE) && \
|
||||||
|
defined(CONFIG_HAVE_ALIGNED_STRUCT_PAGE)
|
||||||
if (s->flags & __CMPXCHG_DOUBLE) {
|
if (s->flags & __CMPXCHG_DOUBLE) {
|
||||||
if (cmpxchg_double(&page->freelist, &page->counters,
|
if (cmpxchg_double(&page->freelist, &page->counters,
|
||||||
freelist_old, counters_old,
|
freelist_old, counters_old,
|
||||||
@ -3014,7 +3016,8 @@ static int kmem_cache_open(struct kmem_cache *s,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(CONFIG_CMPXCHG_DOUBLE) && defined(CONFIG_HAVE_ALIGNED_STRUCT_PAGE)
|
#if defined(CONFIG_HAVE_CMPXCHG_DOUBLE) && \
|
||||||
|
defined(CONFIG_HAVE_ALIGNED_STRUCT_PAGE)
|
||||||
if (system_has_cmpxchg_double() && (s->flags & SLAB_DEBUG_FLAGS) == 0)
|
if (system_has_cmpxchg_double() && (s->flags & SLAB_DEBUG_FLAGS) == 0)
|
||||||
/* Enable fast mode */
|
/* Enable fast mode */
|
||||||
s->flags |= __CMPXCHG_DOUBLE;
|
s->flags |= __CMPXCHG_DOUBLE;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user