Consolidate prof inline function headers
The prof inline functions are no longer involved in a circular dependency, so consolidate the two headers into one.
This commit is contained in:
parent
d454af90f1
commit
e6cb6919c0
@ -73,13 +73,12 @@
|
|||||||
* Include portions of arena code interleaved with tcache code in order to
|
* Include portions of arena code interleaved with tcache code in order to
|
||||||
* resolve circular dependencies.
|
* resolve circular dependencies.
|
||||||
*/
|
*/
|
||||||
#include "jemalloc/internal/prof_inlines_a.h"
|
|
||||||
#include "jemalloc/internal/arena_inlines_a.h"
|
#include "jemalloc/internal/arena_inlines_a.h"
|
||||||
#include "jemalloc/internal/jemalloc_internal_inlines_b.h"
|
#include "jemalloc/internal/jemalloc_internal_inlines_b.h"
|
||||||
#include "jemalloc/internal/tcache_inlines.h"
|
#include "jemalloc/internal/tcache_inlines.h"
|
||||||
#include "jemalloc/internal/arena_inlines_b.h"
|
#include "jemalloc/internal/arena_inlines_b.h"
|
||||||
#include "jemalloc/internal/jemalloc_internal_inlines_c.h"
|
#include "jemalloc/internal/jemalloc_internal_inlines_c.h"
|
||||||
#include "jemalloc/internal/prof_inlines_b.h"
|
#include "jemalloc/internal/prof_inlines.h"
|
||||||
#include "jemalloc/internal/background_thread_inlines.h"
|
#include "jemalloc/internal/background_thread_inlines.h"
|
||||||
|
|
||||||
#endif /* JEMALLOC_INTERNAL_INCLUDES_H */
|
#endif /* JEMALLOC_INTERNAL_INCLUDES_H */
|
||||||
|
@ -48,7 +48,7 @@ extern size_t lg_prof_sample;
|
|||||||
|
|
||||||
extern bool prof_booted;
|
extern bool prof_booted;
|
||||||
|
|
||||||
/* Functions only accessed in prof_inlines_b.h */
|
/* Functions only accessed in prof_inlines.h */
|
||||||
prof_tdata_t *prof_tdata_init(tsd_t *tsd);
|
prof_tdata_t *prof_tdata_init(tsd_t *tsd);
|
||||||
prof_tdata_t *prof_tdata_reinit(tsd_t *tsd, prof_tdata_t *tdata);
|
prof_tdata_t *prof_tdata_reinit(tsd_t *tsd, prof_tdata_t *tdata);
|
||||||
|
|
||||||
|
@ -5,6 +5,28 @@
|
|||||||
#include "jemalloc/internal/sz.h"
|
#include "jemalloc/internal/sz.h"
|
||||||
#include "jemalloc/internal/thread_event.h"
|
#include "jemalloc/internal/thread_event.h"
|
||||||
|
|
||||||
|
JEMALLOC_ALWAYS_INLINE void
|
||||||
|
prof_active_assert() {
|
||||||
|
cassert(config_prof);
|
||||||
|
/*
|
||||||
|
* If opt_prof is off, then prof_active must always be off, regardless
|
||||||
|
* of whether prof_active_mtx is in effect or not.
|
||||||
|
*/
|
||||||
|
assert(opt_prof || !prof_active);
|
||||||
|
}
|
||||||
|
|
||||||
|
JEMALLOC_ALWAYS_INLINE bool
|
||||||
|
prof_active_get_unlocked(void) {
|
||||||
|
prof_active_assert();
|
||||||
|
/*
|
||||||
|
* Even if opt_prof is true, sampling can be temporarily disabled by
|
||||||
|
* setting prof_active to false. No locking is used when reading
|
||||||
|
* prof_active in the fast path, so there are no guarantees regarding
|
||||||
|
* how long it will take for all threads to notice state changes.
|
||||||
|
*/
|
||||||
|
return prof_active;
|
||||||
|
}
|
||||||
|
|
||||||
JEMALLOC_ALWAYS_INLINE bool
|
JEMALLOC_ALWAYS_INLINE bool
|
||||||
prof_gdump_get_unlocked(void) {
|
prof_gdump_get_unlocked(void) {
|
||||||
/*
|
/*
|
@ -1,28 +0,0 @@
|
|||||||
#ifndef JEMALLOC_INTERNAL_PROF_INLINES_A_H
|
|
||||||
#define JEMALLOC_INTERNAL_PROF_INLINES_A_H
|
|
||||||
|
|
||||||
#include "jemalloc/internal/mutex.h"
|
|
||||||
|
|
||||||
JEMALLOC_ALWAYS_INLINE void
|
|
||||||
prof_active_assert() {
|
|
||||||
cassert(config_prof);
|
|
||||||
/*
|
|
||||||
* If opt_prof is off, then prof_active must always be off, regardless
|
|
||||||
* of whether prof_active_mtx is in effect or not.
|
|
||||||
*/
|
|
||||||
assert(opt_prof || !prof_active);
|
|
||||||
}
|
|
||||||
|
|
||||||
JEMALLOC_ALWAYS_INLINE bool
|
|
||||||
prof_active_get_unlocked(void) {
|
|
||||||
prof_active_assert();
|
|
||||||
/*
|
|
||||||
* Even if opt_prof is true, sampling can be temporarily disabled by
|
|
||||||
* setting prof_active to false. No locking is used when reading
|
|
||||||
* prof_active in the fast path, so there are no guarantees regarding
|
|
||||||
* how long it will take for all threads to notice state changes.
|
|
||||||
*/
|
|
||||||
return prof_active;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* JEMALLOC_INTERNAL_PROF_INLINES_A_H */
|
|
Loading…
Reference in New Issue
Block a user