Konstantin Tokarev
2016-04-22 16:29:41 UTC
Hello,
Are RunLoop::Timer::start() and stop() expected to be thread safe?
For example, VideoRenderRequestScheduler[1] uses Timer::startOneShot() with zero interval as a mean to run task in other thread, which can be cancelled. Timer is initialized with RunLoop::main(), and startOneShot(0) is called from differenet thread.
This approach works at least for GTK and EFL ports, however I'm wondering if this is a correct way to do in principle, or there is better approach which does not involve starting Timer from different thread.
[1] WebCore/platform/graphics/gstreamer/VideoSinkGStreamer.cpp
Are RunLoop::Timer::start() and stop() expected to be thread safe?
For example, VideoRenderRequestScheduler[1] uses Timer::startOneShot() with zero interval as a mean to run task in other thread, which can be cancelled. Timer is initialized with RunLoop::main(), and startOneShot(0) is called from differenet thread.
This approach works at least for GTK and EFL ports, however I'm wondering if this is a correct way to do in principle, or there is better approach which does not involve starting Timer from different thread.
[1] WebCore/platform/graphics/gstreamer/VideoSinkGStreamer.cpp
--
Regards,
Konstantin
Regards,
Konstantin