Бинарное воспроизведение boost 1.50
Мне нужно посмотреть, возможно ли сделать двоичный код Boost 1.50 воспроизводимым с минимальными изменениями исходного кода, насколько это возможно, для обеспечения целостности исходного кода. Задача состоит в том, чтобы сделать это без изменения любого файла.cpp или.hpp.
Простая его компиляция дважды и выполнение diff показывает сбой из-за макросов __TIME__ и __DATE__, которые появляются в библиотеках boost WAVE и SPIRIT.
Я компилирую с использованием g++ 4.1.1. Кто-нибудь знает способ сказать препроцессору отменять или переопределять эти макросы через какую-то переменную окружения? Если не env var, то какая-нибудь опция командной строки g ++? Я предполагаю, что возможно, что я мог бы отредактировать некоторый файл.jam, чтобы переопределить __TIME__ и __DATE__, макрос в???? или что там говорит gcc, по умолчанию это когда не могут быть решены.
Возможно, существует способ заставить препроцессор не иметь возможности определять текущую дату и время, который я мог бы включить, построить, а затем отключить?
Любые идеи по этому поводу будут наиболее ценными. Спасибо.
Изменить: для тех, кто следил за этим, я думаю, что я сделал серьезную ошибку в своем первоначальном вопросе. Теперь я обнаружил, что простые параллельные сборки с одной и той же точной командой сборки bjam создают файлы.a и.so, которые кардинально отличаются от макросов DATE и TIME. Двоичные шестнадцатеричные различия показывают большие порции различий в файлах.so. Кажется, что файлы.a следуют шаблону одинаковых значений, которые постоянно различаются (и это вполне могут быть значения макросов TIME и DATE), но файлы.so даже не находятся на одном уровне. Если у кого-то есть настроение, я призываю вас дважды повысить надстройку 1.50, сравнив результаты сборки, и постараюсь засвидетельствовать, что нет никаких существенных различий, кроме просто информативного различия, которое могло бы представлять изменение даты / времени сборки.
Редактировать (продолжение!): После долгих поисков я обнаружил что-то вроде противоречивого искажения имен. Создавая только усиленную файловую систему, дважды, спиной к спине, и проверяя различия между файлами path.o между ними, я заметил это:
нм первого path.o: 00000000 б _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_8F1C916311path_localeE 0000000c б _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_8F1C916312dot_dot_pathE 00000000 00000004 г _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_8F1C916316separator_stringE б _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_8F1C916317codecvt_facet_ptrE 00000004 00000008 г _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_8F1C916326preferred_separator_stringE б _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_8F1C91638dot_pathE
нм второго path.o: 00000000 б _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_EDDD474511path_localeE 0000000c б _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_EDDD474512dot_dot_pathE 00000000 00000004 г _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_EDDD474516separator_stringE б _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_EDDD474517codecvt_facet_ptrE 00000004 00000008 г _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_EDDD474526preferred_separator_stringE б _ZN57_GLOBAL__N_libs_filesystem_src_path.cpp_00000000_EDDD47458dot_pathE
Я не думаю, что видел подобные вещи раньше. Почему эти конкретные определения локальных переменных будут искажены с помощью EDDD4745, а не 8F1C9163? Какие-нибудь мысли? Моя голова уже однажды взорвалась сегодня (решается ближайшим домкратом). Этот просто порочный.
Редактировать: v3)
Я все еще на это, к сожалению. На данный момент я нахожусь на уровне спецификации файла ELF, пытаясь определить, что меняется. Я сейчас работаю с файловой системой boost. Моя команда BJAM
`./b2 -a --with-filesystem --debug-building -d+2 toolset=gcc define=__DATE__="??" define=__TIME__="??" pch=off hardcode-dll-paths=false strip=on`
Попытка определить, что, черт возьми, вызывает эти различия, является довольно сложной задачей. readelf полезен, но только в точку. У меня есть различие двух команд readelf для двух сборок надстройки над filesystem.so, которые использовали ОДИН И ТОТ ЖЕ КОД ИСТОЧНИКА. Я еще недостаточно осведомлен об этом материале, чтобы понять, что влияет на эти изменения, возможно, кто-то в мире.
`diff x1diff x2diff
120,123c120,123
< 00015044 0000cc01 R_386_32 00015070 _ZTIN5boost6system14er
< 0001506c 0000cc01 R_386_32 00015070 _ZTIN5boost6system14er
< 00015048 0000d701 R_386_32 00005760 _ZN5boost6system14erro
< 0001504c 0000af01 R_386_32 00005730 _ZN5boost6system14erro
---
> 00015044 0000cd01 R_386_32 00015070 _ZTIN5boost6system14er
> 0001506c 0000cd01 R_386_32 00015070 _ZTIN5boost6system14er
> 00015048 0000d801 R_386_32 00005760 _ZN5boost6system14erro
> 0001504c 0000b001 R_386_32 00005730 _ZN5boost6system14erro
128,133c128,133
< 00015058 00009801 R_386_32 00005690 _ZNK5boost6system14err
< 000150b8 00009801 R_386_32 00005690 _ZNK5boost6system14err
< 0001505c 0000bf01 R_386_32 000056b0 _ZNK5boost6system14err
< 000150bc 0000bf01 R_386_32 000056b0 _ZNK5boost6system14err
< 00015060 0000a901 R_386_32 00005710 _ZNK5boost6system14err
< 000150c0 0000a901 R_386_32 00005710 _ZNK5boost6system14err
---
> 00015058 00009901 R_386_32 00005690 _ZNK5boost6system14err
> 000150b8 00009901 R_386_32 00005690 _ZNK5boost6system14err
> 0001505c 0000c001 R_386_32 000056b0 _ZNK5boost6system14err
> 000150bc 0000c001 R_386_32 000056b0 _ZNK5boost6system14err
> 00015060 0000aa01 R_386_32 00005710 _ZNK5boost6system14err
> 000150c0 0000aa01 R_386_32 00005710 _ZNK5boost6system14err
141,142c141,142
< 00015068 0000f001 R_386_32 00012180 _ZTSN75_GLOBAL__N_libs
< 00015074 00007b01 R_386_32 00012200 _ZTSN5boost6system14er
---
> 00015068 00007701 R_386_32 00012180 _ZTSN75_GLOBAL__N_libs
> 00015074 00007c01 R_386_32 00012200 _ZTSN5boost6system14er
146,152c146,152
< 00015080 00007e01 R_386_32 00012220 _ZTSN5boost12noncopyab
< 000150a4 0000d801 R_386_32 00015064 _ZTIN75_GLOBAL__N_libs
< 000150cc 00007801 R_386_32 000150dc _ZTIN5boost6system12sy
< 000150f0 00007801 R_386_32 000150dc _ZTIN5boost6system12sy
< 00015300 00007806 R_386_GLOB_DAT 000150dc _ZTIN5boost6system12sy
< 000150d0 00009701 R_386_32 0000c810 _ZN5boost6system12syst
< 000152f4 00009706 R_386_GLOB_DAT 0000c810 _ZN5boost6system12syst
---
> 00015080 00007f01 R_386_32 00012220 _ZTSN5boost12noncopyab
> 000150a4 0000ea01 R_386_32 00015064 _ZTIN75_GLOBAL__N_libs
> 000150cc 00007901 R_386_32 000150dc _ZTIN5boost6system12sy
> 000150f0 00007901 R_386_32 000150dc _ZTIN5boost6system12sy
> 00015300 00007906 R_386_GLOB_DAT 000150dc _ZTIN5boost6system12sy
> 000150d0 00009801 R_386_32 0000c810 _ZN5boost6system12syst
> 000152f4 00009806 R_386_GLOB_DAT 0000c810 _ZN5boost6system12syst
154c154
< 000150d8 0000a501 R_386_32 0000c8b0 _ZNK5boost6system12sys
---
> 000150d8 0000a601 R_386_32 0000c8b0 _ZNK5boost6system12sys
158,161c158,161
< 000150fc 0000a301 R_386_32 000150e8 _ZTIN5boost10filesyste
< 00015304 0000a306 R_386_GLOB_DAT 000150e8 _ZTIN5boost10filesyste
< 00015100 00009501 R_386_32 0000cdd0 _ZN5boost10filesystem1
< 000152e4 00009506 R_386_GLOB_DAT 0000cdd0 _ZN5boost10filesystem1
---
> 000150fc 0000a401 R_386_32 000150e8 _ZTIN5boost10filesyste
> 00015304 0000a406 R_386_GLOB_DAT 000150e8 _ZTIN5boost10filesyste
> 00015100 00009601 R_386_32 0000cdd0 _ZN5boost10filesystem1
> 000152e4 00009606 R_386_GLOB_DAT 0000cdd0 _ZN5boost10filesystem1
163,164c163,164
< 00015108 0000c701 R_386_32 0000d6d0 _ZNK5boost10filesystem
< 00015114 0000d201 R_386_32 0001512c _ZTIN5boost6detail17sp
---
> 00015108 0000c801 R_386_32 0000d6d0 _ZNK5boost10filesystem
> 00015114 0000d301 R_386_32 0001512c _ZTIN5boost6detail17sp
166,176c166,176
< 0001511c 0000b001 R_386_32 0000c700 _ZN5boost6detail17sp_c
< 00015120 00008b01 R_386_32 0000cb10 _ZN5boost6detail17sp_c
< 00015124 00009301 R_386_32 0000c620 _ZN5boost6detail15sp_c
< 00015154 00009301 R_386_32 0000c620 _ZN5boost6detail15sp_c
< 00015174 00009301 R_386_32 0000c620 _ZN5boost6detail15sp_c
< 00015128 0000c101 R_386_32 0000c650 _ZN5boost6detail17sp_c
< 00015130 0000cf01 R_386_32 00012680 _ZTSN5boost6detail17sp
< 00015134 0000a801 R_386_32 00015138 _ZTIN5boost6detail15sp
< 00015144 0000a801 R_386_32 00015138 _ZTIN5boost6detail15sp
< 00015184 0000a801 R_386_32 00015138 _ZTIN5boost6detail15sp
< 0001513c 0000bb01 R_386_32 000126e0 _ZTSN5boost6detail15sp
---
> 0001511c 0000b101 R_386_32 0000c700 _ZN5boost6detail17sp_c
> 00015120 00008c01 R_386_32 0000cb10 _ZN5boost6detail17sp_c
> 00015124 00009401 R_386_32 0000c620 _ZN5boost6detail15sp_c
> 00015154 00009401 R_386_32 0000c620 _ZN5boost6detail15sp_c
> 00015174 00009401 R_386_32 0000c620 _ZN5boost6detail15sp_c
> 00015128 0000c201 R_386_32 0000c650 _ZN5boost6detail17sp_c
> 00015130 0000d001 R_386_32 00012680 _ZTSN5boost6detail17sp
> 00015134 0000a901 R_386_32 00015138 _ZTIN5boost6detail15sp
> 00015144 0000a901 R_386_32 00015138 _ZTIN5boost6detail15sp
> 00015184 0000a901 R_386_32 00015138 _ZTIN5boost6detail15sp
> 0001513c 0000bc01 R_386_32 000126e0 _ZTSN5boost6detail15sp
178c178
< 0001514c 0000d501 R_386_32 0000c670 _ZN5boost6detail15sp_c
---
> 0001514c 0000d601 R_386_32 0000c670 _ZN5boost6detail15sp_c
180,189c180,189
< 00015168 0000ed01 R_386_32 0000c6e0 _ZN5boost6detail17sp_c
< 0001516c 0000c501 R_386_32 0000c730 _ZN5boost6detail17sp_c
< 00015170 00007c01 R_386_32 0000ca30 _ZN5boost6detail17sp_c
< 00015178 0000c301 R_386_32 0000c660 _ZN5boost6detail17sp_c
< 00015180 0000ae01 R_386_32 00012720 _ZTSN5boost6detail17sp
< 000151a4 0000c801 R_386_32 000151d0 _ZTIN5boost10filesyste
< 000151a8 0000d401 R_386_32 000120c0 _ZN5boost10filesystem6
< 000151ac 0000ab01 R_386_32 00012080 _ZN5boost10filesystem6
< 000151b0 0000aa01 R_386_32 00011ee0 _ZNK5boost10filesystem
< 000151b4 0000bd01 R_386_32 00012050 _ZNK5boost10filesystem
---
> 00015168 0000ee01 R_386_32 0000c6e0 _ZN5boost6detail17sp_c
> 0001516c 0000c601 R_386_32 0000c730 _ZN5boost6detail17sp_c
> 00015170 00007d01 R_386_32 0000ca30 _ZN5boost6detail17sp_c
> 00015178 0000c401 R_386_32 0000c660 _ZN5boost6detail17sp_c
> 00015180 0000af01 R_386_32 00012720 _ZTSN5boost6detail17sp
> 000151a4 0000c901 R_386_32 000151d0 _ZTIN5boost10filesyste
> 000151a8 0000d501 R_386_32 000120c0 _ZN5boost10filesystem6
> 000151ac 0000ac01 R_386_32 00012080 _ZN5boost10filesystem6
> 000151b0 0000ab01 R_386_32 00011ee0 _ZNK5boost10filesystem
> 000151b4 0000be01 R_386_32 00012050 _ZNK5boost10filesystem
192c192
< 000151c0 0000ce01 R_386_32 00012040 _ZNK5boost10filesystem
---
> 000151c0 0000cf01 R_386_32 00012040 _ZNK5boost10filesystem
194,196c194,196
< 000151c8 00008801 R_386_32 00012070 _ZNK5boost10filesystem
< 000151cc 00009601 R_386_32 00011cb0 _ZNK5boost10filesystem
< 000151d4 00008901 R_386_32 00012900 _ZTSN5boost10filesyste
---
> 000151c8 00008901 R_386_32 00012070 _ZNK5boost10filesystem
> 000151cc 00009701 R_386_32 00011cb0 _ZNK5boost10filesystem
> 000151d4 00008a01 R_386_32 00012900 _ZTSN5boost10filesyste
202c202
< 000152f0 0000a206 R_386_GLOB_DAT 00015110 _ZTVN5boost6detail17sp
---
> 000152f0 0000a306 R_386_GLOB_DAT 00015110 _ZTVN5boost6detail17sp
207c207
< 00015314 0000b506 R_386_GLOB_DAT 00015160 _ZTVN5boost6detail17sp
---
> 00015314 0000b606 R_386_GLOB_DAT 00015160 _ZTVN5boost6detail17sp
223c223
< 00015350 00007f07 R_386_JUMP_SLOT 0000e3e0 _ZNK5boost10filesystem
---
> 00015350 00008007 R_386_JUMP_SLOT 0000e3e0 _ZNK5boost10filesystem
227c227
< 00015360 0000b207 R_386_JUMP_SLOT 00009d10 _ZN5boost10filesystem6
---
> 00015360 0000b307 R_386_JUMP_SLOT 00009d10 _ZN5boost10filesystem6
230,231c230,231
< 0001536c 0000c607 R_386_JUMP_SLOT 0000f8e0 _ZNK5boost10filesystem
< 00015370 00009d07 R_386_JUMP_SLOT 0000e370 _ZN5boost10filesystem4
---
> 0001536c 0000c707 R_386_JUMP_SLOT 0000f8e0 _ZNK5boost10filesystem
> 00015370 00009e07 R_386_JUMP_SLOT 0000e370 _ZN5boost10filesystem4
235,237c235,237
< 00015380 00007707 R_386_JUMP_SLOT 000078a0 _ZN5boost10filesystem6
< 00015384 0000b607 R_386_JUMP_SLOT 0000cf20 _ZN5boost10filesystem1
< 00015388 0000b807 R_386_JUMP_SLOT 0000f490 _ZN5boost10filesystem4
---
> 00015380 00007807 R_386_JUMP_SLOT 000078a0 _ZN5boost10filesystem6
> 00015384 0000b707 R_386_JUMP_SLOT 0000cf20 _ZN5boost10filesystem1
> 00015388 0000b907 R_386_JUMP_SLOT 0000f490 _ZN5boost10filesystem4
239c239
< 00015390 0000a007 R_386_JUMP_SLOT 000099f0 _ZN5boost10filesystem6
---
> 00015390 0000a107 R_386_JUMP_SLOT 000099f0 _ZN5boost10filesystem6
241c241
< 00015398 00008507 R_386_JUMP_SLOT 00005880 _ZN5boost10filesystem6
---
> 00015398 00008607 R_386_JUMP_SLOT 00005880 _ZN5boost10filesystem6
250c250
< 000153bc 0000d607 R_386_JUMP_SLOT 00010770 _ZNK5boost10filesystem
---
> 000153bc 0000d707 R_386_JUMP_SLOT 00010770 _ZNK5boost10filesystem
254,255c254,255
< 000153cc 0000d007 R_386_JUMP_SLOT 000092c0 _ZN5boost10filesystem6
< 000153d0 0000a407 R_386_JUMP_SLOT 0000f2b0 _ZNK5boost10filesystem
---
> 000153cc 0000d107 R_386_JUMP_SLOT 000092c0 _ZN5boost10filesystem6
> 000153d0 0000a507 R_386_JUMP_SLOT 0000f2b0 _ZNK5boost10filesystem
257c257
< 000153d8 0000cd07 R_386_JUMP_SLOT 000095f0 _ZN5boost10filesystem6
---
> 000153d8 0000ce07 R_386_JUMP_SLOT 000095f0 _ZN5boost10filesystem6
260c260
< 000153e4 00008f07 R_386_JUMP_SLOT 000069e0 _ZN5boost10filesystem6
---
> 000153e4 00009007 R_386_JUMP_SLOT 000069e0 _ZN5boost10filesystem6
269c269
< 00015408 0000ee07 R_386_JUMP_SLOT 00011ea0 _ZNK5boost10filesystem
---
> 00015408 0000ef07 R_386_JUMP_SLOT 00011ea0 _ZNK5boost10filesystem
272,273c272,273
< 00015414 0000ca07 R_386_JUMP_SLOT 0000f7d0 _ZNK5boost10filesystem
< 00015418 0000d107 R_386_JUMP_SLOT 0000df70 _ZNK5boost10filesystem
---
> 00015414 0000cb07 R_386_JUMP_SLOT 0000f7d0 _ZNK5boost10filesystem
> 00015418 0000d207 R_386_JUMP_SLOT 0000df70 _ZNK5boost10filesystem
277c277
< 00015428 0000c907 R_386_JUMP_SLOT 0000d2f0 _ZN5boost10filesystem1
---
> 00015428 0000ca07 R_386_JUMP_SLOT 0000d2f0 _ZN5boost10filesystem1
286,287c286,287
< 0001544c 0000b707 R_386_JUMP_SLOT 0000e190 _ZNK5boost10filesystem
< 00015450 0000c007 R_386_JUMP_SLOT 00011c70 _ZN5boost10filesystem6
---
> 0001544c 0000b807 R_386_JUMP_SLOT 0000e190 _ZNK5boost10filesystem
> 00015450 0000c107 R_386_JUMP_SLOT 00011c70 _ZN5boost10filesystem6
295c295
< 00015470 0000ea07 R_386_JUMP_SLOT 000063c0 _ZN5boost10filesystem6
---
> 00015470 0000eb07 R_386_JUMP_SLOT 000063c0 _ZN5boost10filesystem6
297c297
< 00015478 00008e07 R_386_JUMP_SLOT 00011170 _ZN5boost10filesystem1
---
> 00015478 00008f07 R_386_JUMP_SLOT 00011170 _ZN5boost10filesystem1
303c303
< 00015490 0000a707 R_386_JUMP_SLOT 0000ded0 _ZN5boost10filesystem4
---
> 00015490 0000a807 R_386_JUMP_SLOT 0000ded0 _ZN5boost10filesystem4
306c306
< 0001549c 00009e07 R_386_JUMP_SLOT 00005490 _ZN5boost10filesystem2
---
> 0001549c 00009f07 R_386_JUMP_SLOT 00005490 _ZN5boost10filesystem2
319c319
< 000154d0 00007d07 R_386_JUMP_SLOT 0000efd0 _ZNK5boost10filesystem
---
> 000154d0 00007e07 R_386_JUMP_SLOT 0000efd0 _ZNK5boost10filesystem
325,326c325,326
< 000154e8 00008c07 R_386_JUMP_SLOT 00010eb0 _ZN5boost10filesystem1
< 000154ec 00008207 R_386_JUMP_SLOT 000091c0 _ZN5boost10filesystem6
---
> 000154e8 00008d07 R_386_JUMP_SLOT 00010eb0 _ZN5boost10filesystem1
> 000154ec 00008307 R_386_JUMP_SLOT 000091c0 _ZN5boost10filesystem6
329c329
< 000154f8 00008d07 R_386_JUMP_SLOT 0000ea70 _ZN5boost10filesystem4
---
> 000154f8 00008e07 R_386_JUMP_SLOT 0000ea70 _ZN5boost10filesystem4
334c334
< 0001550c 00009007 R_386_JUMP_SLOT 0000fbb0 _ZNK5boost10filesystem
---
> 0001550c 00009107 R_386_JUMP_SLOT 0000fbb0 _ZNK5boost10filesystem
337,340c337,340
< 00015518 0000eb07 R_386_JUMP_SLOT 00011270 _ZN5boost10filesystem1
< 0001551c 0000b107 R_386_JUMP_SLOT 000114b0 _ZN5boost10filesystem1
< 00015520 00009b07 R_386_JUMP_SLOT 0000c640 _ZN5boost6detail26sp_e
< 00015524 00009c07 R_386_JUMP_SLOT 0000f000 _ZNK5boost10filesystem
---
> 00015518 0000ec07 R_386_JUMP_SLOT 00011270 _ZN5boost10filesystem1
> 0001551c 0000b207 R_386_JUMP_SLOT 000114b0 _ZN5boost10filesystem1
> 00015520 00009c07 R_386_JUMP_SLOT 0000c640 _ZN5boost6detail26sp_e
> 00015524 00009d07 R_386_JUMP_SLOT 0000f000 _ZNK5boost10filesystem
342c342
< 0001552c 0000a607 R_386_JUMP_SLOT 0000dd00 _ZN5boost10filesystem4
---
> 0001552c 0000a707 R_386_JUMP_SLOT 0000dd00 _ZN5boost10filesystem4
344c344
< 00015534 0000ad07 R_386_JUMP_SLOT 00007aa0 _ZN5boost10filesystem6
---
> 00015534 0000ae07 R_386_JUMP_SLOT 00007aa0 _ZN5boost10filesystem6
591,597c591,597
< 234: 000063c0 1559 FUNC GLOBAL DEFAULT 10 _ZN5boost10filesystem6det
< 235: 00011270 81 FUNC GLOBAL DEFAULT 10 _ZN5boost10filesystem19po
< 236: 00009020 405 FUNC GLOBAL DEFAULT 10 _ZN5boost10filesystem6det
< 237: 0000c6e0 30 FUNC WEAK DEFAULT 10 _ZN5boost6detail17sp_coun
< 238: 00011ea0 59 FUNC GLOBAL DEFAULT 10 _ZNK5boost10filesystem6de
< 239: 000155b8 8 OBJECT WEAK DEFAULT 24 _ZGVZNK5boost10filesystem
< 240: 00012180 99 OBJECT WEAK DEFAULT 12 _ZTSN75_GLOBAL__N_libs_fi
---
> 234: 00015064 12 OBJECT WEAK DEFAULT 19 _ZTIN75_GLOBAL__N_libs_fi
> 235: 000063c0 1559 FUNC GLOBAL DEFAULT 10 _ZN5boost10filesystem6det
> 236: 00011270 81 FUNC GLOBAL DEFAULT 10 _ZN5boost10filesystem19po
> 237: 00009020 405 FUNC GLOBAL DEFAULT 10 _ZN5boost10filesystem6det
> 238: 0000c6e0 30 FUNC WEAK DEFAULT 10 _ZN5boost6detail17sp_coun
> 239: 00011ea0 59 FUNC GLOBAL DEFAULT 10 _ZNK5boost10filesystem6de
> 240: 000155b8 8 OBJECT WEAK DEFAULT 24 _ZGVZNK5boost10filesystem
619,623c619,623
< 0 42 ( 32.1%)
< 1 49 ( 37.4%) 34.8%
< 2 32 ( 24.4%) 80.1%
< 3 4 ( 3.1%) 88.7%
< 4 4 ( 3.1%) 100.0%
---
> 0 41 ( 31.3%)
> 1 50 ( 38.2%) 35.5%
> 2 32 ( 24.4%) 80.9%
> 3 5 ( 3.8%) 91.5%
> 4 3 ( 2.3%) 100.0%`
(Я должен был сократить некоторые записи в файле, чтобы поместиться в посте). По большей части, похоже, что номера строк некоторых из этих записей различаются. Что может изменить порядок записей символов в файле ELF?
1 ответ
Я наконец нашел ответ, и я не могу поверить, что мне понадобилось так много времени, чтобы найти его. Здесь обсуждаются анонимные пространства имен, а не сами по себе. Очевидно, boost 1_50 содержит несколько анонимных пространств имен. Похоже, что компилятор, который я использую, ABI gcc 4.1.1 или любой другой (и, возможно, другие более поздние или даже более старые) генерирует новый и другой UUID для префикса символов в этих анонимных пространствах имен каждый раз, когда модуль трансляции компилируется, я полагаю, для причины применения уникальности к символам для внешней связи (правильно? не правильно?). Решением в этом случае является использование флага -frandom-seed, предоставленного компилятором. Я был наконец предупрежден о том, что может происходить, когда случайно наткнулся на эту страницу.
Вот документация для флага компилятора frandom-seed.
Мой вариант использования для этого оказался -frandom-seed="0"
В конце концов, это не имело ничего общего с макросами __DATE __ и __ TIME__ (до тех пор, пока они не имели дело с boost WAVE и SPIRIT, которые содержат их в 1.50).
Этот действительно избил меня.
Под тэгом "двоичная воспроизводимость" переполнение стека, похоже, не имеет к этому никакого отношения. Кажется, что другие фразы, кроме "бинарной воспроизводимости", использовались в других статьях, поэтому параметры поиска, которые я использовал, ничего не придумали. Кто знал? Не я, шеф.