DX11 Updating Shared Textures
I have a shared DX11 texture that is being used with 2 different devices in separate threads. Thread1 (operating on device 1): Called every frame and updates the shared texture Thread2(operating on device2): Consumes the shared texture by copying it to another texture. Frequency is much lesser than thread 1. According to MSDN "If a shared texture is updated on one device ID3D11DeviceContext::Flush must be called on that device." However calling flush on thread1 every frame is very expensive and we see a massive performance hit. We can't flush device 1 on thread 2, because a device context is not thread safe. Is there a way to efficiently make the shared texture update when threads 2 needs to consume it? Thanks for your help! MSDN is not very helpful when dealing with shared textures. emphasized text
In order to synchronize the access to the shared resource between two threads (or interprocess) you can use IDXGIKeyedMutex. It is described here in details: https://msdn.microsoft.com/en-us/library/windows/desktop/ee913554(v=vs.85).aspx#dxgi_1.1_synchronized_shared_surfaces You can check the sample code provided as well although they show only resource sharing between two DX10 devices. It is the same for DX11 devices. The essential part is to QueryInterface the shared texture for IDXGIResource first and then for IDXGIKeyedMutex. After that you use the mutex for synchronization by using AcquireSync and ReleaseSync functions.
System.Threading.QueueUserWorkItemCallback related startup crash
C pipes inter process communication
Acquiring a RwLock for read and keep it beyond the scope
Do threads share local variables?
How to completely terminate Parallel task from main thread?
How does OpenMP do thread allocation?
Overwrite file data efficiently
Does increasing number of cores speed up execution time of a program where threads currently have 50% IO contention?
Arc reference to member of field
Trouble Writing multiThread Chat program
display heavy real time data on winforms application
How to check if Anonymous thread is running
Detailed difference between Java8 ForkJoinPool and Executors.newWorkStealingPool?
Number of threads in Loop parallelisation using OpenMP in C
OpenCl - Global and local size - differences and why increasing local size only sometimes is noticable?
How to compile and spawn/run the projects(http and worker) from a main application?