2000-02-18 03:38:33 +08:00
|
|
|
/* debug.h
|
|
|
|
|
2001-09-12 04:01:02 +08:00
|
|
|
Copyright 1998, 1999, 2000, 2001 Red Hat, Inc.
|
2000-02-18 03:38:33 +08:00
|
|
|
|
|
|
|
This software is a copyrighted work licensed under the terms of the
|
|
|
|
Cygwin license. Please consult the file "CYGWIN_LICENSE" for
|
|
|
|
details. */
|
|
|
|
|
|
|
|
#ifndef MALLOC_DEBUG
|
|
|
|
#define MALLOC_CHECK do {} while (0)
|
|
|
|
#else
|
2001-04-24 23:25:31 +08:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include "dlmalloc.h"
|
2000-02-18 03:38:33 +08:00
|
|
|
#define MALLOC_CHECK ({\
|
|
|
|
debug_printf ("checking malloc pool");\
|
|
|
|
(void)mallinfo ();\
|
|
|
|
})
|
|
|
|
#endif
|
|
|
|
|
|
|
|
extern "C" {
|
2000-10-17 07:55:58 +08:00
|
|
|
DWORD __stdcall WFSO (HANDLE, DWORD) __attribute__ ((regparm(2)));
|
|
|
|
DWORD __stdcall WFMO (DWORD, CONST HANDLE *, BOOL, DWORD) __attribute__ ((regparm(3)));
|
2000-02-18 03:38:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#define WaitForSingleObject WFSO
|
|
|
|
#define WaitForMultipleObject WFMO
|
|
|
|
|
|
|
|
#if !defined(_DEBUG_H_)
|
|
|
|
#define _DEBUG_H_
|
|
|
|
|
2002-05-27 10:25:28 +08:00
|
|
|
#define being_debugged() \
|
2002-05-28 09:55:40 +08:00
|
|
|
(IsDebuggerPresent () /* || GetLastError () == ERROR_PROC_NOT_FOUND*/)
|
2002-05-27 10:25:28 +08:00
|
|
|
|
2000-02-18 03:38:33 +08:00
|
|
|
void threadname_init ();
|
2001-01-12 13:38:25 +08:00
|
|
|
HANDLE __stdcall makethread (LPTHREAD_START_ROUTINE, LPVOID, DWORD, const char *) __attribute__ ((regparm(3)));
|
|
|
|
const char * __stdcall threadname (DWORD, int lockit = TRUE) __attribute__ ((regparm(2)));
|
|
|
|
void __stdcall regthread (const char *, DWORD) __attribute__ ((regparm(1)));
|
2000-02-24 14:45:32 +08:00
|
|
|
int __stdcall iscygthread ();
|
2000-02-18 03:38:33 +08:00
|
|
|
|
|
|
|
#ifndef DEBUGGING
|
2000-10-17 07:55:58 +08:00
|
|
|
# define cygbench(s)
|
2000-02-18 03:38:33 +08:00
|
|
|
# define ForceCloseHandle CloseHandle
|
|
|
|
# define ForceCloseHandle1(h, n) CloseHandle (h)
|
|
|
|
# define ForceCloseHandle2(h, n) CloseHandle (h)
|
|
|
|
# define ProtectHandle(h) do {} while (0)
|
|
|
|
# define ProtectHandle1(h,n) do {} while (0)
|
|
|
|
# define ProtectHandle2(h,n) do {} while (0)
|
2002-07-14 04:00:27 +08:00
|
|
|
# define ProtectHandleINH(h) do {} while (0)
|
|
|
|
# define ProtectHandle1INH(h,n) do {} while (0)
|
|
|
|
# define ProtectHandle2INH(h,n) do {} while (0)
|
2000-02-18 03:38:33 +08:00
|
|
|
# define debug_init() do {} while (0)
|
2002-07-14 04:00:27 +08:00
|
|
|
# define setclexec(h, nh, b) do {} while (0)
|
|
|
|
# define debug_fixup_after_fork_exec() do {} while (0)
|
2000-02-18 03:38:33 +08:00
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
# ifdef NO_DEBUG_DEFINES
|
|
|
|
# undef NO_DEBUG_DEFINES
|
|
|
|
# else
|
|
|
|
# define CloseHandle(h) \
|
|
|
|
close_handle (__PRETTY_FUNCTION__, __LINE__, (h), #h, FALSE)
|
|
|
|
# define ForceCloseHandle(h) \
|
|
|
|
close_handle (__PRETTY_FUNCTION__, __LINE__, (h), #h, TRUE)
|
|
|
|
# define ForceCloseHandle1(h,n) \
|
|
|
|
close_handle (__PRETTY_FUNCTION__, __LINE__, (h), #n, TRUE)
|
|
|
|
# define ForceCloseHandle2(h,n) \
|
|
|
|
close_handle (__PRETTY_FUNCTION__, __LINE__, (h), n, TRUE)
|
|
|
|
# endif
|
|
|
|
|
|
|
|
# define ProtectHandle(h) add_handle (__PRETTY_FUNCTION__, __LINE__, (h), #h)
|
2001-09-01 13:17:34 +08:00
|
|
|
# define ProtectHandle1(h, n) add_handle (__PRETTY_FUNCTION__, __LINE__, (h), #n)
|
|
|
|
# define ProtectHandle2(h, n) add_handle (__PRETTY_FUNCTION__, __LINE__, (h), n)
|
2002-07-14 04:00:27 +08:00
|
|
|
# define ProtectHandleINH(h) add_handle (__PRETTY_FUNCTION__, __LINE__, (h), #h, 1)
|
|
|
|
# define ProtectHandle1INH(h, n) add_handle (__PRETTY_FUNCTION__, __LINE__, (h), #n, 1)
|
|
|
|
# define ProtectHandle2INH(h, n) add_handle (__PRETTY_FUNCTION__, __LINE__, (h), n, 1)
|
2000-02-18 03:38:33 +08:00
|
|
|
|
|
|
|
void debug_init ();
|
2002-07-14 04:00:27 +08:00
|
|
|
void __stdcall add_handle (const char *, int, HANDLE, const char *, bool = false)
|
2001-09-01 13:17:34 +08:00
|
|
|
__attribute__ ((regparm (3)));
|
|
|
|
BOOL __stdcall close_handle (const char *, int, HANDLE, const char *, BOOL)
|
|
|
|
__attribute__ ((regparm (3)));
|
|
|
|
void __stdcall cygbench (const char *s) __attribute__ ((regparm (1)));
|
2001-08-23 01:50:22 +08:00
|
|
|
extern "C" void console_printf (const char *fmt,...);
|
2002-07-14 04:00:27 +08:00
|
|
|
void setclexec (HANDLE, HANDLE, bool);
|
|
|
|
void debug_fixup_after_fork_exec ();
|
2001-09-01 13:17:34 +08:00
|
|
|
extern int pinger;
|
2000-02-18 03:38:33 +08:00
|
|
|
|
2002-07-14 04:00:27 +08:00
|
|
|
struct handle_list
|
|
|
|
{
|
|
|
|
BOOL allocated;
|
|
|
|
HANDLE h;
|
|
|
|
const char *name;
|
|
|
|
const char *func;
|
|
|
|
int ln;
|
2002-07-15 03:15:32 +08:00
|
|
|
bool inherited;
|
2002-07-14 04:00:27 +08:00
|
|
|
DWORD pid;
|
|
|
|
struct handle_list *next;
|
|
|
|
};
|
|
|
|
|
2000-02-18 03:38:33 +08:00
|
|
|
#endif /*DEBUGGING*/
|
|
|
|
#endif /*_DEBUG_H_*/
|