fifo(7) специальный файл, организующий очередь (first-in first-out),

ОПИСАНИЕ

Специальный файл FIFO (именованный канал) подобен каналу, за исключением того, что доступен как часть файловой системы. Его можно открывать из нескольких процессов на чтении или запись. Когда процессы обмениваются данными через FIFO, ядро передаёт все данные без их записи в файловую систему. То есть, специальный файл FIFO не хранит содержимое в файловой системе; запись в файловой системе служит просто местом, посредством которого процессы могут получить доступ к каналу, используя имя в файловой системе.

Ядро поддерживает один объект канала для каждого специального файла FIFO, который открыт хотя бы одним процессом. Для того, чтобы пропускать данные, FIFO должен быть открыт как для чтения, так и для записи. Обычно, при открытии FIFO он блокируется до тех пор, пока вышеописанные условия не будут выполнены.

Процесс может открыть FIFO в неблокирующем режиме. В этом случае специальный файл открывается только для чтения, даже если никто не открывал его для записи; если это произойдет, то вернётся сообщение об ошибке ENXIO (нет такого устройства или адреса), хотя файл открыт для чтения.

В Linux открытие FIFO для чтения и записи может быть осуществлено в блокирующем и неблокирующем режимах. Так как POSIX не описывает эти положения, это может быть использовано для открытия FIFO для чтения в отсутствие считывающих процессов. Процесс, использующий этот файл для чтения и записи (для связи с самим собой), не должен допустить возникновения блокировок (deadlocks).

ЗАМЕЧАНИЯ

Если процесс попытается записать данные в FIFO, который не открыт для чтения, то ему посылается сигнал SIGPIPE.

Специальные файлы FIFO могут быть созданы с помощью mkfifo(3); при выводе ls -l они отображаются с типом файла «p».