НАЗВАНИЕ
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.