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.
 
 |