r260267 - Pass /bigobj when building lib/ASTMatchers/Dynamic/Registry.cpp
Reid Kleckner via cfe-commits
cfe-commits at lists.llvm.org
Tue Feb 9 11:53:31 PST 2016
Author: rnk
Date: Tue Feb 9 13:53:30 2016
New Revision: 260267
URL: http://llvm.org/viewvc/llvm-project?rev=260267&view=rev
Log:
Pass /bigobj when building lib/ASTMatchers/Dynamic/Registry.cpp
This is the third time it has crossed the 2^16 section limit. We've
already spent time optimizing this file to reduce template
instantiations, and it's not clear that there is anymore low hanging
fruit.
Modified:
cfe/trunk/lib/ASTMatchers/Dynamic/CMakeLists.txt
Modified: cfe/trunk/lib/ASTMatchers/Dynamic/CMakeLists.txt
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/ASTMatchers/Dynamic/CMakeLists.txt?rev=260267&r1=260266&r2=260267&view=diff
==============================================================================
--- cfe/trunk/lib/ASTMatchers/Dynamic/CMakeLists.txt (original)
+++ cfe/trunk/lib/ASTMatchers/Dynamic/CMakeLists.txt Tue Feb 9 13:53:30 2016
@@ -1,5 +1,14 @@
set(LLVM_LINK_COMPONENTS support)
+# The registry source file ends up generating a lot of sections for each
+# matcher. Each matcher appears to get a vtable and several methods. Each
+# method needs .text, .pdata, .xdata, and .debug sections, adding to the
+# section multiplier. By default MSVC has a 2^16 limit on the number of
+# sections in an object file, and this needs more than that.
+if (MSVC)
+ set_source_files_properties(Registry.cpp PROPERTIES COMPILE_FLAGS /bigobj)
+endif()
+
add_clang_library(clangDynamicASTMatchers
Diagnostics.cpp
VariantValue.cpp
More information about the cfe-commits
mailing list