· Начало · Отвђтить · Статистика · Поиск · FAQ · Правила · Установки · Язык · Выход · WASM.RU · Noir.Ru ·

 WASM Phorum —› WASM.WIN32 —› Debug info & размер бинарника

. 1 . 2 . >>

Посл.отвђт Сообщенiе


Дата: Авг 16, 2004 21:09:48

Есть набор obj файлов которые собираются в dll: один раз с включенной опцией линкера /debug, второй раз - без неё.
В первом случае получается размер бинарника ~164К, во втором - ~139К. Т.е. разница ~24К. Посмотрел бинарники - у первого размеры всех секций больше, особенно .text.

Вопрос: что такого напихивает линкер в бинарник, кроме ссылки на pdb файл, в режиме /debug ?

для построения obj и dll использованы компилятор и линкер от MS VC++ 6.0.

Спасибо.


Дата: Авг 16, 2004 21:13:35

The /DEBUG option creates debugging information for the .exe file or DLL.

The linker puts the debugging information into a program database (PDB). It updates the PDB during subsequent builds of the program.

An .exe file or DLL created for debugging contains the name and path of the corresponding PDB. The debugger reads the embedded name and uses the PDB when you debug the program. The linker uses the base name of the program and the extension .pdb to name the program database, and embeds the path where it was created. To override this default, set /PDB and specify a different file name.

The compiler's Line Numbers Only (/Zd) or C7 Compatible (/Z7) option causes the compiler to leave the debugging information in the .obj files. You can also use the Program Database (/Zi) compiler option to store the debugging information in a PDB for the .obj file. The linker looks for the object's PDB first in the absolute path written in the .obj file, and then in the directory that contains the .obj file. You cannot specify an object's PDB file name or location to the linker.

/INCREMENTAL is implied when /DEBUG is specified.

А вообще, немножко некорректно задан вопрос. Усилия линкера, в общем-то, не столь и велики по сравнению с усилиями компилятора. Вот компилятор в отладочную версию СТОЛЬКО всего сует, что можно одуреть. А забота линкера тут - помогать отладчику.


Дата: Авг 16, 2004 21:25:10


Усилия линкера, в общем-то, не столь и велики по сравнению с усилиями компилятора. Вот компилятор в отладочную версию СТОЛЬКО всего сует, что можно одуреть.“

Да. Но в моем случае перекомпиляция obj не производится!
Только линковка и вся разница - опция /debug.


Дата: Авг 16, 2004 21:37:55

green

Попробуйте указать /OPT:NOWIN98
У меня щас нет 6го линкера что бы проверить, но вроде эта опция унего не совместима с режимом /debug


PS
Эх, сколько всяких упоминаний про этот .PDB в MSDN, и хоть какое-нибудь описание!
Я пока только кое-что у Шрайбера нашел, и то формат 2.0, а щас уже MSF 7.00 :(
А google ссылки на какой-то protein data bank выдаёт %)


Дата: Авг 16, 2004 21:43:59

А google ссылки на какой-то protein data bank выдаёт %)

Но-но! Железячник хренов, не оскорбляй мой PDB. У него есть неплохие симпотные картинки кристаллической решетки :)


Дата: Авг 16, 2004 21:44:48

А что касается PDB, то есть pdbdump, который опирается на PDB-парсер от самой MS. Ты в тулзы смотрел?


Дата: Авг 16, 2004 22:16:18

S_T_A_S_
я попробовал Вашу опцию. Размер бинарника уменьшился (за счет уменьшения выравнивания секций в файле).
Но разница в размере между двумя режимами линковки осталась существенной, хотя и уменьшилась.


Дата: Авг 16, 2004 22:22:34

volodya
„/INCREMENTAL is implied when /DEBUG is specified“
По моему до меня дошло! :)


Дата: Авг 16, 2004 22:30:11

Странно только зачем ему так нужен INCREMENTAL для генерации debug info.

Интересно, бинарники от Windows free build (сгенеренные с debug info) тоже что ли linked incrementally ?
Что-то сомнительно...


Дата: Авг 16, 2004 23:26:17

volodya

Дык, мне не готовый PDB нужно обрабатывать, а самому его создавать. Какой-нибудь упрощенный вариант, вроде того что по /Zd генерится. Эмпирический метод рулит, но боюсь он не очень быстрый :(


Дата: Авг 16, 2004 23:33:18

А SDK от MS этого не умеет, что ли?


Дата: Авг 16, 2004 23:54:13

S_T_A_S_
„мне не готовый PDB нужно обрабатывать, а самому его создавать“

Я тоже подумывал, как бы оформить результаты исследования бинарника в IDA в виде pdb файла.


Дата: Авг 17, 2004 00:06:43

Я тоже подумывал, как бы оформить результаты исследования бинарника в IDA в виде pdb файла

Для этого есть плагины, которые доступны с сылок в соответствующем разделе тулзов.


Дата: Авг 17, 2004 11:18:45 · Поправил: green

volodya
простите, что-то не нашёл я такого плагина.
Есть для импорта символьной информации из pdb в базу, есть для экспорта из базы в nms.


Дата: Авг 18, 2004 04:18:17

volodya > „А SDK от MS этого не умеет, что ли?“

Судя по MSDN - нет. Извлекать инфу - без проблем..
mspdb71.dll экспортирует кучу COM методов, некоторые из которых судя по всему служат для создания PDB файл, но с ними ещё нужно разбираться..


ЗЫ
Вот нашёл маленькое дополнение к Шрайберу: http://www.jorgon.freeserve.co.uk/Other/pdb.htm

. 1 . 2 . >>


Powered by miniBB 1.6 © 2001-2002
Время загрузки страницы (сек.): 0.063