Defer actually spawning the thread to the call to Run(). The way the thread manager is currently written as a whole won't correctly enforce the thread limit (looking into that, though I think a different approach entirely is merited here anyways), but this at least prevents large numbers of threads from being spawned and sitting in the suspended state in the registrar forever. Fixes ticket #3172.

git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@28774 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Rene Gollent 2008-12-04 00:28:03 +00:00
parent 5b188b1c9f
commit 83868e649d
2 changed files with 10 additions and 9 deletions

View File

@ -35,17 +35,12 @@ RegistrarThread::RegistrarThread(const char *name, int32 priority, BMessenger ma
, fIsFinished(false) , fIsFinished(false)
, fStatus(B_NO_INIT) , fStatus(B_NO_INIT)
, fId(-1) , fId(-1)
, fPriority(priority)
{ {
fName[0] = 0; fName[0] = 0;
status_t err = name && fManagerMessenger.IsValid() ? B_OK : B_BAD_VALUE; status_t err = name && fManagerMessenger.IsValid() ? B_OK : B_BAD_VALUE;
if (!err) { if (err == B_OK)
fId = spawn_thread(&RegistrarThread::EntryFunction, name,
priority, (void*)this);
err = fId >= 0 ? B_OK : fId;
}
if (!err) {
strcpy(fName, name); strcpy(fName, name);
}
fStatus = err; fStatus = err;
} }
@ -72,8 +67,13 @@ status_t
RegistrarThread::Run() RegistrarThread::Run()
{ {
status_t err = InitCheck(); status_t err = InitCheck();
if (!err) if (err == B_OK) {
err = resume_thread(fId); fId = spawn_thread(&RegistrarThread::EntryFunction, fName,
fPriority, (void*)this);
err = fId >= 0 ? B_OK : fId;
if (err == B_OK)
err = resume_thread(fId);
}
return err; return err;
} }

View File

@ -40,6 +40,7 @@ private:
status_t fStatus; status_t fStatus;
thread_id fId; thread_id fId;
char fName[B_OS_NAME_LENGTH]; char fName[B_OS_NAME_LENGTH];
int32 fPriority;
}; };
#endif // REGISTRAR_THREAD_H #endif // REGISTRAR_THREAD_H