Функции управления процессами

· signal()

 

#include <signal.h>.

static void sig_hndl(int signo) // обработчик

{

signal (SIGINT, sig_hndl); // восстановление диспозиции, требуется не всегда

printf(“This is new handler for SIGINT\n”); // сообщение обработчика

}

main()

{

signal(SIGINT, sig_hndl); // смена диспозиции трёх сигналов

signal(SIGUSR1, SIG_DFL);

signal(SIGUSR2, SIG_IGN);

while(1)

pause();

}

 

$ a.out & - можно пользоваться этим терминалом

5050 - pid порождённого процесса

$ kill SIGINT 5050

This is new handler for SIGINT

$ kill SIGUSR2 5050 - ничего не произойдет

$ kill SIGUSR1 5050 - действие по умолчанию (процесс терминируется).

 

Функция управления сигналами в POSIX

· sigaction(2)

Набор сигналов – sigset_t (32 разряда – 32 сигнала). Маскирование сигналов.

Реализация функции sigaction различно в различных ОС (меняется структура, которая ей управляет).

#include <signal.h>

int sigaction (int sig, const struct sigaction *act, const struct sigaction *oldact)

Поля структуры sigaction:

- void (*sa_handler) ()

- void (*sa_sigaction) (int, siginfo_t*, void*)

- sigset_t sa_mask; // маска

- int sa_flags; // флаги

 

Если sa_handler <> 0 или sa_sigaction <> 0, то в поле sa_mask передаётся набор сигналов, которые будут добавлены к маске перед вызовом обработчика. Маска блокирует сигналы, которые в неё добавлены. После возврата из обработчика маска восстанавливается. Обрабатываемый сигнал блокируется. Нет очередей сигналов. sa_flags модифицирует доставку сигналов.

siginfo_t – структура-комментарий о сигнале.

 

#include <siginfo_t.h>

struct siginfo_t{

int sig_no; // номер сигнала

int sig_errno; // номер ошибки

int sig_code; // причина отправки сигнала

};

 

Функции управления sigaction()

#include <signal.h>

sigemptyset(sig_set_t *set); // начальная инициализация, очистка битов

sigfillset(sig_set_t *set); // включение битов

sigaddset(sig_set_t *set, int signo); // добавить 1 сигнал

sigdelset(sig_set_t *set, int signo); // убрать 1 сигнал

sigismemberset(sig_set_t *set, int signo); // является ли сигнал в маске

 

Ресурсоемкость сигналов

Для отправки-доставки требуется системный вызов.

Для доставки – прерывание и его обработка.

Для этого необходимо большое число операций со стеком - копирование пользовательского стека в системную область, извлечение параметров системных вызовов, результатов работы системных вызовов и др. Вывод: затраты слишком велики по сравнению с объемом передаваемой информации.

Используются для реакции на событие.

 

#include <signal.h>

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

#include <unistd.h>

 

void (*oursignal (int signo, void (*hndlr)(int)) (int) // обработчик

{

struct sigaction act, oldact;

act.sa_handler = hndlr;

sigemptyset(&act.sa_mask);

act.sa_flags = 0;

if (signo != SIGALARM) act.sa_flags |= SA_RESTART;

if (sigaction (signo, &act, &oldact) < 0) return (SIG_ERR);

return (oldact.sa_hndlr);

}

 

static void sig_hndlr (int signo);

{

printf(“We are int handler\n”); // нет восстановления старой диспозиции

}

 

main()

{

oursignal(SIGINT, sig_hndl); // смена диспозиции трёх сигналов

oursignal(SIGUSR1, SIG_DFL);

oursignal(SIGUSR2, SIG_IGN);

while(1)

pause();

}

 

Сообщения в микроядерных ОС.

В микроядерных ОС средства сообщений – базовые средства IPC. Универсальны для локальных и сетевых вариантов. Нет необходимости редиректора.

POSIX <= есть в микроядерных системах.

Это средство реализовано как надстройка над родными средствами сообщений.

В СРВ есть требование точного выполнения в заданные сроки – механизм send msg – с квитированием.

Количество блокировок сильно возрастает в общем перечне состояний процесса

[send – receive – reply]

Общие затраты ресурсов на общую передачу сообщений невелики.

Количество передач сообщений огромно (всё взаимодействие посредством сообщений с квитированием).

Типы:

- send-управляемая передача сообщений

- receive-управляемая передача сообщений

В зависимости от типа меняется структура клиент-серверного приложения.

 

Процессы и потоки в WinNT

Основная модель функционирования – объектная. Основная часть ОС написана на языке C. Ресурсы представляются объектами (в т.ч. процессы, файлы). Процессы создаются и реализуются как объекты -> доступ посредством объектных сервисов. В адресном пространстве процесса может быть несколько потоков. Есть встроенные средства синхронизации. Для базового процесса не поддерживается наследование

Состав процесса

- исполняемая программа (код + данные)

- закрытое адресное пространство (набор адресов в виртуальной памяти)

- системные ресурсы (то, что выделяется ОС для выполнения программы)

- хотя бы один поток выполнения.

 

Поток внутри процесса – сущность, управляемая ОС.

Адресное пространство – все ограничения вносятся системой виртуальной памяти. Процессы получают логический образ (окружение потока + пользовательская часть).

Виртуализация – отображение виртуальной памяти в физическую.

Собственное АП процессов изолировано от других -> нужны средства IPC. Здесь это сделано в виде иерархии.

 

API защищённой подсистемы – серверы.

- упрощение базовой системы

- расширение функциональности

Подсистемы находятся в пользовательском режиме (представлены в виде ограниченного набора ф-й).

 

Клиент-серверная модель – защищённая подсистема определяет набор требуемых функций. Через них эти функции и вызываются. У процесса есть маркер доступа.

 

Таблица описателей.

Описатели – набор структур, созданных диспетчером. Он играет роль посредника для процесса, чтобы читать и писать в виртуальном АП.

Маркер доступа также является объектом. Создаётся и уничтожается диспетчером. Открытие описателя маркера доступа выполняется по специальным правам. Маркер содержит заголовок объекта – атрибуты (дескриптор защиты), имя процесса, каталог объектов.

Дополнительные ресурсы – базовый приоритет, процессорное сродство, набор квот на ресурсы. Могут наследоваться.

Атрибуты объекта Назначение
ID Уникальный определитель
Маркер доступа Объект, содержащий информацию о правах процесса
Базовый приоритет Базовый приоритет основного потока
Процессорное сродство Набор процессоров, на которых потоки-процессы могут исполняться по умолчанию
Размер квот Мах V резидентной/нерезидентной системной памяти – пространство в файле подкачки, например процессорное время, выделенное процессу.
Время выполнения Общее время выполнения всех потоков
Счётчик ввода/вывода Переменная, в которой сохраняется число и тип операций ввода/вывода процессов
Счётчик операций вирт. памяти Переменная, в которой сохраняется число и тип операций виртуальной памяти
Код отладки Канал коммуникации между процессами
Код завершения Причина завершения процесса

 

Атрибуты определяет диспетчер процессов. Атрибуты формируют ограничения на потоки процессов. Приоритеты потоков регулируются ядром NT.

 

Общее у потока и процесса: АП, маркер доступа, базовый приоритет, описатель объекта.

Для потока-объекта есть свои атрибуты.

Атрибуты объекта Назначение
Клиентский ID Уникальный определитель потока
Контекст потока Набор значений регистров и другие непосредственные данные, определяющие состояние потока
Динамический приоритет Приоритет на данное время
Базовый приоритет Нижний предел приоритета
Процессорное сродство потока Набор процессоров, на которых может выполняться данный поток
Время выполнения потока Общее время выполнения потока в режиме ядра и в режиме задачи
Статус оповещения Наличие асинхронного вызова (процедура APC)
Счётчик приостановок Количество остановок выполнения потока без возобновления
Маркер имперсонации (SUID) Временный маркер доступа от имени другого потока
Код отладки Канал коммуникации
Код завершения Причина завершения потока

 

Приоритеты 16-31 – приоритеты РВ (нет связи с СРВ) – событийное реагирование.