What is the COMDAT section used for?

29.8k views Asked by At

I see the /Gy option and am wondering why I would use it? http://msdn.microsoft.com/en-us/library/xsa71f43.aspx

2

There are 2 answers

2
Scott Wisniewski On

The purpose of a COMDAT section is to allow "duplicate" sections to be defined in multiple object files. Normally, if the same symbol is defined in multiple object files, the linker will report errors. This can cause problems for some C++ language features, like templates, that may instantiate the same symbols in different cpp files.

COMDAT sections are used to get around this. When a section is marked as a COMDAT in an object file, it also specifies a flag that indicates how conflicts should be resolved. There are a bunch of options, including "just pick anyone you like", "make sure all dups. are the same size", "make sure all dups. have the same content", "pick the largest one", etc. See the COFF spec for a complete list.

In any case, unlike what other answers said, there's no requirement, one way or the other, on what the contents of a COMDAT section has to be. They can contain one procedure, many procedures, data, or any combination of both code and data.

2
Dmitriy Yurchenko On

/Gy option is good to be used in release builds. 'cause every function has it's own section, linker can drop every unused piece of code. If you do not specify /Gy option you will get something like this: "a.cpp" defines 3 functions and compiler puts them in one code section when compiling. "main.cpp" uses only one function from "a.cpp", but when linking all of functions from "a.cpp" will be linked (two of them as a burden). And if every function had it's own section, linker could pick up only one that contained function needed by "main.cpp". Compiling without /Gy option is good for debug builds. When compiling a class, all of it's methods get their own separate sections by default.