From 926a4a922f9a5ec397cb3d316dd915b00b39c54d Mon Sep 17 00:00:00 2001 From: =?utf8?q?Mathias=20Fr=C3=B6hlich?= Date: Sat, 18 Aug 2012 11:43:51 +0200 Subject: [PATCH] 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 --- src/gallium/drivers/radeon/radeon_llvm_emit.cpp | 15 +++++++++++++++ 1 file changed, 15 insertions(+) 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. * -- 2.30.2