SYMS(4)
НАЗВАНИЕ
syms - формат таблицы имен в обычном об ектном файле
СИНТАКСИС
#include <syms.h>
ОПИСАНИЕ
Объектные файлы обычного формата содержат информацию
для поддержки, отладки в терминах исходного языка [см.
sdb(1)]. Информация о номерах строк [см. linenum(4)] и
об именах, встречающихся в программе, позволяет отлаживать программу на уровне исходного C-текста. Каждая
таблица имен в объектном файле устроена следующим образом:
- Имя первого файла.
- Имя первой функции.
- Локальные имена из первой функции.
- Имя второй функции.
- Локальные имена из второй функции.
- ...
- Имена, локальные в первом файле (описанные вне
- функций как static).
- Имя второго файла.
- Имя первой функции.
- Локальные имена из первой функции.
- Имя второй функции.
- Локальные имена из второй функции.
- ...
- Имена, локальные во втором файле.
- ...
- Определенные глобальные имена.
- Неопределенные глобальные имена.
Таблица имен состоит из элементов фиксированной длины
(18 байт). Элемент, описывающий имя, кроме собственно
текста имени, дополненного нулями, содержит его значение и другую информацию. Ниже приведена соответствующая
C-структура:
#define SYMNMLEN 8 /* Максимальное количество символов в тексте имени */
#define FILNMLEN 14 /* Максимальное количество символов в имени файла */
#define DIMNUM 4 /* Размерность массива во вспомогательном разделе */
struct syment {
union { /* Все способы описать текст имени */
char _n_name[SYMNMLEN]; /* Текст имени */
struct {
long _n_zeroes; /* Если == 0, то в таблице цепочек */
long _n_offset; /* Смещение в табл. цепочек */
} _n_n;
char *_n_nptr[2];
} _n;
long n_value; /* Значение имени */
short n_scnum; /* Номер секции */
unsigned short n_type; /* Тип и производный тип */
char n_sclass; /* Класс памяти */
char n_numaux; /* Число вспомогательных
элементов */
};
#define n_name _n._n_name
#define n_zeroes _n._n_n._n_zeroes
#define n_offset _n._n_n._n_offset
#define n_nptr _n._n_nptr[1]
Смысл значений имен пояснен во включаемом файле
<syms.h>. Для описания некоторых имен требуется больше
информации, чем содержится в одном элементе; в таком
случае за первым элементом, описывающим имя, следуют
вспомогательные элементы. Вспомогательные элементы имеют тот же размер, что и основные; их формат приведен
ниже:
union auxent {
struct {
long x_tagndx; /* Индекс описателя структуры,
об единения или перечисления */
union {
struct {
unsigned short x_lnno; /* Номер строки
определения */
unsigned short x_size; /* Размер массива, структуры
или об единения */
} x_lnsz;
long x_fsize; /* Размер функции */
} x_misc;
union {
struct {
long x_lnnoptr;
long x_endndx;
} x_fcn;
struct { /* Если массив, то его размерности (до 4) */
unsigned short x_dimen [DIMNUM];
} x_ary;
} x_fcnary;
unsigned short x_tvndx;
} x_sym;
struct {
char x_fname [FILNMLEN]; /* Имя файла (занимает весь
элемент) */
} x_file;
struct {
long x_scnlen; /* Длина секции */
unsigned short x_nreloc; /* Число элем. с инф. о
настройке ссылок */
unsigned short x_nlinno; /* Число элем. с инф. о
номерах строк */
} x_scn;
struct {
long x_tvfill;
unsigned short x_tvlen;
unsigned short x_tvran[2];
} x_tv;
};
Элементы таблицы имен нумеруются, начиная с 0.
СМ. ТАКЖЕ
a.out(4), linenum(4).
sdb(1) в Справочнике пользователя.
ПРЕДОСТЕРЕЖЕНИЯ
На компьютерах, у которых тип int эквивалентен типу
long, вместо long в таблице имен указывается int. Таким
образом, в таблице отсутствует информация о том, как на
самом деле описано имя: как int или как long.