Chromium Code Reviews| Index: Source/modules/webaudio/DeferredTaskHandler.cpp |
| diff --git a/Source/modules/webaudio/DeferredTaskHandler.cpp b/Source/modules/webaudio/DeferredTaskHandler.cpp |
| index c2605c157caa2787a5da09895322d8aa52a7ff66..7b635016c2b10687d0001547dd8a9bc2428aaf6b 100644 |
| --- a/Source/modules/webaudio/DeferredTaskHandler.cpp |
| +++ b/Source/modules/webaudio/DeferredTaskHandler.cpp |
| @@ -42,6 +42,19 @@ void DeferredTaskHandler::lock() |
| m_contextGraphMutex.lock(); |
| } |
| +void DeferredTaskHandler::forceLock() |
| +{ |
| + // This allows the regular lock in non-real-time audio thread. |
|
Raymond Toy
2015/06/16 17:57:09
I think this can only be used with an online conte
hongchan
2015/06/16 21:31:21
No. This lock is only for offline audio context. M
Raymond Toy
2015/06/16 21:46:38
Typo on my part. I meant offline. I think since i
|
| + ASSERT(!isMainThread()); |
| + if (isMainThread()) { |
|
Raymond Toy
2015/06/16 17:57:09
This is confusing. You ASSERT that it's not the m
hongchan
2015/06/16 21:31:20
I though we discussed this: for debug build, the a
Raymond Toy
2015/06/16 21:46:38
As we discussed offline, this is ok. But now I wo
|
| + // If this gets called in the main thread, do tryLock() instead. |
| + m_contextGraphMutex.tryLock(); |
| + return; |
| + } |
| + |
| + m_contextGraphMutex.lock(); |
| +} |
| + |
| bool DeferredTaskHandler::tryLock() |
| { |
| // Try to catch cases of using try lock on main thread |