- •1 Ответ
- •2 Ответ Структура управляемой системы реального времени
- •3 Ответ
- •1) Принцип модульности
- •4) Принцип функциональной избыточности
- •6) Принцип совместимости
- •7) Принцип открытой и наращиваемой ос
- •4 Билет
- •5 И 6 билет
- •7 Билет
- •8 Билет Прерывание в защищённом режиме
- •9 Билет
- •10 Билет Страничная трансляция
- •11 Билет
- •12 Билет
- •13 Билет
- •14 Билет
- •15 Билет
- •16 Билет
- •17 Билет
- •18 Билет
- •30. 2.7. Семафоры
- •19 Билет
- •34. Синхронизация через диспетчеризующий механизм
- •20 Билет
- •21 Билет
- •22 Билет
- •23 Билет . Организация взаимодействия между процессами
- •Создание и удаление каналов Создание канала
- •Удаление канала
- •Установление и удаление соединений с каналом Установление соединения
- •Разрыв соединения
- •24 Билет
- •25 Билет
- •26 Билет
- •27 Билет
- •28 Билет
- •29 Билет
- •30 Билет
- •31 Билет
- •32 Билет
- •33 Билет
- •Int flags, // флаги, определяющие область действия тайм-аута
- •34 Билет
- •35 Билет
- •36 Билет
- •37 Билет
- •38 Билет
- •39 Билет
- •40 Билет
- •41 Билет
- •Именование в qnx
- •43 Билет
- •44 Билет
- •45 Билет
- •Устройства с последовательным интерфейсом
- •46 Билет
27 Билет
Очереди сообщений
Стандарт POSIX определяет набор неблокирующих средств передачи
сообщений, известных как «POSIX-очереди сообщений». Для того чтобы
использовать этот механизм обмена данными, необходимо запустить ме-
неджер очередей mqueue. Ядро QNX Neutrino непосредственно не участву-
ет в поддержке этого механизма. POSIX-очереди сообщений обеспечивают
интерфейс, хорошо известный многим программистам. Они подобны почто-
вым ящикам, которые можно обнаружить во многих исполняющих системах
реального времени. POSIX-очереди сообщений реализуют механизм при-
оритетного перемещения данных, при котором отправитель не блокируется
и может иметь много не доставленных сообщений, упорядоченных в оче-
редь. Фактически существует несколько очередей с разным уровнем при-
оритета. POSIX-очереди сообщений существуют независимо от процессов,
которые их используют. Это более медленный механизм, чем естественные
сообщения ядра, однако он обладает более широкими функциональными
возможностями, что может в ряде случаев компенсировать недостаток бы-
стродействия.
Очереди сообщений имеют сходство с файлами, во всяком случае, в
том, что касается их интерфейса. Любая очередь сообщений, как и файл,
имеет имя. Открыть очередь сообщений можно с помощью вызова__mq_open(), закрыть – с помощью mq_close() и уничтожить сообщения – с
помощью mq_unlink(). Для того чтобы поместить данные в очередь сообще-
ний и извлечь данные из очереди, используются вызовы mq_send() и
mq_receive(). При точном соответствии со стандартом POSIX в имени оче-
реди может присутствовать только один слеш (/). Однако в QNX стандарт
имеет расширение и поддерживает имена, содержащие много слешей. Это
позволяет, например, некоторой компании иметь все очереди сообщений, в
которых слешами выделено имя компании, что дает возможность исклю-
чить конфликты при совместном использовании данного механизма обмена
несколькими компаниями в рамках одной сети. В QNX Neutrino все очереди
сообщений с ведущим символом (/) будут отображаться как имена файлов в
директории /dev/mqueue. Эти имена можно отобразить на дисплее с помо-
щью команды интерпретатора ls –Rl /dev/mqueue. Очереди сообщений с
другими именами локализуются в текущем директории процесса, создаю-
щего очередь. Очередь сообщений может быть открыта и на другом узле, в
этом случае спецификация имени должна включать предваряющий пре-
фикс /net/node/, где node – имя узла. Для управления очередью использу-
ются вызовы, представленные • oflag – флаги, определяющие режим доступа. Вы должны специфицировать
O_RDONLY (только для чтения), O_WRONLY (только для записи) или O_RDWR (для чтения и
записи). Кроме того, для получения дополнительных эффектов, к этим флагам по «ИЛИ» мож-
но добавить следующие константы:
- O_CREAT – инструктирует сервер создать новую очередь, если имя, указанное в аргу-
менте name, не существует,
- O_EXCL – используется вместе с флагом O_CREAT. Если очередь с указанным именем
существует, то вызов не исполняется и возвращается ошибка в глобальной переменной errno
с кодом EEXIST. При одиночном использовании данного флага он игнорируется,
- O_NONBLOCK – при сброшенном флаге вызовы mq_send() или mq_receive() могут
быть заблокированы, если очередь полна или, наоборот, пуста. Если флаг установлен, то вы-
зовы никогда не блокируются, но происходит возврат с установленной ошибкой EAGAIN в гло-
бальной переменной errno;
• mode – аргумент присутствует в вызове mq_open(), только если установлен флаг
O_CREAT, и определяет для новой очереди файловые разрешения для типовых категорий
пользователей: собственник, член группы и прочие. Разрешения задаются с помощью сим-
вольных констант представленных в табл. 3.13;
• mq_attr – опциональный аргумент присутствует в вызове mq_open(), только если уста-
новлен флаг O_CREAT. Указывает на структуру mq_attr, которая содержит атрибуты для но-
вой очереди сообщений. Структура имеет следующий набор полей:
- long mq_flags – флаги очереди,
- long mq_maxmsg – максимальное число сообщений в очереди,
- long mq_msgsize – максимальный размер каждого сообщения,
- long mq_curmsgs – число сообщений, непрерывно сохраняемых в данной очереди,
- long mq_sendwait – число потоков, непрерывно ожидающих пересылки сообщения. Не-
нулевое значение в этом поле означает, что очередь заполнена полностью,
- long mq_recvwait – число потоков, непрерывно ожидающих приема сообщения. Нену-
левое значение в этом поле означает, что очередь пуста.
Значения полей структуры mq_attr для существующей очереди можно получить с помо-
щью вызова mq_getattr() и установить с помощью вызова mq_setattr(). Если аргумент mq_attr
имеет значение NULL, то создается новая очередь с атрибутами:
- mq_maxmsg: 1024 // число сообщений в очереди,
- mq_msgsize: 4096 // максимальный размер сообщений,
- mq_flags: 0 // флаги.
Таблица 3.13
Собственник Член группы Прочие Разрешения
S_IRUSR S_IRGRP S_IROTH Чтение
S_IRWXU S_IRWXG S_IRWXO Чтение/запись/исполнение (поиск)
S_IWUSR S_IWGRP S_IWOTH Запись
S_IXUSR S_IXGRP S_IXOTH Исполнение (поиск)
Для передачи и приема сообщения используются вызовы mq_send() и
mq_receive(). Синтаксис этих вызовов представлен в следующем фрагмен-
те. Эти вызовы не блокируют поток, а в случае неудачи возвращают значе-
ние –1 и код ошибки в глобальной переменной errno.
int mq_send (mqd_t mqdes, // дескриптор очереди
const char * msg_ptr, // указатель к сообщению
size_t msg_len, // размер сообщения
unsigned int msg_prio ); // приоритет сообщения
Приоритет для сообщений может быть установлен в диапазоне от 0 до (MQ_PRIO_MAX-
1). Константа MQ_PRIO_MAX устанавливается при запуске сервера mqueue. Вместо функцииmq_send() может быть использован вызов write(), он эквивалентен mq_send() со значением
msg_prio=0. При неудаче вызов mq_send() возвращает значение –-1, а при успешном заверше-
нии – любое положительное значение.
ssize_t mq_receive( mqd_t mqdes, // дескриптор очереди
char* msg_ptr, // указатель к буферу сообщения
size_t msg_len, // размер сообщения
unsigned int* msg_prio ); // приоритет сообщения
Если указатель msg_prio установлен в NULL, значение приоритета принятого сообще-
ния не сохраняется. Вызов read() с дескриптором mqdes аналогичен вызову mq_receive() с ар-
гументом msg_prio= NULL.
Сообщения, подобно файлам, существуют, даже если процессы, их
создавшие, завершены. Если все процессы отсоединены от очереди вызо-
вами mq_unlink() и последний связанный с ней процесс выполняет вызов
mq_close(), то очередь уничтожается со всем ее содержимым. Вызов close()
с дескриптором очереди имеет тот же самый эффект, что и вызов
mq_close(). Для уведомления процессов о поступлении сообщений в оче-
редь может быть использован вызов mq_notify(). Синтаксис этого вызова
представлен в следующем фрагменте.
int mq_notify(mqd_t mqdes, // дескриптор очереди
const struct sigevent* notification ); // уведомление
Тип уведомления notification устанавливается структурой sigevent.
. Очереди сообщений.
Стандарт POSIX определяет набор неблокирующих средств передачи
сообщений, известных как «POSIX-очереди сообщений». Для того чтобы
использовать этот механизм обмена данными, необходимо запустить ме-
неджер очередей mqueue. Ядро QNX Neutrino непосредственно не участву-
ет в поддержке этого механизма. POSIX-очереди сообщений обеспечивают
интерфейс, хорошо известный многим программистам. Они подобны почто-
вым ящикам, которые можно обнаружить во многих исполняющих системах
реального времени. POSIX-очереди сообщений реализуют механизм при-
оритетного перемещения данных, при котором отправитель не блокируется
и может иметь много не доставленных сообщений, упорядоченных в оче-
редь. Фактически существует несколько очередей с разным уровнем при-
оритета. POSIX-очереди сообщений существуют независимо от процессов,
которые их используют. Это более медленный механизм, чем естественные
сообщения ядра, однако он обладает более широкими функциональными
возможностями, что может в ряде случаев компенсировать недостаток бы-
стродействия.
Очереди сообщений имеют сходство с файлами, во всяком случае, в
том, что 1 1 Tfкасается их интерфейса. Любая очередь сообщений, как и файл,
имеет имя. Открыть очередь сообщений можно с помощью вызова mq_open(), закрыть – с помощью mq_close() и уничтожить сообщения – с
помощью mq_unlink(). Для того чтобы поместить данные в очередь сообще-
ний и извлечь данные из очереди, используются вызовы mq_send() и
mq_receive(). При точном соответствии со стандартом POSIX в имени оче-
реди может присутствовать только один слеш (/). Однако в QNX стандарт
имеет расширение и поддерживает имена, содержащие много слешей. Это
позволяет, например, некоторой компании иметь все очереди сообщений, в
которых слешами выделено имя компании, что дает возможность исключить конфликты при совместном использовании данного механизма обмена
несколькими компаниями в рамках одной сети. В QNX Neutrino все очереди
сообщений с ведущим символом (/) будут отображаться как имена файлов в
директории /dev/mqueue. Эти имена можно отобразить на дисплее с помощью команды интерпретатора ls –Rl /dev/mqueue. Очереди сообщений с другими именами локализуются в текущем директории процесса, создаю-
щего очередь. Очередь сообщений может быть открыта и на другом узле, в
этом случае спецификация имени должна включать предваряющий пре-
фикс /net/node/, где node – имя узла. Для управления очередью используются вызовы, представленные в табл.
Функция Описание
mq_open() Открыть очередь сообщений
mq_close() Закрыть очередь сообщений
mq_unlink() Удалить очередь сообщений
mq_send() Добавить сообщение к очереди
mq_receive() Получить сообщение из очереди
mq_notify() Уведомить вызывающий процесс, что сообщение находится в очереди
mq_setattr() Установить атрибуты очереди сообщений
mq_getattr() Получить атрибуты очереди сообщений
mq_timedreceive() Получить наиболее старое сообщение с наивысшим приоритетом
mq_timedsend() Добавить в очередь сообщение с заданным временем доставки
Для передачи и приема сообщения используются вызовы mq_send() и
mq_receive(). Синтаксис этих вызовов представлен в следующем фрагмен-
те. Эти вызовы не блокируют поток, а в случае неудачи возвращают значе-
ние –1 и код ошибки в глобальной переменной errno.
