Extent -> Ehooks: Move purge_lazy hook.
This commit is contained in:
parent
f83fdf5336
commit
368baa42ef
@ -29,6 +29,11 @@ bool ehooks_default_commit(extent_hooks_t *extent_hooks, void *addr, size_t size
|
|||||||
bool ehooks_default_decommit_impl(void *addr, size_t offset, size_t length);
|
bool ehooks_default_decommit_impl(void *addr, size_t offset, size_t length);
|
||||||
bool ehooks_default_decommit(extent_hooks_t *extent_hooks, void *addr, size_t size,
|
bool ehooks_default_decommit(extent_hooks_t *extent_hooks, void *addr, size_t size,
|
||||||
size_t offset, size_t length, unsigned arena_ind);
|
size_t offset, size_t length, unsigned arena_ind);
|
||||||
|
#ifdef PAGES_CAN_PURGE_LAZY
|
||||||
|
bool ehooks_default_purge_lazy_impl(void *addr, size_t offset, size_t length);
|
||||||
|
bool ehooks_default_purge_lazy(extent_hooks_t *extent_hooks, void *addr, size_t size,
|
||||||
|
size_t offset, size_t length, unsigned arena_ind);
|
||||||
|
#endif
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
ehooks_pre_reentrancy(tsdn_t *tsdn) {
|
ehooks_pre_reentrancy(tsdn_t *tsdn) {
|
||||||
@ -168,14 +173,23 @@ ehooks_decommit(tsdn_t *tsdn, ehooks_t *ehooks, void *addr, size_t size,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static inline bool
|
static inline bool
|
||||||
ehooks_purge_lazy(ehooks_t *ehooks, void *addr, size_t size, size_t offset,
|
ehooks_purge_lazy(tsdn_t *tsdn, ehooks_t *ehooks, void *addr, size_t size,
|
||||||
size_t length, unsigned arena_ind) {
|
size_t offset, size_t length, unsigned arena_ind) {
|
||||||
extent_hooks_t *extent_hooks = ehooks_get_extent_hooks_ptr(ehooks);
|
extent_hooks_t *extent_hooks = ehooks_get_extent_hooks_ptr(ehooks);
|
||||||
|
#ifdef PAGES_CAN_PURGE_LAZY
|
||||||
|
if (extent_hooks == &extent_hooks_default) {
|
||||||
|
return ehooks_default_purge_lazy_impl(addr, offset, length);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
if (extent_hooks->purge_lazy == NULL) {
|
if (extent_hooks->purge_lazy == NULL) {
|
||||||
return true;
|
return true;
|
||||||
|
} else {
|
||||||
|
ehooks_pre_reentrancy(tsdn);
|
||||||
|
bool err = extent_hooks->purge_lazy(extent_hooks, addr, size,
|
||||||
|
offset, length, arena_ind);
|
||||||
|
ehooks_post_reentrancy(tsdn);
|
||||||
|
return err;
|
||||||
}
|
}
|
||||||
return extent_hooks->purge_lazy(extent_hooks, addr, size, offset,
|
|
||||||
length, arena_ind);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool
|
static inline bool
|
||||||
|
@ -90,7 +90,8 @@ base_unmap(tsdn_t *tsdn, ehooks_t *ehooks, unsigned ind, void *addr,
|
|||||||
if (!ehooks_purge_forced(ehooks, addr, size, 0, size, ind)) {
|
if (!ehooks_purge_forced(ehooks, addr, size, 0, size, ind)) {
|
||||||
goto label_post_reentrancy;
|
goto label_post_reentrancy;
|
||||||
}
|
}
|
||||||
if (!ehooks_purge_lazy(ehooks, addr, size, 0, size, ind)) {
|
if (!ehooks_purge_lazy(tsdn, ehooks, addr, size, 0, size,
|
||||||
|
ind)) {
|
||||||
goto label_post_reentrancy;
|
goto label_post_reentrancy;
|
||||||
}
|
}
|
||||||
/* Nothing worked. That's the application's problem. */
|
/* Nothing worked. That's the application's problem. */
|
||||||
|
18
src/ehooks.c
18
src/ehooks.c
@ -126,3 +126,21 @@ ehooks_default_decommit(extent_hooks_t *extent_hooks, void *addr, size_t size,
|
|||||||
size_t offset, size_t length, unsigned arena_ind) {
|
size_t offset, size_t length, unsigned arena_ind) {
|
||||||
return ehooks_default_decommit_impl(addr, offset, length);
|
return ehooks_default_decommit_impl(addr, offset, length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef PAGES_CAN_PURGE_LAZY
|
||||||
|
bool
|
||||||
|
ehooks_default_purge_lazy_impl(void *addr, size_t offset, size_t length) {
|
||||||
|
return pages_purge_lazy((void *)((uintptr_t)addr + (uintptr_t)offset),
|
||||||
|
length);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
ehooks_default_purge_lazy(extent_hooks_t *extent_hooks, void *addr, size_t size,
|
||||||
|
size_t offset, size_t length, unsigned arena_ind) {
|
||||||
|
assert(addr != NULL);
|
||||||
|
assert((offset & PAGE_MASK) == 0);
|
||||||
|
assert(length != 0);
|
||||||
|
assert((length & PAGE_MASK) == 0);
|
||||||
|
return ehooks_default_purge_lazy_impl(addr, offset, length);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
35
src/extent.c
35
src/extent.c
@ -21,10 +21,6 @@ size_t opt_lg_extent_max_active_fit = LG_EXTENT_MAX_ACTIVE_FIT_DEFAULT;
|
|||||||
|
|
||||||
static bool extent_commit_impl(tsdn_t *tsdn, arena_t *arena, ehooks_t *ehooks,
|
static bool extent_commit_impl(tsdn_t *tsdn, arena_t *arena, ehooks_t *ehooks,
|
||||||
extent_t *extent, size_t offset, size_t length, bool growing_retained);
|
extent_t *extent, size_t offset, size_t length, bool growing_retained);
|
||||||
#ifdef PAGES_CAN_PURGE_LAZY
|
|
||||||
static bool extent_purge_lazy_default(extent_hooks_t *extent_hooks, void *addr,
|
|
||||||
size_t size, size_t offset, size_t length, unsigned arena_ind);
|
|
||||||
#endif
|
|
||||||
static bool extent_purge_lazy_impl(tsdn_t *tsdn, arena_t *arena,
|
static bool extent_purge_lazy_impl(tsdn_t *tsdn, arena_t *arena,
|
||||||
ehooks_t *ehooks, extent_t *extent, size_t offset, size_t length,
|
ehooks_t *ehooks, extent_t *extent, size_t offset, size_t length,
|
||||||
bool growing_retained);
|
bool growing_retained);
|
||||||
@ -55,7 +51,7 @@ const extent_hooks_t extent_hooks_default = {
|
|||||||
ehooks_default_commit,
|
ehooks_default_commit,
|
||||||
ehooks_default_decommit,
|
ehooks_default_decommit,
|
||||||
#ifdef PAGES_CAN_PURGE_LAZY
|
#ifdef PAGES_CAN_PURGE_LAZY
|
||||||
extent_purge_lazy_default,
|
ehooks_default_purge_lazy,
|
||||||
#else
|
#else
|
||||||
NULL,
|
NULL,
|
||||||
#endif
|
#endif
|
||||||
@ -1390,7 +1386,7 @@ extent_dalloc_wrapper(tsdn_t *tsdn, arena_t *arena, ehooks_t *ehooks,
|
|||||||
arena_ind_get(arena))) {
|
arena_ind_get(arena))) {
|
||||||
zeroed = true;
|
zeroed = true;
|
||||||
} else if (extent_state_get(extent) == extent_state_muzzy ||
|
} else if (extent_state_get(extent) == extent_state_muzzy ||
|
||||||
!ehooks_purge_lazy(ehooks, extent_base_get(extent),
|
!ehooks_purge_lazy(tsdn, ehooks, extent_base_get(extent),
|
||||||
extent_size_get(extent), 0, extent_size_get(extent),
|
extent_size_get(extent), 0, extent_size_get(extent),
|
||||||
arena_ind_get(arena))) {
|
arena_ind_get(arena))) {
|
||||||
zeroed = false;
|
zeroed = false;
|
||||||
@ -1461,38 +1457,13 @@ extent_decommit_wrapper(tsdn_t *tsdn, arena_t *arena, ehooks_t *ehooks,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PAGES_CAN_PURGE_LAZY
|
|
||||||
static bool
|
|
||||||
extent_purge_lazy_default(extent_hooks_t *extent_hooks, void *addr, size_t size,
|
|
||||||
size_t offset, size_t length, unsigned arena_ind) {
|
|
||||||
assert(addr != NULL);
|
|
||||||
assert((offset & PAGE_MASK) == 0);
|
|
||||||
assert(length != 0);
|
|
||||||
assert((length & PAGE_MASK) == 0);
|
|
||||||
|
|
||||||
return pages_purge_lazy((void *)((uintptr_t)addr + (uintptr_t)offset),
|
|
||||||
length);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
extent_purge_lazy_impl(tsdn_t *tsdn, arena_t *arena, ehooks_t *ehooks,
|
extent_purge_lazy_impl(tsdn_t *tsdn, arena_t *arena, ehooks_t *ehooks,
|
||||||
extent_t *extent, size_t offset, size_t length, bool growing_retained) {
|
extent_t *extent, size_t offset, size_t length, bool growing_retained) {
|
||||||
witness_assert_depth_to_rank(tsdn_witness_tsdp_get(tsdn),
|
witness_assert_depth_to_rank(tsdn_witness_tsdp_get(tsdn),
|
||||||
WITNESS_RANK_CORE, growing_retained ? 1 : 0);
|
WITNESS_RANK_CORE, growing_retained ? 1 : 0);
|
||||||
|
bool err = ehooks_purge_lazy(tsdn, ehooks, extent_base_get(extent),
|
||||||
if (ehooks_purge_lazy_will_fail(ehooks)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (!ehooks_are_default(ehooks)) {
|
|
||||||
extent_hook_pre_reentrancy(tsdn, arena);
|
|
||||||
}
|
|
||||||
bool err = ehooks_purge_lazy(ehooks, extent_base_get(extent),
|
|
||||||
extent_size_get(extent), offset, length, arena_ind_get(arena));
|
extent_size_get(extent), offset, length, arena_ind_get(arena));
|
||||||
if (!ehooks_are_default(ehooks)) {
|
|
||||||
extent_hook_post_reentrancy(tsdn);
|
|
||||||
}
|
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user