functionality. * cygheap.cc (init_cheap): Move cygheap_max calculation to _csbrk. (_csbrk): Reorganize to not assume first allocation is <= 1 page. (cygheap_setup_for_child): Mark protected handle as inheritable. * cygheap.h (cygheap_debug): New struct. (init_cygheap): Add new structure when debugging. * dcrt0.cc (dll_crt0_1): Remove call to debug_init. Close ppid_handle here, if appropriate. Don't protect subproc_ready, since it is already protected in the parent. Call memory_init prior to ProtectHandle to ensure that cygheap is set up. Call debug_fixup_after_fork_exec when appropriate. (_dll_crt0): Don't close ppid_handle here. * debug.cc: Use cygheap debug structure rather than static elements throughout. (add_handle): Don't issue a warning if attempt to protect handle in exactly the same way from exactly the same place. Add pid info to warning output. Accept additional argument controlling whether handle is to be inherited. Add pid to stored information. (debug_fixup_after_fork_exec): Renamed from debug_fixup_after_fork. Reorganize to avoid erroneously skipping handles. (mark_closed): Add pid info to warning output. (setclexec): Rename from setclexec_pid. * fhandler.cc (fhandler_base::get_default_fmode): Minor reorg. (fhandler_base::fstat): Add debugging output. (fhandler_base::set_inheritance): Call setclexec rather than setclexec_pid. (fhandler_base::fork_fixup): Ditto. * fhandler_console.cc (get_tty_stuff): Mark protected handle as inheritable. * fhandler_tty.cc (fhandler_tty_slave::open): Ditto. * tty.cc (tty::make_pipes): Ditto. (tty::common_init): Ditto. * fork.cc (fork_parent): Ditto. (fork_child): Close protected handles with correct name. Remove debug_fixup_after_fork call. * fhandler_socket.cc (fhandler_socket::create_secret_event): Mark protected handle as inheritable/non-inheritable, as appropriate. * shared.cc (memory_init): Mark protected handle as inheritable. Call debug_init here. * sigproc.cc (wait_sig): Close protected handle with correct name. * spawn.cc (spawn_guts): Rename spr to subproc_ready and mark it as inheritable. * exceptions.cc (debugger_command): Try to run dumper.exe, if found. * syscalls.cc (fstat64): Don't follow symlinks for path_conv lookup since path is already resolved.
102 lines
3.3 KiB
C
102 lines
3.3 KiB
C
/* debug.h
|
|
|
|
Copyright 1998, 1999, 2000, 2001 Red Hat, Inc.
|
|
|
|
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
|
|
#include <stdlib.h>
|
|
#include "dlmalloc.h"
|
|
#define MALLOC_CHECK ({\
|
|
debug_printf ("checking malloc pool");\
|
|
(void)mallinfo ();\
|
|
})
|
|
#endif
|
|
|
|
extern "C" {
|
|
DWORD __stdcall WFSO (HANDLE, DWORD) __attribute__ ((regparm(2)));
|
|
DWORD __stdcall WFMO (DWORD, CONST HANDLE *, BOOL, DWORD) __attribute__ ((regparm(3)));
|
|
}
|
|
|
|
#define WaitForSingleObject WFSO
|
|
#define WaitForMultipleObject WFMO
|
|
|
|
#if !defined(_DEBUG_H_)
|
|
#define _DEBUG_H_
|
|
|
|
#define being_debugged() \
|
|
(IsDebuggerPresent () /* || GetLastError () == ERROR_PROC_NOT_FOUND*/)
|
|
|
|
void threadname_init ();
|
|
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)));
|
|
int __stdcall iscygthread ();
|
|
|
|
#ifndef DEBUGGING
|
|
# define cygbench(s)
|
|
# 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)
|
|
# define ProtectHandleINH(h) do {} while (0)
|
|
# define ProtectHandle1INH(h,n) do {} while (0)
|
|
# define ProtectHandle2INH(h,n) do {} while (0)
|
|
# define debug_init() do {} while (0)
|
|
# define setclexec(h, nh, b) do {} while (0)
|
|
# define debug_fixup_after_fork_exec() do {} while (0)
|
|
|
|
#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)
|
|
# define ProtectHandle1(h, n) add_handle (__PRETTY_FUNCTION__, __LINE__, (h), #n)
|
|
# define ProtectHandle2(h, n) add_handle (__PRETTY_FUNCTION__, __LINE__, (h), n)
|
|
# 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)
|
|
|
|
void debug_init ();
|
|
void __stdcall add_handle (const char *, int, HANDLE, const char *, bool = false)
|
|
__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)));
|
|
extern "C" void console_printf (const char *fmt,...);
|
|
void setclexec (HANDLE, HANDLE, bool);
|
|
void debug_fixup_after_fork_exec ();
|
|
extern int pinger;
|
|
|
|
struct handle_list
|
|
{
|
|
BOOL allocated;
|
|
HANDLE h;
|
|
const char *name;
|
|
const char *func;
|
|
int ln;
|
|
bool clexec;
|
|
DWORD pid;
|
|
struct handle_list *next;
|
|
};
|
|
|
|
#endif /*DEBUGGING*/
|
|
#endif /*_DEBUG_H_*/
|