]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - contrib/jemalloc/include/jemalloc/internal/background_thread_inlines.h
MFV r361937:
[FreeBSD/FreeBSD.git] / contrib / jemalloc / include / jemalloc / internal / background_thread_inlines.h
1 #ifndef JEMALLOC_INTERNAL_BACKGROUND_THREAD_INLINES_H
2 #define JEMALLOC_INTERNAL_BACKGROUND_THREAD_INLINES_H
3
4 JEMALLOC_ALWAYS_INLINE bool
5 background_thread_enabled(void) {
6         return atomic_load_b(&background_thread_enabled_state, ATOMIC_RELAXED);
7 }
8
9 JEMALLOC_ALWAYS_INLINE void
10 background_thread_enabled_set(tsdn_t *tsdn, bool state) {
11         malloc_mutex_assert_owner(tsdn, &background_thread_lock);
12         atomic_store_b(&background_thread_enabled_state, state, ATOMIC_RELAXED);
13 }
14
15 JEMALLOC_ALWAYS_INLINE background_thread_info_t *
16 arena_background_thread_info_get(arena_t *arena) {
17         unsigned arena_ind = arena_ind_get(arena);
18         return &background_thread_info[arena_ind % max_background_threads];
19 }
20
21 JEMALLOC_ALWAYS_INLINE background_thread_info_t *
22 background_thread_info_get(size_t ind) {
23         return &background_thread_info[ind % max_background_threads];
24 }
25
26 JEMALLOC_ALWAYS_INLINE uint64_t
27 background_thread_wakeup_time_get(background_thread_info_t *info) {
28         uint64_t next_wakeup = nstime_ns(&info->next_wakeup);
29         assert(atomic_load_b(&info->indefinite_sleep, ATOMIC_ACQUIRE) ==
30             (next_wakeup == BACKGROUND_THREAD_INDEFINITE_SLEEP));
31         return next_wakeup;
32 }
33
34 JEMALLOC_ALWAYS_INLINE void
35 background_thread_wakeup_time_set(tsdn_t *tsdn, background_thread_info_t *info,
36     uint64_t wakeup_time) {
37         malloc_mutex_assert_owner(tsdn, &info->mtx);
38         atomic_store_b(&info->indefinite_sleep,
39             wakeup_time == BACKGROUND_THREAD_INDEFINITE_SLEEP, ATOMIC_RELEASE);
40         nstime_init(&info->next_wakeup, wakeup_time);
41 }
42
43 JEMALLOC_ALWAYS_INLINE bool
44 background_thread_indefinite_sleep(background_thread_info_t *info) {
45         return atomic_load_b(&info->indefinite_sleep, ATOMIC_ACQUIRE);
46 }
47
48 JEMALLOC_ALWAYS_INLINE void
49 arena_background_thread_inactivity_check(tsdn_t *tsdn, arena_t *arena,
50     bool is_background_thread) {
51         if (!background_thread_enabled() || is_background_thread) {
52                 return;
53         }
54         background_thread_info_t *info =
55             arena_background_thread_info_get(arena);
56         if (background_thread_indefinite_sleep(info)) {
57                 background_thread_interval_check(tsdn, arena,
58                     &arena->decay_dirty, 0);
59         }
60 }
61
62 #endif /* JEMALLOC_INTERNAL_BACKGROUND_THREAD_INLINES_H */