X-Git-Url: https://git.saurik.com/redis.git/blobdiff_plain/9e83ac06ef1c978c65fefc1fbf5af1e95f31fe15..c15a3887e08d468b96d4313cc19862b5e4b09977:/src/zmalloc.c diff --git a/src/zmalloc.c b/src/zmalloc.c index 544155e7..1917a549 100644 --- a/src/zmalloc.c +++ b/src/zmalloc.c @@ -32,13 +32,24 @@ #include #include #include - #include "config.h" +#ifdef HAVE_MALLOC_SIZE +#define PREFIX_SIZE (0) +#else #if defined(__sun) -#define PREFIX_SIZE sizeof(long long) +#define PREFIX_SIZE (sizeof(long long)) #else -#define PREFIX_SIZE sizeof(size_t) +#define PREFIX_SIZE (sizeof(size_t)) +#endif +#endif + +/* Explicitly override malloc/free etc when using tcmalloc. */ +#if defined(USE_TCMALLOC) +#define malloc(size) tc_malloc(size) +#define calloc(count,size) tc_calloc(count,size) +#define realloc(ptr,size) tc_realloc(ptr,size) +#define free(ptr) tc_free(ptr) #endif #define increment_used_memory(__n) do { \ @@ -172,7 +183,15 @@ void zmalloc_enable_thread_safeness(void) { zmalloc_thread_safe = 1; } -/* Fragmentation = RSS / allocated-bytes */ +/* Get the RSS information in an OS-specific way. + * + * WARNING: the function zmalloc_get_rss() is not designed to be fast + * and may not be called in the busy loops where Redis tries to release + * memory expiring or swapping out objects. + * + * For this kind of "fast RSS reporting" usages use instead the + * function RedisEstimateRSS() that is a much faster (and less precise) + * version of the funciton. */ #if defined(HAVE_PROCFS) #include @@ -180,8 +199,7 @@ void zmalloc_enable_thread_safeness(void) { #include #include -float zmalloc_get_fragmentation_ratio(void) { - size_t allocated = zmalloc_used_memory(); +size_t zmalloc_get_rss(void) { int page = sysconf(_SC_PAGESIZE); size_t rss; char buf[4096]; @@ -210,7 +228,7 @@ float zmalloc_get_fragmentation_ratio(void) { rss = strtoll(p,NULL,10); rss *= page; - return (float)rss/allocated; + return rss; } #elif defined(HAVE_TASKINFO) #include @@ -221,7 +239,7 @@ float zmalloc_get_fragmentation_ratio(void) { #include #include -float zmalloc_get_fragmentation_ratio(void) { +size_t zmalloc_get_rss(void) { task_t task = MACH_PORT_NULL; struct task_basic_info t_info; mach_msg_type_number_t t_info_count = TASK_BASIC_INFO_COUNT; @@ -230,10 +248,20 @@ float zmalloc_get_fragmentation_ratio(void) { return 0; task_info(task, TASK_BASIC_INFO, (task_info_t)&t_info, &t_info_count); - return (float)t_info.resident_size/zmalloc_used_memory(); + return t_info.resident_size; } #else -float zmalloc_get_fragmentation_ratio(void) { - return 0; +float zmalloc_get_rss(void) { + /* If we can't get the RSS in an OS-specific way for this system just + * return the memory usage we estimated in zmalloc().. + * + * Fragmentation will appear to be always 1 (no fragmentation) + * of course... */ + return zmalloc_used_memory(); } #endif + +/* Fragmentation = RSS / allocated-bytes */ +float zmalloc_get_fragmentation_ratio(void) { + return (float)zmalloc_get_rss()/zmalloc_used_memory(); +}