diff options
author | Christopher Faylor <me@cgf.cx> | 2008-08-01 19:12:49 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2008-08-01 19:12:49 +0000 |
commit | b23b171641332bb24736274825e558175b1acf13 (patch) | |
tree | 06819fed79a28367844dd8d83ebc6f2ff6608a5c | |
parent | 3462d736b64e2601971fb185cbf83cb8828208c3 (diff) | |
download | newlib-b23b171641332bb24736274825e558175b1acf13.zip newlib-b23b171641332bb24736274825e558175b1acf13.tar.gz newlib-b23b171641332bb24736274825e558175b1acf13.tar.bz2 |
* dcrt0.cc (dll_crt0_1): Add a symbol denoting return from call to main().
* exceptions.cc (stack_info::walk): Stop walking the stack when we hit
_cygwin_exit_return rather than just blindly stopping when PC becomes zero.
-rw-r--r-- | winsup/cygwin/ChangeLog | 8 | ||||
-rw-r--r-- | winsup/cygwin/dcrt0.cc | 4 | ||||
-rw-r--r-- | winsup/cygwin/exceptions.cc | 9 |
3 files changed, 18 insertions, 3 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index d1c1ae7..e907245 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,11 @@ +2008-08-01 Christopher Faylor <me+cygwin@cgf.cx> + + * dcrt0.cc (dll_crt0_1): Add a symbol denoting return from call to + main(). + * exceptions.cc (stack_info::walk): Stop walking the stack when we + hit _cygwin_exit_return rather than just blindly stopping when PC + becomes zero. + 2008-07-31 Corinna Vinschen <corinna@vinschen.de> * path.cc (symlink_info::check): Handle (and explain) a special case diff --git a/winsup/cygwin/dcrt0.cc b/winsup/cygwin/dcrt0.cc index 6b2d283..e37cbec 100644 --- a/winsup/cygwin/dcrt0.cc +++ b/winsup/cygwin/dcrt0.cc @@ -933,6 +933,10 @@ dll_crt0_1 (void *) ld_preload (); if (user_data->main) cygwin_exit (user_data->main (__argc, __argv, *user_data->envptr)); + __asm__ (" \n\ + .global __cygwin_exit_return \n\ +__cygwin_exit_return: \n\ +"); } extern "C" void __stdcall diff --git a/winsup/cygwin/exceptions.cc b/winsup/cygwin/exceptions.cc index 9b7c980..e744e7c 100644 --- a/winsup/cygwin/exceptions.cc +++ b/winsup/cygwin/exceptions.cc @@ -243,21 +243,24 @@ stack_info::init (DWORD ebp, bool wantargs, bool goodframe) # undef debp } +extern "C" void _cygwin_exit_return (); + /* Walk the stack by looking at successive stored 'bp' frames. This is not foolproof. */ int stack_info::walk () { char **ebp; + + if ((void (*) ()) sf.AddrPC.Offset == _cygwin_exit_return) + return 0; /* stack frames are exhausted */ + if (((ebp = (char **) next_offset ()) == NULL) || (ebp >= (char **) cygwin_hmodule)) return 0; sf.AddrFrame.Offset = (DWORD) ebp; sf.AddrPC.Offset = sf.AddrReturn.Offset; - if (!sf.AddrPC.Offset) - return 0; /* stack frames are exhausted */ - /* The return address always follows the stack pointer */ sf.AddrReturn.Offset = (DWORD) *++ebp; |