Операционная система UNIX - страница 112

стр.


Таблица 3.5. Идентификация объектов IPC

Объект IPCПространство именДескриптор
КаналФайловый дескриптор
FIFOИмя файлаФайловый дескриптор
Очередь сообщенийКлючИдентификатор
Объект IPCПространство именДескриптор
СемафорКлючИдентификатор
Разделяемая памятьКлючИдентификатор

Работа с объектами IPC System V во многом сходна. Для создания или получения доступа к объекту используются соответствующие системные вызовы get: msgget(2) для очереди сообщений, semget(2) для семафора и shmget(2) для разделяемой памяти. Все эти вызовы возвращают дескриптор объекта в случае успеха и -1 в случае неудачи. Отметим, что функции get позволяют процессу получить ссылку на объект, которой по существу является возвращаемый дескриптор, но не позволяют производить конкретные операции над объектом (помещать или получать сообщения из очереди сообщений, устанавливать семафор или записывать данные в разделяемую память. Все функции get в качестве аргументов используют ключ >key и флажки создания объекта >ipcflag. Остальные аргументы зависят от конкретного типа объекта. Переменная >ipcflag определяет права доступа к объекту >PERM, а также указывает, создается ли новый объект или требуется доступ к существующему. Последнее определяется комбинацией (или отсутствием) флажков >IPC_CREAT и >IPC_EXCL.

Права доступа к объекту указываются набором флажков доступа, подобно тому, как это делается для файлов:

Значение PERM (в восьмеричном виде)Аналог прав доступа для файловРазрешено
>0400>r--------Чтение для владельца-пользователя
>0200>-w-------Запись для владельца-пользователя
>0040>---r-----Чтение для владельца-группы
>0020>----w----Запись для владельца-группы
>0004>------r--Чтение для всех остальных
>0002>-------w-Запись для всех остальных

Комбинацией флажков можно добиться различных результатов:

Значение аргумента ipcflagРезультат действия функции
Объект существуетОбъект не существует
>0Возвращает дескрипторОшибка: отсутствие объекта (>ENOENT)
>PERM | IPC_CREATВозвращает дескрипторСоздает объект с соответствующими >PERM правами доступа
>PERM | IPC_CREATОшибка: объект уже существует (>EEXIST)Создает объект с соответствующими >PERM правами доступа

Работа с объектами IPC System V во многом похожа на работу с файлами в UNIX. Одним из различий является то, что файловые дескрипторы имеют значимость в контексте процесса, в то время как значимость дескрипторов объектов IPC распространяется на всю систему. Так файловый дескриптор 3 одного процесса в общем случае никак не связан с дескриптором 3 другого неродственного процесса (т.е. эти дескрипторы ссылаются на различные файлы). Иначе обстоит дело с дескрипторами объектов IPC. Все процессы, использующие, скажем, одну очередь сообщений, получат одинаковые дескрипторы этого объекта.

Для каждого из объектов IPC ядро поддерживает соответствующую структуру данных, отличную для каждого типа объекта (очереди сообщений, семафора или разделяемой памяти). Общей у этих данных является структура >ipc_perm описывающая права доступа к объекту, подобно тому, как это делается для файлов. Основными полями этой структуры являются:

>uidИдентификатор владельца-пользователя объекта
>gidИдентификатор владельца-группы объекта
>cuidUID создателя объекта
>cgidGID создателя объекта
>modeПрава доступа на чтение и запись для всех классов доступа (9 битов)
>keyКлюч объекта

Права доступа (как и для файлов) определяют возможные операции, которые может выполнять над объектом конкретный процесс (получение доступа к существующему объекту, чтение, запись и удаление).

Заметим, что система не удаляет созданные объекты IPC даже тогда, когда ни один процесс не пользуется ими. Удаление созданных объектов является обязанностью процессов, которым для этого предоставляются соответствующие функции управления msgctl(2), semctl(2), shmctl(2). С помощью этих функций процесс может получить и установить ряд полей внутренних структур, поддерживаемых системой для объектов IPC, а также удалить созданные объекты. Безусловно, как и во многих других случаях использования объектов IPC процессы предварительно должны "договориться", какой процесс и когда удалит объект. Чаще всего, таким процессом является сервер.