
- •Каналы
- •Каналы
- •Неименованные каналы
- •Системные вызовы
- •Последовательность
- •Каналы предназначены только для передачи информации в одном направлении.
- •Правила для каналов (1)
- •Правила для каналов (2)
- •Правила для каналов (3)
- •Правила для каналов (4)
- •Правила для каналов (5)
- •Режим без блокировки
- •Именованные каналы (1)
- •Именованные каналы (2)
- •Именованные каналы (3)
- •Именованные каналы (4)
- •Именованные каналы (5)
- •Конвейер команд
- •Создание канала в конвейере команд
- •Блокировки
- •Блокировки файлов
- •Блокировки файлов
- •Поля структуры flock
- •Системный вызов fcntl
- •Подсистема
- •Драйверы устройств
- •Символьные драйверы
- •Блочные драйверы
- •Драйверы низкого уровня
- •Драйверы устройств UNIX
- •Программные драйверы
- •Архитектура драйверов
- •Доступ к драйверу
- •Элемент массива коммутатора устройств (1)
- •Элемент массива коммутатора устройств (2)
- •Вызов функции драйвера
- •Драйвер как набор функций
- •Некоторые функции (1)
- •Некоторые функции (2)
- •Некоторые функции (3)
- •Некоторые функции (4)
- •Некоторые функции (5)
- •Некоторые функции (6)
- •Некоторые функции (7)
- •Некоторые функции (8)
- •Некоторые функции (9)
- •Обращение к драйверу
- •Три контекста вызова
- •Доступ к драйверу символьного устройства
- •Доступ к драйверу блочного устройства
- •Синхронная и асинхронная
- •Файловый интерфейс
- •Работа с простым
- •Работа с драйвером
- •Клоны
- •Работа с клонами
- •Связь драйвера с ядром
- •Динамическая установка
- •Динамическая установка
- •Доступ к блочным
- •Различные типы доступа
- •Буферизация при работе с символьным драйвером
- •Архитектура терминального доступа
- •Два режима работы
- •Дисциплина линии
- •Работа драйвера терминала
- •Псевдотерминалы
- •Взаимодействие процессов
- •Удаленный доступ

Каналы

Каналы
Обеспечивают передачу информации в виде потока байтов без сохранения границ сообщений.
Каналы бывают:
•неименованные (каналы)
•именованные (FIFO-файлы)

Неименованные каналы
Нет имени.
Взаимодействовать при помощи неименованных каналов могут только родственные (имеющие общего родителя или родитель и дочерний процесс) процессы.

Системные вызовы
int pipe(int fd[2]);
int pipe2(int fd[2], int flags);
O_NONBLOCK (O_NDELAY) O_CLOEXEC

Последовательность
действий
•Создать канал
•Создать процесс
•В каждом из процессов закрыть неиспользуемый дескриптор
•По окончании работы закрыть используемый дескриптор

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

Правила для каналов (1)
•При чтении меньшего числа байтов, чем находится в канале, возвращается требуемое число байтов, остаток сохраняется для последующих чтений.

Правила для каналов (2)
•При чтении большего числа байтов, чем находится в канале, возвращается доступное число байтов. Необходимо правильно обрабатывать данную ситуацию.

Правила для каналов (3)
•Если канал пуст и ни один процесс не открыл его на запись, при чтении будет прочитано ноль байтов. Если хотя бы один процесс имеет дескриптор канала, открытый на запись, то читающий процесс будет заблокирован.

Правила для каналов (4)
•Операция записи числа байтов меньшего емкости канала является атомарной. Данные от нескольких процессов, пишущих в канал, не перемешиваются.