diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 4639df4828..fbfe4aded6 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2015-11-17 Pedro Alves + + * windows-nat.c (handle_exception): Return 0 for first chance + exceptions. + (get_windows_debug_event): Adjust. + 2015-11-17 Pedro Alves * windows-nat.c (xslate): Use GDB_SIGNAL_UNKNOWN instead of -1 as diff --git a/gdb/windows-nat.c b/gdb/windows-nat.c index cce10f8818..a7132d6210 100644 --- a/gdb/windows-nat.c +++ b/gdb/windows-nat.c @@ -1124,7 +1124,7 @@ handle_exception (struct target_waitstatus *ourstatus) default: /* Treat unhandled first chance exceptions specially. */ if (current_event.u.Exception.dwFirstChance) - return -1; + return 0; printf_unfiltered ("gdb: unknown target exception 0x%08x at %s\n", (unsigned) current_event.u.Exception.ExceptionRecord.ExceptionCode, host_address_to_string ( @@ -1491,19 +1491,10 @@ get_windows_debug_event (struct target_ops *ops, "EXCEPTION_DEBUG_EVENT")); if (saw_create != 1) break; - switch (handle_exception (ourstatus)) - { - case 0: - continue_status = DBG_EXCEPTION_NOT_HANDLED; - break; - case 1: - thread_id = current_event.dwThreadId; - break; - case -1: - last_sig = 1; - continue_status = -1; - break; - } + if (handle_exception (ourstatus)) + thread_id = current_event.dwThreadId; + else + continue_status = DBG_EXCEPTION_NOT_HANDLED; break; case OUTPUT_DEBUG_STRING_EVENT: /* Message from the kernel. */ @@ -1529,10 +1520,7 @@ get_windows_debug_event (struct target_ops *ops, if (!thread_id || saw_create != 1) { - if (continue_status == -1) - windows_resume (ops, minus_one_ptid, 0, 1); - else - CHECK (windows_continue (continue_status, -1, 0)); + CHECK (windows_continue (continue_status, -1, 0)); } else {