From: Mathias Fröhlich Date: Sat, 18 Aug 2012 09:43:51 +0000 (+0200) Subject: radeon-llvm: Start multithreaded before using llvm. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=926a4a922f9a5ec397cb3d316dd915b00b39c54d;p=mesa.git radeon-llvm: Start multithreaded before using llvm. This is required to make some of llvm's api calls thread save. In particular the PassRegistry, which is implicitly accessed while compiling shader programs. The PassRegistry uses a mutex that is only active if the llvm_is_multithreaded() returns true. Calling llvm_start_multithreading() makes this happen and by calling this function we try to make sure that we can savely compile shaders in paralell. Since there is also a call llvm_stop_multithreading() in the llvm api, we cannot guarantee that this does not get switched off while we are relying on this being set, but for the easier use cases this fixes a race with the radeon llvm compiler we have as of today. Signed-off-by: Mathias Froehlich Signed-off-by: Tom Stellard --- diff --git a/src/gallium/drivers/radeon/radeon_llvm_emit.cpp b/src/gallium/drivers/radeon/radeon_llvm_emit.cpp index 89130b33157..eef55a8e93a 100644 --- a/src/gallium/drivers/radeon/radeon_llvm_emit.cpp +++ b/src/gallium/drivers/radeon/radeon_llvm_emit.cpp @@ -35,6 +35,7 @@ #include #include #include +#include #include #include @@ -57,6 +58,20 @@ void LLVMInitializeAMDGPUTargetInfo(void); } #endif +namespace { + +class LLVMEnsureMultithreaded { +public: + LLVMEnsureMultithreaded() + { + llvm_start_multithreaded(); + } +}; + +static LLVMEnsureMultithreaded lLVMEnsureMultithreaded; + +} + /** * Compile an LLVM module to machine code. *