diff options
| -rw-r--r-- | cli/src/cli.c | 12 | ||||
| -rw-r--r-- | glusterfsd/src/glusterfsd.c | 12 | ||||
| -rw-r--r-- | libglusterfs/src/dict.c | 35 | ||||
| -rw-r--r-- | libglusterfs/src/glusterfs.h | 5 | 
4 files changed, 45 insertions, 19 deletions
| diff --git a/cli/src/cli.c b/cli/src/cli.c index f20ea1f17..c638dc827 100644 --- a/cli/src/cli.c +++ b/cli/src/cli.c @@ -179,6 +179,18 @@ glusterfs_ctx_defaults_init (glusterfs_ctx_t *ctx)          if (!ctx->stub_mem_pool)                  return -1; +        ctx->dict_pool = mem_pool_new (dict_t, 32); +        if (!ctx->dict_pool) +                return -1; + +        ctx->dict_pair_pool = mem_pool_new (data_pair_t, 512); +        if (!ctx->dict_pair_pool) +                return -1; + +        ctx->dict_data_pool = mem_pool_new (data_t, 512); +        if (!ctx->dict_data_pool) +                return -1; +          INIT_LIST_HEAD (&pool->all_frames);          LOCK_INIT (&pool->lock);          ctx->pool = pool; diff --git a/glusterfsd/src/glusterfsd.c b/glusterfsd/src/glusterfsd.c index 7d322b0dd..57b3f0160 100644 --- a/glusterfsd/src/glusterfsd.c +++ b/glusterfsd/src/glusterfsd.c @@ -1031,6 +1031,18 @@ glusterfs_ctx_defaults_init (glusterfs_ctx_t *ctx)                  return -1;          } +        ctx->dict_pool = mem_pool_new (dict_t, 1024); +        if (!ctx->dict_pool) +                return -1; + +        ctx->dict_pair_pool = mem_pool_new (data_pair_t, 16 * GF_UNIT_KB); +        if (!ctx->dict_pair_pool) +                return -1; + +        ctx->dict_data_pool = mem_pool_new (data_t, 8 * GF_UNIT_KB); +        if (!ctx->dict_data_pool) +                return -1; +          INIT_LIST_HEAD (&pool->all_frames);          LOCK_INIT (&pool->lock);          ctx->pool = pool; diff --git a/libglusterfs/src/dict.c b/libglusterfs/src/dict.c index fd9dd1cd7..a9d67ebc7 100644 --- a/libglusterfs/src/dict.c +++ b/libglusterfs/src/dict.c @@ -36,14 +36,15 @@  #include "logging.h"  #include "compat.h"  #include "byte-order.h" +#include "globals.h"  data_pair_t *  get_new_data_pair ()  {          data_pair_t *data_pair_ptr = NULL; -        data_pair_ptr = (data_pair_t *) GF_CALLOC (1, sizeof (data_pair_t), -                                                   gf_common_mt_data_pair_t); +        data_pair_ptr = mem_get0 (THIS->ctx->dict_pair_pool); +          return data_pair_ptr;  } @@ -52,7 +53,7 @@ get_new_data ()  {          data_t *data = NULL; -        data = (data_t *) GF_CALLOC (1, sizeof (data_t), gf_common_mt_data_t); +        data = mem_get0 (THIS->ctx->dict_data_pool);          if (!data) {                  return NULL;          } @@ -64,18 +65,17 @@ get_new_data ()  dict_t *  get_new_dict_full (int size_hint)  { -        dict_t *dict = GF_CALLOC (1, sizeof (dict_t), gf_common_mt_dict_t); +        dict_t *dict = mem_get0 (THIS->ctx->dict_pool);          if (!dict) {                  return NULL;          }          dict->hash_size = size_hint; -        dict->members = GF_CALLOC (size_hint, sizeof (data_pair_t *), -                                   gf_common_mt_data_pair_t); +        dict->members = mem_get0 (THIS->ctx->dict_pair_pool);          if (!dict->members) { -                GF_FREE (dict); +                mem_put (dict);                  return NULL;          } @@ -149,7 +149,7 @@ data_destroy (data_t *data)                  data->len = 0xbabababa;                  if (!data->is_const) -                        GF_FREE (data); +                        mem_put (data);          }  } @@ -162,9 +162,7 @@ data_copy (data_t *old)                  return NULL;          } -        data_t *newdata = (data_t *) GF_CALLOC (1, sizeof (*newdata), -                                                gf_common_mt_data_t); - +        data_t *newdata = mem_get0 (THIS->ctx->dict_data_pool);          if (!newdata) {                  return NULL;          } @@ -193,7 +191,7 @@ err_out:                  FREE (newdata->data);          if (newdata->vec)                  FREE (newdata->vec); -        GF_FREE (newdata); +        mem_put (newdata);          return NULL;  } @@ -272,8 +270,7 @@ _dict_set (dict_t *this,                  /* Indicates duplicate key */                  return 0;          } -        pair = (data_pair_t *) GF_CALLOC (1, sizeof (*pair), -                                          gf_common_mt_data_pair_t); +        pair = mem_get0 (THIS->ctx->dict_pair_pool);          if (!pair) {                  return -1;          } @@ -281,7 +278,7 @@ _dict_set (dict_t *this,          pair->key = (char *) GF_CALLOC (1, strlen (key) + 1,                                          gf_common_mt_char);          if (!pair->key) { -                GF_FREE (pair); +                mem_put (pair);                  if (key_free)                          GF_FREE (key); @@ -385,7 +382,7 @@ dict_del (dict_t *this, char *key)                                  pair->next->prev = pair->prev;                          GF_FREE (pair->key); -                        GF_FREE (pair); +                        mem_put (pair);                          this->count--;                          break;                  } @@ -416,11 +413,11 @@ dict_destroy (dict_t *this)                  pair = pair->next;                  data_unref (prev->value);                  GF_FREE (prev->key); -                GF_FREE (prev); +                mem_put (prev);                  prev = pair;          } -        GF_FREE (this->members); +        mem_put (this->members);          if (this->extra_free)                  GF_FREE (this->extra_free); @@ -428,7 +425,7 @@ dict_destroy (dict_t *this)                  free (this->extra_stdfree);          if (!this->is_static) -                GF_FREE (this); +                mem_put (this);          return;  } diff --git a/libglusterfs/src/glusterfs.h b/libglusterfs/src/glusterfs.h index 0ab576798..0d4240a2a 100644 --- a/libglusterfs/src/glusterfs.h +++ b/libglusterfs/src/glusterfs.h @@ -371,6 +371,11 @@ struct _glusterfs_ctx {                                               mempools, used to log details of                                               mempool in statedump */          char                *statedump_path; + +        struct mem_pool    *dict_pool; +        struct mem_pool    *dict_pair_pool; +        struct mem_pool    *dict_data_pool; +  };  typedef struct _glusterfs_ctx glusterfs_ctx_t; | 
