Внеполосные данные TCP в TPI не рассматриваются как истинные срочные данные. В самом деле, в TCP полоса 0 используется как для обычных, так и для внеполосных данных. Полоса 1 используется для отправки срочных данных в тех протоколах, в которых срочные данные (а не просто срочный указатель, как в TCP) отправляются перед обычными данными. В данном контексте следует внимательно отнестись к термину «обычный» (normal). В системах SVR, предшествующих SVR4, не было полос приоритета, а сообщения делились на обычные и приоритетные (priority messages). В SVR4 были введены полосы приоритета, что потребовало также введения функций getpmsg и putpmsg, которые мы вскоре опишем. Приоритетные сообщения были переименованы в сообщения с высоким приоритетом, и встал вопрос, как называть сообщения, относящиеся к полосам приоритета от 1 до 255. Наиболее распространенной является терминология [98], согласно которой все сообщения, которые не являются сообщениями с высоким приоритетом, называются обычными сообщениями и разделяются на подкатегории согласно своим полосам приоритета. Термин «обычное сообщение» в любом случае должен соответствовать сообщению из полосы приоритета 0.
Хотя пока мы говорили только о сообщениях с высоким приоритетом и об обычных сообщениях, существует около 12 типов обычных сообщений и около 18 типов сообщений с высоким приоритетом. С точки зрения приложений и функций getmsg
и putmsg
, которые мы опишем в следующем разделе, нам интересны только три различных типа сообщений: M_DATA
, M_PROTO
и M_PCPROTO
(PC
означает «priority control», то есть приоритетное управление, и подразумевает сообщения с высоким приоритетом). В табл. 31.1 показано, как эти три типа сообщений генерируются функциями write
и putmsg
.
Таблица 31.1. Типы потоковых сообщений, генерируемые функциями write и putmsg
Функция | Управляющая информация? | Данные? | Флаги | Генерируемый тип сообщения |
---|---|---|---|---|
write | Да | M_DATA | ||
putmsg | Нет | Да | 0 | M_DATA |
putmsg | Да | Все равно | 0 | M_PROTO |
putmsg | Да | Все равно | MSG_HIPRI | M_PCPROTO |
31.3. Функции getmsg и putmsg
Данные, передаваемые в обоих направлениях по потоку, состоят из сообщений, а каждое сообщение содержит read
или write
, то мы можем передавать только данные. Для того чтобы процесс мог записывать и считывать как данные, так и управляющую информацию, необходимо добавить две новые функции.
#include
int getmsg(int
int putmsg(int
const struct strbuf *
Обе составляющие сообщения — и сами данные, и управляющая информация — описываются структурой strbuf
:
struct strbuf {
int maxlen; /* максимальный размер буфера buf */
int len; /* фактическое количество данных в buf */
char *buf; /* данные */
};
Вильям Л Саймон , Вильям Саймон , Наталья Владимировна Макеева , Нора Робертс , Юрий Викторович Щербатых
Зарубежная компьютерная, околокомпьютерная литература / ОС и Сети, интернет / Короткие любовные романы / Психология / Прочая справочная литература / Образование и наука / Книги по IT / Словари и Энциклопедии