diff --git a/include/llvm/PassSupport.h b/include/llvm/PassSupport.h index 006fefa0b35..ecccf791fe0 100644 --- a/include/llvm/PassSupport.h +++ b/include/llvm/PassSupport.h @@ -24,6 +24,7 @@ #include "Pass.h" #include "llvm/PassRegistry.h" #include "llvm/InitializePasses.h" +#include "llvm/Support/Compiler.h" #include namespace llvm { @@ -129,21 +130,20 @@ private: }; #define INITIALIZE_PASS(passName, arg, name, cfg, analysis) \ - void llvm::initialize##passName##Pass(PassRegistry &Registry) { \ - static bool initialized = false; \ - if (initialized) return; \ - initialized = true; \ + static void* initialize##passName##PassOnce(PassRegistry &Registry) { \ PassInfo *PI = new PassInfo(name, arg, & passName ::ID, \ PassInfo::NormalCtor_t(callDefaultCtor< passName >), cfg, analysis); \ Registry.registerPass(*PI); \ + return PI; \ + } \ + void llvm::initialize##passName##Pass(PassRegistry &Registry) { \ + ATTRIBUTE_USED \ + static void* initialized = initialize##passName##PassOnce(Registry); \ } \ static RegisterPass passName ## _info(arg, name, cfg, analysis); #define INITIALIZE_PASS_BEGIN(passName, arg, name, cfg, analysis) \ - void llvm::initialize##passName##Pass(PassRegistry &Registry) { \ - static bool initialized = false; \ - if (initialized) return; \ - initialized = true; + static void* initialize##passName##PassOnce(PassRegistry &Registry) { #define INITIALIZE_PASS_DEPENDENCY(depName) \ initialize##depName##Pass(Registry); @@ -154,6 +154,11 @@ private: PassInfo *PI = new PassInfo(name, arg, & passName ::ID, \ PassInfo::NormalCtor_t(callDefaultCtor< passName >), cfg, analysis); \ Registry.registerPass(*PI); \ + return PI; \ + } \ + void llvm::initialize##passName##Pass(PassRegistry &Registry) { \ + ATTRIBUTE_USED \ + static void* initialized = initialize##passName##PassOnce(Registry); \ } \ static RegisterPass passName ## _info(arg, name, cfg, analysis); @@ -232,14 +237,19 @@ struct RegisterAnalysisGroup : public RegisterAGBase { }; #define INITIALIZE_ANALYSIS_GROUP(agName, name) \ - void llvm::initialize##agName##AnalysisGroup(PassRegistry &Registry) { \ + static void* initialize##agName##AnalysisGroupOnce(PassRegistry &Registry) { \ PassInfo *AI = new PassInfo(name, & agName :: ID); \ Registry.registerAnalysisGroup(& agName ::ID, 0, *AI, false); \ + return AI; \ + } \ + void llvm::initialize##agName##AnalysisGroup(PassRegistry &Registry) { \ + ATTRIBUTE_USED static void* initialized = \ + initialize##agName##AnalysisGroupOnce(Registry); \ } \ static RegisterAnalysisGroup agName##_info (name); #define INITIALIZE_AG_PASS(passName, agName, arg, name, cfg, analysis, def) \ - void llvm::initialize##passName##Pass(PassRegistry &Registry) { \ + static void* initialize##passName##PassOnce(PassRegistry &Registry) { \ initialize##agName##AnalysisGroup(Registry); \ PassInfo *PI = new PassInfo(name, arg, & passName ::ID, \ PassInfo::NormalCtor_t(callDefaultCtor< passName >), cfg, analysis); \ @@ -247,12 +257,17 @@ struct RegisterAnalysisGroup : public RegisterAGBase { \ PassInfo *AI = new PassInfo(name, & agName :: ID); \ Registry.registerAnalysisGroup(& agName ::ID, & passName ::ID, *AI, def); \ + return AI; \ + } \ + void llvm::initialize##passName##Pass(PassRegistry &Registry) { \ + ATTRIBUTE_USED \ + static void* initialized = initialize##passName##PassOnce(Registry); \ } \ static RegisterPass passName ## _info(arg, name, cfg, analysis); \ static RegisterAnalysisGroup passName ## _ag(passName ## _info); #define INITIALIZE_AG_PASS_BEGIN(passName, agName, arg, n, cfg, analysis, def) \ - void llvm::initialize##passName##Pass(PassRegistry &Registry) { \ + static void* initialize##passName##PassOnce(PassRegistry &Registry) { \ initialize##agName##AnalysisGroup(Registry); #define INITIALIZE_AG_PASS_END(passName, agName, arg, n, cfg, analysis, def) \ @@ -262,6 +277,11 @@ struct RegisterAnalysisGroup : public RegisterAGBase { \ PassInfo *AI = new PassInfo(n, & agName :: ID); \ Registry.registerAnalysisGroup(& agName ::ID, & passName ::ID, *AI, def); \ + return AI; \ + } \ + void llvm::initialize##passName##Pass(PassRegistry &Registry) { \ + ATTRIBUTE_USED \ + static void* initialized = initialize##passName##PassOnce(Registry); \ } \ static RegisterPass passName ## _info(arg, n, cfg, analysis); \ static RegisterAnalysisGroup passName ## _ag(passName ## _info);