Commit 4705b8a6 authored by Alexandre Julliard's avatar Alexandre Julliard

Avoid crash when trying to attach to a terminating process.

parent 23d4aab2
...@@ -425,6 +425,7 @@ static int debugger_attach( struct process *process, struct thread *debugger ) ...@@ -425,6 +425,7 @@ static int debugger_attach( struct process *process, struct thread *debugger )
if (process->debugger) goto error; /* already being debugged */ if (process->debugger) goto error; /* already being debugged */
if (process->init_event) goto error; /* still starting up */ if (process->init_event) goto error; /* still starting up */
if (!process->thread_list) goto error; /* no thread running in the process */
/* make sure we don't create a debugging loop */ /* make sure we don't create a debugging loop */
for (thread = debugger; thread; thread = thread->process->debugger) for (thread = debugger; thread; thread = thread->process->debugger)
...@@ -437,19 +438,18 @@ static int debugger_attach( struct process *process, struct thread *debugger ) ...@@ -437,19 +438,18 @@ static int debugger_attach( struct process *process, struct thread *debugger )
suspend_process( process ); suspend_process( process );
/* we must have been able to attach all threads */ /* we must have been able to attach all threads */
if (!process->thread_list) goto error2;
for (thread = process->thread_list; thread; thread = thread->proc_next) for (thread = process->thread_list; thread; thread = thread->proc_next)
{ {
if (!thread->attached) if (!thread->attached) goto error2;
{
resume_process( process );
goto error;
}
} }
if (set_process_debugger( process, debugger )) return 1; if (set_process_debugger( process, debugger )) return 1;
resume_process( process ); resume_process( process );
return 0; return 0;
error2:
resume_process( process );
error: error:
set_error( STATUS_ACCESS_DENIED ); set_error( STATUS_ACCESS_DENIED );
return 0; return 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment