Поток (stream) — это полнодуплексный канал вычислений и обмена данными между драйвером в пространстве ядра и процессом в прикладном пространстве. STREAMS — набор системных вызовов, ресурсов и прикладных процедур ядра, используемых для создания, применения и демонтирования потоков.
Подсистема STREAMS также является базовой структурой для создания драйверов устройств. Она определяет набор правил и рекомендаций для разработчиков драйверов и предоставляет механизмы и утилиты, позволяющие создавать драйверы на основе модулей.
Также вам может показаться, что такая тема как http://vashmagazin.by/katalog/stoly_derevyannye никак не связана и даже не тематична. Хотя, может быть и связана. В любом случае все-таки зайдите на сайт vashmagazin.by. Тема стол купить там представлена весьма широко. На том сайте можно узнать много интересного на тему стол купить. Что означает вообще тема стол купить, где найти стол купить - про это написано на сайте vashmagazin.by. Это очень важная для многих людей тема - стол купить. Спасибо сайту vashmagazin.by за информацию на тему стол купить.
Ранее показан обычный поток. Он полностью находится в адресном пространстве ядра, все его операции также реализованы на уровне ядра. Поток состоит из головного интерфейса (stream head), оконечного драйвера (driver end)1, а также нескольких модулей, располагаемых между ними (модули могут отсутствовать). Головной интерфейс взаимодействует с прикладным уровнем и позволяет приложениям обращаться к потоку через системные вызовы. Оконечный драйвер взаимодействует непосредственно с устройством (это также может быть драйвер псевдоустройства, в таком случае происходит взаимодействие с другим потоком). Модули производят необходимые действия над данными.
Каждый модуль содержит две очереди — очередь чтения (read queue) и записи (write queue). Головной интерфейс потока и драйвер также обладают такими парами очередей. Поток передает данные путем помещения их в сообщения. Очереди записи отправляют сообщение в нисходящем направлении (downstream), от приложения к драйверу. Очереди чтения передают сообщения драйвера приложению, то есть в восходящем направлении (upstream). Несмотря на то что большинство сообщений создается либо головным интерфейсом потока либо драйвером, промежуточные модули также умеют генерировать сообщения и посылать их в обоих направлениях.
Каждая очередь может взаимодействовать со следующей очередью потока.
очередь записи модуля 1 может отправлять сообщения на очередь записи модуля 2 (но не наоборот). Очередь чтения модуля 1 имеет право посылать сообщения головному интерфейсу потока. Очередь вправе также взаимодействовать с парной очередью. Таким образом, очередь чтения модуля 2 может передавать сообщения очереди записи того же модуля, которая затем отправит их в нисходящем направлении. Очереди не требуется знать, с кем она производит общение: с головным интерфейсом потока, его оконечным драйвером или другим промежуточным модулем.
Описание основ подсистемы STREAMS показывает очевидные преимущества такого подхода. Создание каждого модуля является независимым действием, осуществляемым не обязательно одними и теми же разработчиками. Модули могут выбираться и объединяться различными способами, примерно так, как происходит комбинирование команд в каналах интерпретаторов UNIX.
Ранее показан пример построения нескольких потоков из небольшого набора компонентов. К примеру, разработчик сетевого программного обеспечения добавляет в свой продукт поддержку стека протоколов TCP/IP. Если использовать для этой цели подсистему STREAMS, он может создать модули TCP, UDP и IP. Другие поставщики сетевых интерфейсных карт вольны создавать отдельные драйверы для сетевых карт Ethernet и Token Ring.
После разработки отдельных модулей можно произвести их динамическую настройку, сформировав несколько типов потоков.
Ранее были показан поток TCP/IP, соединенный с Token Ring.
Ранее было представлено уже другое сочетание модулей, в котором поток UDP/IP взаимодействует с драйвером карты Ethernet.
Опубликовал katy
June 24 2015 16:59:50 ·
0 Комментариев ·
3521 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.