RESOLVED FIXED 137195
[WK2][EFL] Fix the problem that threads created by a DispatchQueueEfl are not destroyed even after the DispatchQueueEfl has been destructed
https://bugs.webkit.org/show_bug.cgi?id=137195
Summary [WK2][EFL] Fix the problem that threads created by a DispatchQueueEfl are not...
Joonghun Park
Reported 2014-09-28 09:50:12 PDT
Linux and Unix System's pthread is created in joinable state by default. So it is needed to detach the thread explicitly after dispatchQueue is destructed. Currently, even after DispatchQueueEfl was destructed the thread created by a DispatchQueueEfl is not destroyed because there is no explicit detachThread command. It leads to maximum number of threads which is allowed by a process in platform in case iterating creation and deletion of plugin process many times and lock-up is occurred in conclusion.
Attachments
Patch (2.56 KB, patch)
2014-09-28 09:56 PDT, Joonghun Park
no flags
Patch (3.04 KB, patch)
2014-09-28 10:47 PDT, Joonghun Park
no flags
Patch (3.24 KB, patch)
2014-09-28 11:13 PDT, Joonghun Park
no flags
Patch (3.37 KB, patch)
2014-10-06 22:34 PDT, Joonghun Park
no flags
Patch (3.71 KB, patch)
2014-10-08 05:02 PDT, Joonghun Park
no flags
Patch (2.14 KB, patch)
2014-10-13 23:17 PDT, Joonghun Park
no flags
Patch (2.14 KB, patch)
2014-10-13 23:35 PDT, Joonghun Park
no flags
Joonghun Park
Comment 1 2014-09-28 09:56:22 PDT
Joonghun Park
Comment 2 2014-09-28 10:47:16 PDT
Joonghun Park
Comment 3 2014-09-28 11:13:56 PDT
Joonghun Park
Comment 4 2014-10-06 22:34:53 PDT
Gyuyoung Kim
Comment 5 2014-10-08 03:26:09 PDT
Comment on attachment 239390 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=239390&action=review > Source/WebKit2/ChangeLog:3 > + [WK2][EFL] Fix not destroyed thread created by DispatchQueueEfl even after the DispatchQueueEfl has been destructed Not clear bug title. > Source/WebKit2/ChangeLog:8 > + Linux and Unix System's pthread is created in joinable state by default. I don't get this patch description. Please improve it further. > Source/WebKit2/ChangeLog:10 > + The call to waitForThreadCompletion() in ~DispatchQueue() is for this purpose. I don't read this sentence. > Source/WebKit2/Platform/efl/DispatchQueueEfl.h:67 > + ThreadIdentifier m_threadID; If you declare this below bool m_isThreadRunning, you don't need to change m_isThreadRunning in DispatchQueue::DispatchQueue()
Joonghun Park
Comment 6 2014-10-08 05:02:21 PDT
Gyuyoung Kim
Comment 7 2014-10-10 22:52:45 PDT
Comment on attachment 239469 [details] Patch Patch looks reasonable for me. However it would be great other folks also take a look this patch. Add byungwoo to CC.
Gyuyoung Kim
Comment 8 2014-10-12 20:35:02 PDT
Comment on attachment 239469 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=239469&action=review BTW I wonder whether there is any regression on EFL layout test. Did you run layout test with this patch ? > Source/WebKit2/ChangeLog:8 > + Linux and Unix System's pthread is created in joinable state by default. pthread is -> pthreads are > Source/WebKit2/ChangeLog:9 > + It means that if the created threads are not destructed explicitly, How about below sentence ? "If threads aren't destructed explicitly, it will be still live until process which created the thread is dead. Besides it may cause out of capacity range of thread creation in a process. It is one of hidden defects. Thus we need to destroy the thread together when DispatchQueue's dtor is called. This patch calls waitForThreadCompletion() to destroy the thread in dtor of DispatchQueue class"
Gyuyoung Kim
Comment 9 2014-10-12 20:35:33 PDT
Comment on attachment 239469 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=239469&action=review > Source/WebKit2/Platform/efl/DispatchQueueEfl.cpp:74 > + , m_threadID(0) One more thing. 0 -> nullptr ?
Byungwoo Lee
Comment 10 2014-10-13 01:30:00 PDT
Do we have to join the created thread at the DispatchQueue destructor? How about detaching after the thread was created? Is there any problem to do so?
Joonghun Park
Comment 11 2014-10-13 01:40:07 PDT
(In reply to comment #10) > Do we have to join the created thread at the DispatchQueue destructor? > How about detaching after the thread was created? Is there any problem to do so? If the dispatchQueue object is destructed prior to the entry function of the dispatchQueue thread, dispatchQueue's m_workItems is valid no more. If under the circumstances, DispatchQueue::performWork() is called, it leads to crash or locking up. That's why we should use pthread_join in dtor of DispatchQueue class, I think.
Byungwoo Lee
Comment 12 2014-10-13 01:48:06 PDT
(In reply to comment #11) > (In reply to comment #10) > > Do we have to join the created thread at the DispatchQueue destructor? > > How about detaching after the thread was created? Is there any problem to do so? > > If the dispatchQueue object is destructed prior to the entry function of the dispatchQueue thread, dispatchQueue's m_workItems is valid no more. > If under the circumstances, DispatchQueue::performWork() is called, it leads to crash or locking up. That's why we should use pthread_join in dtor of DispatchQueue class, I think. How can it be possible? DispatchQueue::ThreadContext has the reference of DispatchQueue and the context will be passed to the thread function.
Byungwoo Lee
Comment 13 2014-10-13 01:59:33 PDT
Comment on attachment 239469 [details] Patch DispatchQueue can be destroyed at the ThreadContext::function because the DispatchQueue::ThreadContext has a reference of the DispatchQueue instance. Joining the thread at the DispatchQueue destructor can lead a infinite waiting of the created thread.
Joonghun Park
Comment 14 2014-10-13 03:14:06 PDT
(In reply to comment #13) > (From update of attachment 239469 [details]) > DispatchQueue can be destroyed at the ThreadContext::function because the DispatchQueue::ThreadContext has a reference of the DispatchQueue instance. Joining the thread at the DispatchQueue destructor can lead a infinite waiting of the created thread. I examined the code carefully again, and I found that you're right. ThreadContext object has a RefPtr and passed to ThreadContext::function() as arguments. So I see that the destruction sequence is garanteed what which only after ThreadContext::function() is completed the DispatchQueue object can be destructed. I will use detachThread() in ~DispatchQueue() instead of pthread_join. Thank you for your advice~
Gyuyoung Kim
Comment 15 2014-10-13 03:17:06 PDT
(In reply to comment #13) > (From update of attachment 239469 [details]) > DispatchQueue can be destroyed at the ThreadContext::function because the DispatchQueue::ThreadContext has a reference of the DispatchQueue instance. Joining the thread at the DispatchQueue destructor can lead a infinite waiting of the created thread. Nice review Byungwoo ! I missed that DispatchQueue::ThreadContext has a reference of DispatchQueue though it looks very basic behavior.
Byungwoo Lee
Comment 16 2014-10-13 03:38:08 PDT
:) And could you please check one more? As I mentioned before, I think that it will be better to detach the thread right after the thread was created instead of ~DispatchQueue() if it is possible. To do so, we can remove redundant m_threadID.
Joonghun Park
Comment 17 2014-10-13 23:17:43 PDT
Byungwoo Lee
Comment 18 2014-10-13 23:23:49 PDT
Comment on attachment 239780 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=239780&action=review > Source/WebKit2/ChangeLog:16 > + Thus we need to destroy the thread together > + when DispatchQueue's dtor is called. > + This patch calls waitForThreadCompletion() to destroy the thread in dtor of DispatchQueue class. These need to be updated.
Joonghun Park
Comment 19 2014-10-13 23:35:10 PDT
Joonghun Park
Comment 20 2014-10-13 23:36:11 PDT
(In reply to comment #18) > (From update of attachment 239780 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=239780&action=review > > > Source/WebKit2/ChangeLog:16 > > + Thus we need to destroy the thread together > > + when DispatchQueue's dtor is called. > > + This patch calls waitForThreadCompletion() to destroy the thread in dtor of DispatchQueue class. > > These need to be updated. I revised the comment. Please check it once again.
Byungwoo Lee
Comment 21 2014-10-13 23:43:00 PDT
LGTM if you verified tests with this patch.
Joonghun Park
Comment 22 2014-10-13 23:45:00 PDT
(In reply to comment #21) > LGTM if you verified tests with this patch. I executed regression tests with this patch and there was no regression caused by this patch.
Joonghun Park
Comment 23 2014-10-13 23:47:24 PDT
(In reply to comment #22) > (In reply to comment #21) > > LGTM if you verified tests with this patch. > > I executed regression tests with this patch and there was no regression caused by this patch. I mean, layout test.
Gyuyoung Kim
Comment 24 2014-10-14 02:29:51 PDT
Comment on attachment 239782 [details] Patch r+ed based on Byungwoo internal review.
WebKit Commit Bot
Comment 25 2014-10-14 17:53:12 PDT
Comment on attachment 239782 [details] Patch Clearing flags on attachment: 239782 Committed r174719: <http://trac.webkit.org/changeset/174719>
WebKit Commit Bot
Comment 26 2014-10-14 17:53:17 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.