PIPE(2) PIPE(2) NAME pipe - create an interprocess channel SYNOPSIS #include <u.h> #include <libc.h> int pipe(int fd[2]) DESCRIPTION Pipe creates a buffered channel for interprocess I/O commu- nication. Two file descriptors are returned in fd. Data written to fd[1] is available for reading from fd[0] and data written to fd[0] is available for reading from fd[1]. After the pipe has been established, cooperating processes created by subsequent fork(2) calls may pass data through the pipe with read and write calls. The bytes placed on a pipe by one write are contiguous even if many processes are writing. Write boundaries are preserved: each read termi- nates when the read buffer is full or after reading the last byte of a write, whichever comes first. The number of bytes available to a read(2) is reported in the Length field returned by fstat or dirfstat on a pipe (see stat(2)). The limit of data bytes in the pipe's buffer can be set by fwstat or dirfwstat on either of the pipe's descriptors. When all the data has been read from a pipe and the writer has closed the pipe or exited, read(2) will return 0 bytes. Writes to a pipe with no reader will generate a note sys: write on closed pipe. SOURCE /sys/src/libc/9syscall SEE ALSO intro(2), read(2), pipe(3) DIAGNOSTICS Sets errstr. BUGS If a read or a write of a pipe is interrupted, some unknown number of bytes may have been transferred. When a read from a pipe returns 0 bytes, it usually means end of file but is indistinguishable from reading the result of an explicit write of zero bytes. Page 1 Plan 9 (printed 1/22/25)