From: Artur Bergman Date: Sat, 1 Feb 2003 12:01:01 +0000 (+0000) Subject: Don't free thread before using it, breaks platforms that X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=c2f2a82b809cca4067f3f96f30c6d54de2eb4d18;p=p5sagit%2Fp5-mst-13.2.git Don't free thread before using it, breaks platforms that trust that I really want to free what I free, (like HPUX and AIX). p4raw-id: //depot/perl@18615 --- diff --git a/ext/threads/threads.xs b/ext/threads/threads.xs index 043f762..c9c2063 100755 --- a/ext/threads/threads.xs +++ b/ext/threads/threads.xs @@ -91,7 +91,6 @@ perl_key self_key; void Perl_ithread_destruct (pTHX_ ithread* thread, const char *why) { - PerlInterpreter* destroyperl = NULL; MUTEX_LOCK(&thread->mutex); if (!thread->next) { Perl_croak(aTHX_ "panic: destruct destroyed thread %p (%s)",thread, why); @@ -123,26 +122,25 @@ Perl_ithread_destruct (pTHX_ ithread* thread, const char *why) #endif MUTEX_UNLOCK(&create_destruct_mutex); /* Thread is now disowned */ - if (thread->interp) { + + if(thread->interp) { dTHXa(thread->interp); + ithread* current_thread; PERL_SET_CONTEXT(thread->interp); + PERL_THREAD_GETSPECIFIC(self_key,current_thread); + PERL_THREAD_SETSPECIFIC(self_key,thread); SvREFCNT_dec(thread->params); thread->params = Nullsv; - destroyperl = thread->interp; + perl_destruct(thread->interp); + perl_free(thread->interp); thread->interp = NULL; + PERL_THREAD_SETSPECIFIC(self_key,current_thread); + } MUTEX_UNLOCK(&thread->mutex); MUTEX_DESTROY(&thread->mutex); PerlMemShared_free(thread); - if(destroyperl) { - ithread* current_thread; - PERL_THREAD_GETSPECIFIC(self_key,current_thread); - PERL_THREAD_SETSPECIFIC(self_key,thread); - perl_destruct(destroyperl); - perl_free(destroyperl); - PERL_THREAD_SETSPECIFIC(self_key,current_thread); - } PERL_SET_CONTEXT(aTHX); }