【发布时间】:2015-09-17 20:35:24
【问题描述】:
我正在尝试从使用链接时间代码生成选项生成的.obj 文件中确定 Visual Studio 版本(2002/2003、2005、2008、2010、2012、2013、2015)。
我使用 MSVC2012 生成的文件具有以下 COFF 标头内容:
File Header
+0 00 00 Machine - Unknown Machine
+2 FF FF NumberOfSections
+4 01 00 4C 01 TimeDateStamp
+8 70 94 F9 55 PointerToSymbolTable
+12 38 FE B3 0C NumberOfSymbols
+16 A5 D9 SizeOfOptionalHeader
+18 AB 4D Characteristics
Optional Header
+20 AC 9B Magic
+22 D6 B6 Linker Version Major/Minor
似乎最初的 4 个字节为 00,00,FF,FF 将其标记为 LTCG 对象,后面的内容是专有的。通常的文件头成员都没有“意义”(也许时间戳没问题,我没有检查)。
如果此标头的任何部分是特定于编译器的,是否有人知道?我需要确定的是用于编译对象的 MSVC 主要版本...
似乎有一个版本,编码为<MAJOR:16:LE> 0x80 <MINOR:16:LE>,存储在标题之后不久。例如:
17.00.61030 -> 0x11.0xEE66 -> 11 00 80 66 EE
19.00.23026 -> 0x13.0x59F2 -> 13 00 80 F2 59
我们需要弄清楚如何通过先前数据的偏移量可靠地得到它。
This 是一个相关问题,没有解决方案...
【问题讨论】:
-
/LTCG 是一个链接器选项。但是 .obj 文件是由编译器创建的,链接器从未接近它。所以这没有意义。您可能正在谈论 /GL 选项。是的,它很特别,.obj 文件根本不包含机器代码。它包含 IL,即编译器前端和后端之间使用的中间语言。链接器使用它来重新启动 /LTCG 的后端。如您所料,它完全没有文档记录,如有更改,恕不另行通知。
-
@HansPassant 对于它的价值,已发布的 MSVC 版本不会追溯更改其输出。因此,虽然“更改恕不另行通知”适用于未来的版本,但在实践中并没有太大的障碍。
-
啊,很好,这让我感觉好多了。
-
@HansPassant :) 现在是星期五 :)
标签: visual-studio coff