Reorganize some quick-and-dirty code to find out what openssl stuff is leaking, using dmalloc.

svn:r5178
This commit is contained in:
Nick Mathewson 2005-10-03 20:20:38 +00:00
parent 9e54e2e293
commit c5ee3e961e
3 changed files with 33 additions and 21 deletions

View File

@ -96,7 +96,7 @@ const char util_c_id[] = "$Id$";
* ===== */
#ifdef USE_DMALLOC
#include <dmalloc.h>
#define DMALLOC_FN_ARGS file, line,
#define DMALLOC_FN_ARGS , file, line
#else
#define dmalloc_strdup(file, line, string, xalloc_b) strdup(string)
@ -116,7 +116,7 @@ const char util_c_id[] = "$Id$";
* ignored otherwise.
*/
void *
_tor_malloc(DMALLOC_PARAMS size_t size)
_tor_malloc(size_t size DMALLOC_PARAMS)
{
void *result;
@ -141,9 +141,9 @@ _tor_malloc(DMALLOC_PARAMS size_t size)
* the process on error. (Same as calloc(size,1), but never returns NULL.)
*/
void *
_tor_malloc_zero(DMALLOC_PARAMS size_t size)
_tor_malloc_zero(size_t size DMALLOC_PARAMS)
{
void *result = _tor_malloc(DMALLOC_FN_ARGS size);
void *result = _tor_malloc(size DMALLOC_FN_ARGS);
memset(result, 0, size);
return result;
}
@ -153,7 +153,7 @@ _tor_malloc_zero(DMALLOC_PARAMS size_t size)
* terminate. (Like realloc(ptr,size), but never returns NULL.)
*/
void *
_tor_realloc(DMALLOC_PARAMS void *ptr, size_t size)
_tor_realloc(void *ptr, size_t size DMALLOC_PARAMS)
{
void *result;
@ -170,7 +170,7 @@ _tor_realloc(DMALLOC_PARAMS void *ptr, size_t size)
* NULL.)
*/
char *
_tor_strdup(DMALLOC_PARAMS const char *s)
_tor_strdup(const char *s DMALLOC_PARAMS)
{
char *dup;
tor_assert(s);
@ -190,11 +190,11 @@ _tor_strdup(DMALLOC_PARAMS const char *s)
* NULL.)
*/
char *
_tor_strndup(DMALLOC_PARAMS const char *s, size_t n)
_tor_strndup(const char *s, size_t n DMALLOC_PARAMS)
{
char *dup;
tor_assert(s);
dup = _tor_malloc(DMALLOC_FN_ARGS n+1);
dup = _tor_malloc((n+1) DMALLOC_FN_ARGS);
/* Performance note: Ordinarily we prefer strlcpy to strncpy. But
* this function gets called a whole lot, and platform strncpy is
* much faster than strlcpy when strlen(s) is much longer than n.

View File

@ -48,8 +48,8 @@
#endif
#ifdef USE_DMALLOC
#define DMALLOC_PARAMS const char *file, const int line,
#define DMALLOC_ARGS _SHORT_FILE_, __LINE__,
#define DMALLOC_PARAMS , const char *file, const int line
#define DMALLOC_ARGS , _SHORT_FILE_, __LINE__
#else
#define DMALLOC_PARAMS
#define DMALLOC_ARGS
@ -61,11 +61,11 @@
#define tor_fragile_assert()
/* Memory management */
void *_tor_malloc(DMALLOC_PARAMS size_t size);
void *_tor_malloc_zero(DMALLOC_PARAMS size_t size);
void *_tor_realloc(DMALLOC_PARAMS void *ptr, size_t size);
char *_tor_strdup(DMALLOC_PARAMS const char *s);
char *_tor_strndup(DMALLOC_PARAMS const char *s, size_t n);
void *_tor_malloc(size_t size DMALLOC_PARAMS);
void *_tor_malloc_zero(size_t size DMALLOC_PARAMS);
void *_tor_realloc(void *ptr, size_t size DMALLOC_PARAMS);
char *_tor_strdup(const char *s DMALLOC_PARAMS);
char *_tor_strndup(const char *s, size_t n DMALLOC_PARAMS);
#ifdef USE_DMALLOC
extern int dmalloc_free(const char *file, const int line, void *pnt,
const int func_id);
@ -79,11 +79,11 @@ extern int dmalloc_free(const char *file, const int line, void *pnt,
#define tor_free(p) do { if (p) {free(p); (p)=NULL;} } while (0)
#endif
#define tor_malloc(size) _tor_malloc(DMALLOC_ARGS size)
#define tor_malloc_zero(size) _tor_malloc_zero(DMALLOC_ARGS size)
#define tor_realloc(ptr, size) _tor_realloc(DMALLOC_ARGS ptr, size)
#define tor_strdup(s) _tor_strdup(DMALLOC_ARGS s)
#define tor_strndup(s, n) _tor_strndup(DMALLOC_ARGS s, n)
#define tor_malloc(size) _tor_malloc(size DMALLOC_ARGS)
#define tor_malloc_zero(size) _tor_malloc_zero(size DMALLOC_ARGS)
#define tor_realloc(ptr, size) _tor_realloc(ptr, size DMALLOC_ARGS)
#define tor_strdup(s) _tor_strdup(s DMALLOC_ARGS)
#define tor_strndup(s, n) _tor_strndup(s, n DMALLOC_ARGS)
/* String manipulation */
#define HEX_CHARACTERS "0123456789ABCDEFabcdef"

View File

@ -1907,10 +1907,23 @@ nt_strerror(uint32_t errnum)
}
#endif
#ifdef USE_DMALLOC
#include <openssl/crypto.h>
static void
_tor_dmalloc_free(void *p)
{
tor_free(p);
}
#endif
/** DOCDOC */
int
tor_main(int argc, char *argv[])
{
#ifdef USE_DMALLOC
int r = CRYPTO_set_mem_ex_functions(_tor_malloc, _tor_realloc, _tor_dmalloc_free);
log_fn(LOG_NOTICE, "r = %d", r);
#endif
#ifdef MS_WINDOWS_SERVICE
backup_argv = argv;
backup_argc = argc;
@ -1963,4 +1976,3 @@ tor_main(int argc, char *argv[])
tor_cleanup();
return -1;
}