* dcrt0.cc (__api_fatal): Simplify to just use strace mechamisms.
(do_exit): Move minimal_printf... * pinfo.cc (pinfo::exit): ...into here. * strace.cc (strace::vprntf): Guarantee output to the console when system_printf/api_fatal. * heap.cc (heap_init): Wait a second before issuing an error when ERROR_INVALID_ADDRESS since this is probably due to a CTRL-C handler sneaking in, using the memory that we want to use for the heap, and, eventually exiting.
This commit is contained in:
parent
c675040a06
commit
a16b738dd5
|
@ -1,3 +1,16 @@
|
||||||
|
2005-12-26 Christopher Faylor <cgf@timesys.com>
|
||||||
|
|
||||||
|
* dcrt0.cc (__api_fatal): Simplify to just use strace mechamisms.
|
||||||
|
(do_exit): Move minimal_printf...
|
||||||
|
* pinfo.cc (pinfo::exit): ...into here.
|
||||||
|
* strace.cc (strace::vprntf): Guarantee output to the console when
|
||||||
|
system_printf/api_fatal.
|
||||||
|
|
||||||
|
* heap.cc (heap_init): Wait a second before issuing an error when
|
||||||
|
ERROR_INVALID_ADDRESS since this is probably due to a CTRL-C handler
|
||||||
|
sneaking in, using the memory that we want to use for the heap, and,
|
||||||
|
eventually exiting.
|
||||||
|
|
||||||
2005-12-23 Christopher Faylor <cgf@timesys.com>
|
2005-12-23 Christopher Faylor <cgf@timesys.com>
|
||||||
|
|
||||||
* cygtls.cc (_cygtls::handle_threadlist_exception): Make an error
|
* cygtls.cc (_cygtls::handle_threadlist_exception): Make an error
|
||||||
|
@ -5,7 +18,7 @@
|
||||||
* cygtls.h (sockaddr_in): Use header rather than defining our own
|
* cygtls.h (sockaddr_in): Use header rather than defining our own
|
||||||
structure.
|
structure.
|
||||||
* exceptions.cc (_cygtls::interrupt_setup): Use exact contents of
|
* exceptions.cc (_cygtls::interrupt_setup): Use exact contents of
|
||||||
sa_mask rather than assuming tht current sig should be masked, too.
|
sa_mask rather than assuming that current sig should be masked, too.
|
||||||
(_cygtls::call_signal_handler): Use more aggressive locking.
|
(_cygtls::call_signal_handler): Use more aggressive locking.
|
||||||
* gendef (_sigbe): Wait until later before releasing incyg.
|
* gendef (_sigbe): Wait until later before releasing incyg.
|
||||||
(_sigreturn): Remove more arguments to accommodate quasi-sa_sigaction
|
(_sigreturn): Remove more arguments to accommodate quasi-sa_sigaction
|
||||||
|
@ -14,7 +27,7 @@
|
||||||
* signal.cc (sigaction): Implement SA_NODEFER.
|
* signal.cc (sigaction): Implement SA_NODEFER.
|
||||||
* tlsoffsets.h: Regenerate.
|
* tlsoffsets.h: Regenerate.
|
||||||
|
|
||||||
* sigproc.cc (wait_sig): Use default buffer size or Windows 9x complains.
|
* sigproc.cc (wait_sig): Use default buffer size or Windows 9x complains
|
||||||
|
|
||||||
* pinfo.cc (_onreturn::dummy_handle): Remove.
|
* pinfo.cc (_onreturn::dummy_handle): Remove.
|
||||||
(_onreturn::h): Make this a pointer.
|
(_onreturn::h): Make this a pointer.
|
||||||
|
|
|
@ -1132,7 +1132,6 @@ do_exit (int status)
|
||||||
tty_terminate ();
|
tty_terminate ();
|
||||||
}
|
}
|
||||||
|
|
||||||
minimal_printf ("winpid %d, exit %d", GetCurrentProcessId (), n);
|
|
||||||
myself.exit (n);
|
myself.exit (n);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1171,24 +1170,10 @@ __api_fatal (const char *fmt, ...)
|
||||||
va_list ap;
|
va_list ap;
|
||||||
|
|
||||||
va_start (ap, fmt);
|
va_start (ap, fmt);
|
||||||
int n = __small_sprintf (buf, "%P (%u): *** ", cygwin_pid (GetCurrentProcessId ()));
|
int n = __small_sprintf (buf, "%P: *** fatal error - ", cygwin_pid (GetCurrentProcessId ()));
|
||||||
__small_vsprintf (buf + n, fmt, ap);
|
__small_vsprintf (buf + n, fmt, ap);
|
||||||
va_end (ap);
|
va_end (ap);
|
||||||
strcat (buf, "\n");
|
strace.prntf (_STRACE_SYSTEM, NULL, "%s", buf);
|
||||||
int len = strlen (buf);
|
|
||||||
DWORD done;
|
|
||||||
WriteFile (GetStdHandle (STD_ERROR_HANDLE), buf, len, &done, 0);
|
|
||||||
|
|
||||||
/* Make sure that the message shows up on the screen, too, since this is
|
|
||||||
a serious error. */
|
|
||||||
if (GetFileType (GetStdHandle (STD_ERROR_HANDLE)) != FILE_TYPE_CHAR)
|
|
||||||
{
|
|
||||||
HANDLE h = CreateFile ("CONOUT$", GENERIC_READ | GENERIC_WRITE,
|
|
||||||
FILE_SHARE_WRITE | FILE_SHARE_WRITE,
|
|
||||||
&sec_none, OPEN_EXISTING, 0, 0);
|
|
||||||
if (h != INVALID_HANDLE_VALUE)
|
|
||||||
WriteFile (h, buf, len, &done, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef DEBUGGING
|
#ifdef DEBUGGING
|
||||||
try_to_debug ();
|
try_to_debug ();
|
||||||
|
|
|
@ -76,10 +76,14 @@ heap_init ()
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (!p)
|
if (!p)
|
||||||
|
{
|
||||||
|
if (GetLastError () == ERROR_INVALID_ADDRESS)
|
||||||
|
Sleep (2000);
|
||||||
api_fatal ("couldn't allocate heap, %E, base %p, top %p, "
|
api_fatal ("couldn't allocate heap, %E, base %p, top %p, "
|
||||||
"reserve_size %d, allocsize %d, page_const %d",
|
"reserve_size %d, allocsize %d, page_const %d",
|
||||||
cygheap->user_heap.base, cygheap->user_heap.top,
|
cygheap->user_heap.base, cygheap->user_heap.top,
|
||||||
reserve_size, allocsize, page_const);
|
reserve_size, allocsize, page_const);
|
||||||
|
}
|
||||||
if (p != cygheap->user_heap.base)
|
if (p != cygheap->user_heap.base)
|
||||||
api_fatal ("heap allocated at wrong address %p (mapped) != %p (expected)", p, cygheap->user_heap.base);
|
api_fatal ("heap allocated at wrong address %p (mapped) != %p (expected)", p, cygheap->user_heap.base);
|
||||||
if (!VirtualAlloc (cygheap->user_heap.base, allocsize, MEM_COMMIT, PAGE_READWRITE))
|
if (!VirtualAlloc (cygheap->user_heap.base, allocsize, MEM_COMMIT, PAGE_READWRITE))
|
||||||
|
|
|
@ -139,6 +139,7 @@ pinfo::zap_cwd ()
|
||||||
void
|
void
|
||||||
pinfo::exit (DWORD n)
|
pinfo::exit (DWORD n)
|
||||||
{
|
{
|
||||||
|
minimal_printf ("winpid %d, exit %d", GetCurrentProcessId (), n);
|
||||||
lock_process until_exit ();
|
lock_process until_exit ();
|
||||||
cygthread::terminate ();
|
cygthread::terminate ();
|
||||||
|
|
||||||
|
|
|
@ -202,24 +202,35 @@ void
|
||||||
strace::vprntf (unsigned category, const char *func, const char *fmt, va_list ap)
|
strace::vprntf (unsigned category, const char *func, const char *fmt, va_list ap)
|
||||||
{
|
{
|
||||||
DWORD err = GetLastError ();
|
DWORD err = GetLastError ();
|
||||||
int count;
|
int len;
|
||||||
char buf[10000];
|
char buf[10000];
|
||||||
|
|
||||||
PROTECT (buf);
|
PROTECT (buf);
|
||||||
SetLastError (err);
|
SetLastError (err);
|
||||||
|
|
||||||
count = vsprntf (buf, func, fmt, ap);
|
len = vsprntf (buf, func, fmt, ap);
|
||||||
CHECK (buf);
|
CHECK (buf);
|
||||||
if (category & _STRACE_SYSTEM)
|
if (category & _STRACE_SYSTEM)
|
||||||
{
|
{
|
||||||
DWORD done;
|
DWORD done;
|
||||||
WriteFile (GetStdHandle (STD_ERROR_HANDLE), buf, count, &done, 0);
|
WriteFile (GetStdHandle (STD_ERROR_HANDLE), buf, len, &done, 0);
|
||||||
FlushFileBuffers (GetStdHandle (STD_ERROR_HANDLE));
|
FlushFileBuffers (GetStdHandle (STD_ERROR_HANDLE));
|
||||||
|
/* Make sure that the message shows up on the screen, too, since this is
|
||||||
|
a serious error. */
|
||||||
|
if (GetFileType (GetStdHandle (STD_ERROR_HANDLE)) != FILE_TYPE_CHAR)
|
||||||
|
{
|
||||||
|
HANDLE h = CreateFile ("CONOUT$", GENERIC_READ | GENERIC_WRITE,
|
||||||
|
FILE_SHARE_WRITE | FILE_SHARE_WRITE,
|
||||||
|
&sec_none, OPEN_EXISTING, 0, 0);
|
||||||
|
if (h != INVALID_HANDLE_VALUE)
|
||||||
|
WriteFile (h, buf, len, &done, 0);
|
||||||
|
CloseHandle (h);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NOSTRACE
|
#ifndef NOSTRACE
|
||||||
if (active)
|
if (active)
|
||||||
write (category, buf, count);
|
write (category, buf, len);
|
||||||
#endif
|
#endif
|
||||||
SetLastError (err);
|
SetLastError (err);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue