diff options
author | cebka@mailsupport.rambler.ru <cebka@mailsupport.rambler.ru> | 2008-09-21 07:23:29 +0400 |
---|---|---|
committer | cebka@mailsupport.rambler.ru <cebka@mailsupport.rambler.ru> | 2008-09-21 07:23:29 +0400 |
commit | 82e2d7ab53eb60bdc52d2e736b097d68d489aa9c (patch) | |
tree | ec77bdc53fdde60016583b0ca012eb11d57f5302 /perl | |
parent | f67c28af2aaf03b60e5bbf606fc694b04ccc68c5 (diff) | |
download | rspamd-82e2d7ab53eb60bdc52d2e736b097d68d489aa9c.tar.gz rspamd-82e2d7ab53eb60bdc52d2e736b097d68d489aa9c.zip |
* Use internal task pool for memcached operation exported for perl
* Make AV reference mortal as it is described in perlxs (3)
Diffstat (limited to 'perl')
-rw-r--r-- | perl/rspamd.xs | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/perl/rspamd.xs b/perl/rspamd.xs index 1632ebade..6bbaaddf1 100644 --- a/perl/rspamd.xs +++ b/perl/rspamd.xs @@ -13,6 +13,7 @@ #include "../config.h" #include "../main.h" #include "../perl.h" +#include "../mem_pool.h" #define perl_set_session(r) \ r = INT2PTR(struct worker_task *, SvIV((SV *) SvRV(ST(0)))) @@ -136,14 +137,14 @@ read_memcached_key (r, key, datalen, callback) callback = SvRV(ST(3)); /* Copy old ctx to new one */ - ctx = malloc (sizeof (memcached_ctx_t)); + ctx = memory_pool_alloc (r->task_pool, sizeof (memcached_ctx_t)); if (ctx == NULL) { XSRETURN_UNDEF; } memcpy (ctx, r->memc_ctx, sizeof (memcached_ctx_t)); /* Set perl callback */ ctx->callback = perl_call_memcached_callback; - callback_data = malloc (sizeof (struct _param)); + callback_data = memory_pool_alloc (r->task_pool, sizeof (struct _param)); if (callback_data == NULL) { XSRETURN_UNDEF; } @@ -152,7 +153,7 @@ read_memcached_key (r, key, datalen, callback) ctx->callback_data = (void *)callback_data; strlcpy (param.key, key, sizeof (param.key)); - param.buf = malloc (datalen); + param.buf = memory_pool_alloc (r->task_pool, datalen); if (param.buf != NULL) { param.bufsize = datalen; } @@ -186,14 +187,14 @@ write_memcached_key (r, key, data, expire, callback) callback = SvRV(ST(4)); /* Copy old ctx to new one */ - ctx = malloc (sizeof (memcached_ctx_t)); + ctx = memory_pool_alloc (r->task_pool, sizeof (memcached_ctx_t)); if (ctx == NULL) { XSRETURN_UNDEF; } memcpy (ctx, r->memc_ctx, sizeof (memcached_ctx_t)); /* Set perl callback */ ctx->callback = perl_call_memcached_callback; - callback_data = malloc (sizeof (struct _param)); + callback_data = memory_pool_alloc (r->task_pool, sizeof (struct _param)); if (callback_data == NULL) { XSRETURN_UNDEF; } @@ -231,14 +232,14 @@ delete_memcached_key (r, key, callback) callback = SvRV(ST(2)); /* Copy old ctx to new one */ - ctx = malloc (sizeof (memcached_ctx_t)); + ctx = memory_pool_alloc (r->task_pool, sizeof (memcached_ctx_t)); if (ctx == NULL) { XSRETURN_UNDEF; } memcpy (ctx, r->memc_ctx, sizeof (memcached_ctx_t)); /* Set perl callback */ ctx->callback = perl_call_memcached_callback; - callback_data = malloc (sizeof (struct _param)); + callback_data = memory_pool_alloc (r->task_pool, sizeof (struct _param)); if (callback_data == NULL) { XSRETURN_UNDEF; } |