Header refactoring: unify spin.h and move it out of the catch-all.

This commit is contained in:
David Goldblatt 2017-04-17 16:35:04 -07:00 committed by David Goldblatt
parent 418d96a86c
commit 38e847c1c5
9 changed files with 42 additions and 49 deletions

View File

@ -40,7 +40,6 @@
/* TYPES */ /* TYPES */
/******************************************************************************/ /******************************************************************************/
#include "jemalloc/internal/spin_types.h"
#include "jemalloc/internal/prng_types.h" #include "jemalloc/internal/prng_types.h"
#include "jemalloc/internal/ticker_types.h" #include "jemalloc/internal/ticker_types.h"
#include "jemalloc/internal/ckh_types.h" #include "jemalloc/internal/ckh_types.h"
@ -65,7 +64,6 @@
/* STRUCTS */ /* STRUCTS */
/******************************************************************************/ /******************************************************************************/
#include "jemalloc/internal/spin_structs.h"
#include "jemalloc/internal/ticker_structs.h" #include "jemalloc/internal/ticker_structs.h"
#include "jemalloc/internal/ckh_structs.h" #include "jemalloc/internal/ckh_structs.h"
#include "jemalloc/internal/witness_structs.h" #include "jemalloc/internal/witness_structs.h"
@ -110,7 +108,6 @@
/* INLINES */ /* INLINES */
/******************************************************************************/ /******************************************************************************/
#include "jemalloc/internal/spin_inlines.h"
#include "jemalloc/internal/prng_inlines.h" #include "jemalloc/internal/prng_inlines.h"
#include "jemalloc/internal/ticker_inlines.h" #include "jemalloc/internal/ticker_inlines.h"
#include "jemalloc/internal/tsd_inlines.h" #include "jemalloc/internal/tsd_inlines.h"

View File

@ -1,6 +1,8 @@
#ifndef JEMALLOC_INTERNAL_RTREE_INLINES_H #ifndef JEMALLOC_INTERNAL_RTREE_INLINES_H
#define JEMALLOC_INTERNAL_RTREE_INLINES_H #define JEMALLOC_INTERNAL_RTREE_INLINES_H
#include "jemalloc/internal/spin.h"
#ifndef JEMALLOC_ENABLE_INLINE #ifndef JEMALLOC_ENABLE_INLINE
uintptr_t rtree_leafkey(uintptr_t key); uintptr_t rtree_leafkey(uintptr_t key);
uintptr_t rtree_subkey(uintptr_t key, unsigned level); uintptr_t rtree_subkey(uintptr_t key, unsigned level);

View File

@ -0,0 +1,36 @@
#ifndef JEMALLOC_INTERNAL_SPIN_H
#define JEMALLOC_INTERNAL_SPIN_H
#ifdef JEMALLOC_SPIN_C_
# define SPIN_INLINE extern inline
#else
# define SPIN_INLINE inline
#endif
#define SPIN_INITIALIZER {0U}
typedef struct {
unsigned iteration;
} spin_t;
SPIN_INLINE void
spin_adaptive(spin_t *spin) {
volatile uint32_t i;
if (spin->iteration < 5) {
for (i = 0; i < (1U << spin->iteration); i++) {
CPU_SPINWAIT;
}
spin->iteration++;
} else {
#ifdef _WIN32
SwitchToThread();
#else
sched_yield();
#endif
}
}
#undef SPIN_INLINE
#endif /* JEMALLOC_INTERNAL_SPIN_H */

View File

@ -1,29 +0,0 @@
#ifndef JEMALLOC_INTERNAL_SPIN_INLINES_H
#define JEMALLOC_INTERNAL_SPIN_INLINES_H
#ifndef JEMALLOC_ENABLE_INLINE
void spin_adaptive(spin_t *spin);
#endif
#if (defined(JEMALLOC_ENABLE_INLINE) || defined(JEMALLOC_SPIN_C_))
JEMALLOC_INLINE void
spin_adaptive(spin_t *spin) {
volatile uint32_t i;
if (spin->iteration < 5) {
for (i = 0; i < (1U << spin->iteration); i++) {
CPU_SPINWAIT;
}
spin->iteration++;
} else {
#ifdef _WIN32
SwitchToThread();
#else
sched_yield();
#endif
}
}
#endif
#endif /* JEMALLOC_INTERNAL_SPIN_INLINES_H */

View File

@ -1,8 +0,0 @@
#ifndef JEMALLOC_INTERNAL_SPIN_STRUCTS_H
#define JEMALLOC_INTERNAL_SPIN_STRUCTS_H
struct spin_s {
unsigned iteration;
};
#endif /* JEMALLOC_INTERNAL_SPIN_STRUCTS_H */

View File

@ -1,8 +0,0 @@
#ifndef JEMALLOC_INTERNAL_SPIN_TYPES_H
#define JEMALLOC_INTERNAL_SPIN_TYPES_H
typedef struct spin_s spin_t;
#define SPIN_INITIALIZER {0U}
#endif /* JEMALLOC_INTERNAL_SPIN_TYPES_H */

View File

@ -3,6 +3,7 @@
#include "jemalloc/internal/jemalloc_internal_includes.h" #include "jemalloc/internal/jemalloc_internal_includes.h"
#include "jemalloc/internal/assert.h" #include "jemalloc/internal/assert.h"
#include "jemalloc/internal/spin.h"
/******************************************************************************/ /******************************************************************************/
/* Data. */ /* Data. */

View File

@ -6,6 +6,7 @@
#include "jemalloc/internal/atomic.h" #include "jemalloc/internal/atomic.h"
#include "jemalloc/internal/jemalloc_internal_types.h" #include "jemalloc/internal/jemalloc_internal_types.h"
#include "jemalloc/internal/malloc_io.h" #include "jemalloc/internal/malloc_io.h"
#include "jemalloc/internal/spin.h"
#include "jemalloc/internal/util.h" #include "jemalloc/internal/util.h"
/******************************************************************************/ /******************************************************************************/

View File

@ -1,3 +1,4 @@
#define JEMALLOC_SPIN_C_ #define JEMALLOC_SPIN_C_
#include "jemalloc/internal/jemalloc_preamble.h" #include "jemalloc/internal/jemalloc_preamble.h"
#include "jemalloc/internal/jemalloc_internal_includes.h"
#include "jemalloc/internal/spin.h"