NM(1)

НАЗВАНИЕ
nm - вывод таблицы имен об ектного файла обычного формата

СИНТАКСИС


	nm  [-o] [-x] [-h] [-v] [-n] [-e] [-f] [-u] [-r] [-p] [-V] [-T] файл ...

ОПИСАНИЕ
Команда nm выдает на стандартный вывод таблицу имен для каждого об ектного файла, указанного в командной строке. Файл может быть как перемещаемым, так и абсолютным об ектным файлом, или может быть архивом из таких файлов. Для каждого элемента таблицы выдается следующая информация:

Name Имя элемента таблицы.
Value Значение, выражаемое как смещение или адрес, в зависимости от класса хранения.
Class Класс хранения.
Type Информация о типе. Если элемент описывает экземпляр структуры или об единения, то за типом будет выведено имя структуры или об единения (например, struct-имя). Если элемент соответствует массиву, то размер массива будет указан за типом (например, char[n][m]). Заметим, что для наличия этой информации файл должен быть откомпилирован командой cc(1) с опцией -g.
Size Размер в байтах, если он определен. Заметим, что для наличия этой информации файл должен быть откомпилирован командой cc(1) с опцией -g.
Line Номер строки в файле с исходным текстом, в которой об ект определяется, если эта информация имеет смысл. Заметим, что для наличия этой информации файл должен быть откомпилирован командой cc(1) с опцией -g.
Section Для об ектов с классом хранения статический (static) и внешний (extern) указывается секция, которой принадлежит об ект: секция команд (.text), секция инициализированных данных (.data) или секция неинициализированных данных (.bss).

Следующие опции определяют содержание и формат информации, выдаваемой командой nm:

-o Выводить значение и размер в восьмеричном виде, а не в десятичном.
-x Выводить значение и размер в шестнадцатеричном виде, а не в десятичном.
-h Не выводить заголовок.
-v Отсортировать внешние об екты по значению.
-n Отсортировать внешние об екты по алфавиту.
-e Выдавать только статические и внешние об екты.
-f Выдавать всю информацию. Выводятся обычно подавляемые избыточные элементы таблицы имен (.text, .data, .lib, .bss).
-u Выводить только неопределенные об екты.
-r Добавлять в начале каждой выводимой строки имя об ектного файла или архива.
-p Выводить в легко обозримом, кратком формате. Перед именем каждого об екта стоит его значение (пробелы, если не определено) и одна из следующих букв: U (неопределенный), A (абсолютный), T (входит в секцию команд), D (входит в секцию данных), S (входит в секцию, определенную пользователем), R (располагается в регистре), F (файл) или C (входит в общий блок). Информация о локальных (не внешних) об ектах выдается малыми буквами.
-V Вывести в стандартный протокол информацию о версии команды nm.
-T По умолчанию команда nm выводит полные имена об ектов. Но так как об ектные файлы могут содержать имена произвольной длины, то возможен сдвиг последующих колонок. Опция -T вызывает усечение длинных имен. При этом факт усечения отмечается звездочкой в последней позиции, отведенной под имя.

Опции можно использовать в произвольном порядке, вместе или по отдельности, и в произвольном месте командной строки. Так, команды


	nm  f1 -e -v

      и

	nm  -ve f1

работают одинаково: выдают статические и внешние об екты файла с сортировкой внешних об ектов по значению.

ФАЙЛЫ


	TMPDIR/*        Временные файлы.

Обычно каталог TMPDIR - это /usr/tmp, однако данное соглашение можно изменить, присвоив переменной окружения TMPDIR другое значение [см. tempnam( ) в tmpnam(3S)].

СМ. ТАКЖЕ
as(1), cc(1), ld(1).
tmpnam(3S), a.out(4), ar(4) в Справочнике программиста.

ДИАГНОСТИКА


	nm: файл: cannot open

	    Файл не удается открыть.

	nm: файл: bad magic

 	    Файл не является об ектным файлом обычного  формата.

	nm: файл: no symbols

	    Файл не содержит таблицы имен.

СЮРПРИЗЫ
В ситуации, когда выводятся все об екты, для сохранения локализации информации нужно, чтобы об екты выводились в том порядке, в каком они хранятся в таблице имен. Следовательно, опции -v и -n следует использовать только вместе с опцией -e.