malloc() debugging on MacOSX.

This commit is contained in:
Igor Sysoev 2011-10-24 15:46:48 +00:00
parent b9c859e6d5
commit efc6ecab82
13 changed files with 48 additions and 9 deletions

View File

@ -203,9 +203,7 @@ main(int argc, char *const *argv)
ngx_cycle_t *cycle, init_cycle; ngx_cycle_t *cycle, init_cycle;
ngx_core_conf_t *ccf; ngx_core_conf_t *ccf;
#if (NGX_FREEBSD)
ngx_debug_init(); ngx_debug_init();
#endif
if (ngx_strerror_init() != NGX_OK) { if (ngx_strerror_init() != NGX_OK) {
return 1; return 1;

View File

@ -46,10 +46,10 @@
#else #else
#if (NGX_FREEBSD) #if (NGX_HAVE_DEBUG_MALLOC)
#define ngx_slab_junk(p, size) \ #define ngx_slab_junk(p, size) \
if (ngx_freebsd_debug_malloc) ngx_memset(p, 0xD0, size) if (ngx_debug_malloc) ngx_memset(p, 0xD0, size)
#else #else

View File

@ -8,6 +8,7 @@
#define _NGX_DARWIN_H_INCLUDED_ #define _NGX_DARWIN_H_INCLUDED_
void ngx_debug_init(void);
ngx_chain_t *ngx_darwin_sendfile_chain(ngx_connection_t *c, ngx_chain_t *in, ngx_chain_t *ngx_darwin_sendfile_chain(ngx_connection_t *c, ngx_chain_t *in,
off_t limit); off_t limit);
@ -15,5 +16,7 @@ extern int ngx_darwin_kern_osreldate;
extern int ngx_darwin_hw_ncpu; extern int ngx_darwin_hw_ncpu;
extern u_long ngx_darwin_net_inet_tcp_sendspace; extern u_long ngx_darwin_net_inet_tcp_sendspace;
extern ngx_uint_t ngx_debug_malloc;
#endif /* _NGX_DARWIN_H_INCLUDED_ */ #endif /* _NGX_DARWIN_H_INCLUDED_ */

View File

@ -87,6 +87,7 @@
#define NGX_HAVE_OS_SPECIFIC_INIT 1 #define NGX_HAVE_OS_SPECIFIC_INIT 1
#define NGX_HAVE_DEBUG_MALLOC 1
extern char **environ; extern char **environ;

View File

@ -14,6 +14,8 @@ int ngx_darwin_hw_ncpu;
int ngx_darwin_kern_ipc_somaxconn; int ngx_darwin_kern_ipc_somaxconn;
u_long ngx_darwin_net_inet_tcp_sendspace; u_long ngx_darwin_net_inet_tcp_sendspace;
ngx_uint_t ngx_debug_malloc;
static ngx_os_io_t ngx_darwin_io = { static ngx_os_io_t ngx_darwin_io = {
ngx_unix_recv, ngx_unix_recv,
@ -55,6 +57,34 @@ sysctl_t sysctls[] = {
}; };
void
ngx_debug_init()
{
#if (NGX_DEBUG_MALLOC)
/*
* MacOSX 10.6, 10.7: MallocScribble fills freed memory with 0x55
* and fills allocated memory with 0xAA.
* MacOSX 10.4, 10.5: MallocScribble fills freed memory with 0x55,
* MallocPreScribble fills allocated memory with 0xAA.
* MacOSX 10.3: MallocScribble fills freed memory with 0x55,
* and no way to fill allocated memory.
*/
setenv("MallocScribble", "1", 0);
ngx_debug_malloc = 1;
#else
if (getenv("MallocScribble")) {
ngx_debug_malloc = 1;
}
#endif
}
ngx_int_t ngx_int_t
ngx_os_specific_init(ngx_log_t *log) ngx_os_specific_init(ngx_log_t *log)
{ {

View File

@ -8,6 +8,7 @@
#define _NGX_FREEBSD_H_INCLUDED_ #define _NGX_FREEBSD_H_INCLUDED_
void ngx_debug_init(void);
ngx_chain_t *ngx_freebsd_sendfile_chain(ngx_connection_t *c, ngx_chain_t *in, ngx_chain_t *ngx_freebsd_sendfile_chain(ngx_connection_t *c, ngx_chain_t *in,
off_t limit); off_t limit);
@ -17,7 +18,7 @@ extern u_long ngx_freebsd_net_inet_tcp_sendspace;
extern ngx_uint_t ngx_freebsd_sendfile_nbytes_bug; extern ngx_uint_t ngx_freebsd_sendfile_nbytes_bug;
extern ngx_uint_t ngx_freebsd_use_tcp_nopush; extern ngx_uint_t ngx_freebsd_use_tcp_nopush;
extern ngx_uint_t ngx_freebsd_debug_malloc; extern ngx_uint_t ngx_debug_malloc;
#endif /* _NGX_FREEBSD_H_INCLUDED_ */ #endif /* _NGX_FREEBSD_H_INCLUDED_ */

View File

@ -109,6 +109,7 @@ pid_t rfork_thread(int flags, void *stack, int (*func)(void *arg), void *arg);
#define NGX_HAVE_OS_SPECIFIC_INIT 1 #define NGX_HAVE_OS_SPECIFIC_INIT 1
#define NGX_HAVE_DEBUG_MALLOC 1
extern char **environ; extern char **environ;

View File

@ -22,7 +22,8 @@ int ngx_freebsd_machdep_hlt_logical_cpus;
ngx_uint_t ngx_freebsd_sendfile_nbytes_bug; ngx_uint_t ngx_freebsd_sendfile_nbytes_bug;
ngx_uint_t ngx_freebsd_use_tcp_nopush; ngx_uint_t ngx_freebsd_use_tcp_nopush;
ngx_uint_t ngx_freebsd_debug_malloc;
ngx_uint_t ngx_debug_malloc;
static ngx_os_io_t ngx_freebsd_io = { static ngx_os_io_t ngx_freebsd_io = {
@ -80,7 +81,7 @@ ngx_debug_init()
malloc_options = "J"; malloc_options = "J";
#endif #endif
ngx_freebsd_debug_malloc = 1; ngx_debug_malloc = 1;
#else #else
char *mo; char *mo;
@ -88,7 +89,7 @@ ngx_debug_init()
mo = getenv("MALLOC_OPTIONS"); mo = getenv("MALLOC_OPTIONS");
if (mo && ngx_strchr(mo, 'J')) { if (mo && ngx_strchr(mo, 'J')) {
ngx_freebsd_debug_malloc = 1; ngx_debug_malloc = 1;
} }
#endif #endif
} }

View File

@ -108,6 +108,7 @@ typedef struct iocb ngx_aiocb_t;
#define NGX_HAVE_OS_SPECIFIC_INIT 1 #define NGX_HAVE_OS_SPECIFIC_INIT 1
#define ngx_debug_init()
extern char **environ; extern char **environ;

View File

@ -31,7 +31,6 @@ typedef struct {
} ngx_os_io_t; } ngx_os_io_t;
void ngx_debug_init(void);
ngx_int_t ngx_os_init(ngx_log_t *log); ngx_int_t ngx_os_init(ngx_log_t *log);
void ngx_os_status(ngx_log_t *log); void ngx_os_status(ngx_log_t *log);
ngx_int_t ngx_os_specific_init(ngx_log_t *log); ngx_int_t ngx_os_specific_init(ngx_log_t *log);

View File

@ -125,6 +125,8 @@ typedef struct aiocb ngx_aiocb_t;
#define NGX_LISTEN_BACKLOG 511 #define NGX_LISTEN_BACKLOG 511
#define ngx_debug_init()
#if (__FreeBSD__) && (__FreeBSD_version < 400017) #if (__FreeBSD__) && (__FreeBSD_version < 400017)

View File

@ -98,6 +98,7 @@
#define NGX_HAVE_OS_SPECIFIC_INIT 1 #define NGX_HAVE_OS_SPECIFIC_INIT 1
#define ngx_debug_init()
extern char **environ; extern char **environ;

View File

@ -182,6 +182,7 @@ typedef int sig_atomic_t;
#define ngx_random rand #define ngx_random rand
#define ngx_debug_init()
#endif /* _NGX_WIN32_CONFIG_H_INCLUDED_ */ #endif /* _NGX_WIN32_CONFIG_H_INCLUDED_ */