mirror of
https://github.com/fluencelabs/redis
synced 2025-03-22 10:30:49 +00:00
40 lines
973 B
C
40 lines
973 B
C
|
#define JEMALLOC_EXTENT_C_
|
||
|
#include "jemalloc/internal/jemalloc_internal.h"
|
||
|
|
||
|
/******************************************************************************/
|
||
|
|
||
|
static inline int
|
||
|
extent_szad_comp(extent_node_t *a, extent_node_t *b)
|
||
|
{
|
||
|
int ret;
|
||
|
size_t a_size = a->size;
|
||
|
size_t b_size = b->size;
|
||
|
|
||
|
ret = (a_size > b_size) - (a_size < b_size);
|
||
|
if (ret == 0) {
|
||
|
uintptr_t a_addr = (uintptr_t)a->addr;
|
||
|
uintptr_t b_addr = (uintptr_t)b->addr;
|
||
|
|
||
|
ret = (a_addr > b_addr) - (a_addr < b_addr);
|
||
|
}
|
||
|
|
||
|
return (ret);
|
||
|
}
|
||
|
|
||
|
/* Generate red-black tree functions. */
|
||
|
rb_gen(, extent_tree_szad_, extent_tree_t, extent_node_t, link_szad,
|
||
|
extent_szad_comp)
|
||
|
|
||
|
static inline int
|
||
|
extent_ad_comp(extent_node_t *a, extent_node_t *b)
|
||
|
{
|
||
|
uintptr_t a_addr = (uintptr_t)a->addr;
|
||
|
uintptr_t b_addr = (uintptr_t)b->addr;
|
||
|
|
||
|
return ((a_addr > b_addr) - (a_addr < b_addr));
|
||
|
}
|
||
|
|
||
|
/* Generate red-black tree functions. */
|
||
|
rb_gen(, extent_tree_ad_, extent_tree_t, extent_node_t, link_ad,
|
||
|
extent_ad_comp)
|