Go to main content

man pages section 3: Basic Library Functions

Exit Print View

Updated: July 2017
 
 

tcdrain(3C)

Name

tcdrain - wait for transmission of output

Synopsis

#include <termios.h>

int tcdrain(int fildes);

Description

The tcdrain () function waits until all output written to the object referred to by fildes is transmitted. The fildes argument is an open file descriptor associated with a terminal.

Any attempts to use tcdrain() from a process which is a member of a background process group on a fildes associated with its controlling terminal, will cause the process group to be sent a SIGTTOU signal. If the calling process is blocking or ignoring SIGTTOU signals, the process is allowed to perform the operation, and no signal is sent.

Return Values

Upon successful completion, 0 is returned. Otherwise, −1 is returned and errno is set to indicate the error.

Errors

The tcdrain() function will fail if:

EBADF

The fildes argument is not a valid file descriptor.

EINTR

A signal interrupted tcdrain().

ENOTTY

The file associated with fildes is not a terminal.

The tcdrain() function may fail if:

EIO

The process group of the writing process is orphaned, and the writing process is not ignoring or blocking SIGTTOU.

Attributes

See attributes(5) for descriptions of the following attributes:

ATTRIBUTE TYPE
ATTRIBUTE VALUE
Interface Stability
Committed
MT-Level
MT-Safe, and Async-Signal-Safe
Standard

See Also

tcflush(3C), attributes(5), standards(5), termio(7I)