1994-05-24 10:09:53 +00:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 1982, 1986, 1990, 1993, 1994
|
|
|
|
* The Regents of the University of California. All rights reserved.
|
|
|
|
* (c) UNIX System Laboratories, Inc.
|
|
|
|
* All or some portions of this file are derived from material licensed
|
|
|
|
* to the University of California by American Telephone and Telegraph
|
|
|
|
* Co. or Unix System Laboratories, Inc. and are reproduced herein with
|
|
|
|
* the permission of UNIX System Laboratories, Inc.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 4. Neither the name of the University nor the names of its contributors
|
|
|
|
* may be used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* @(#)filio.h 8.1 (Berkeley) 3/28/94
|
1999-08-28 01:08:13 +00:00
|
|
|
* $FreeBSD$
|
1994-05-24 10:09:53 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SYS_FILIO_H_
|
|
|
|
#define _SYS_FILIO_H_
|
|
|
|
|
|
|
|
#include <sys/ioccom.h>
|
|
|
|
|
|
|
|
/* Generic file-descriptor ioctl's. */
|
|
|
|
#define FIOCLEX _IO('f', 1) /* set close on exec on fd */
|
|
|
|
#define FIONCLEX _IO('f', 2) /* remove close on exec */
|
|
|
|
#define FIONREAD _IOR('f', 127, int) /* get # bytes to read */
|
|
|
|
#define FIONBIO _IOW('f', 126, int) /* set/clear non-blocking i/o */
|
|
|
|
#define FIOASYNC _IOW('f', 125, int) /* set/clear async i/o */
|
|
|
|
#define FIOSETOWN _IOW('f', 124, int) /* set owner */
|
|
|
|
#define FIOGETOWN _IOR('f', 123, int) /* get owner */
|
1999-08-27 16:35:37 +00:00
|
|
|
#define FIODTYPE _IOR('f', 122, int) /* get d_flags type part */
|
1999-12-07 22:25:28 +00:00
|
|
|
#define FIOGETLBA _IOR('f', 121, int) /* get start blk # */
|
2005-03-08 21:32:19 +00:00
|
|
|
struct fiodgname_arg {
|
|
|
|
int len;
|
|
|
|
void *buf;
|
|
|
|
};
|
|
|
|
#define FIODGNAME _IOW('f', 120, struct fiodgname_arg) /* get dev. name */
|
There are a number of ways an application can check if there are
inbound data waiting on a filedescriptor, such as a pipe or a socket,
for instance by using select(2), poll(2), kqueue(2), ioctl(FIONREAD)
etc.
But we have no way of finding out if written data have yet to be
disposed of, for instance, transmitted (and ack'ed!) to some remote
host, or read by the applicantion at the far end of the pipe.
The closest we get, is calling shutdown(2) on a TCP socket in
non-blocking mode, but this has the undesirable sideeffect of
preventing future communication.
Add a complement to FIONREAD, called FIONWRITE, which returns the
number of bytes not yet properly disposed of. Implement it for
all sockets.
Background:
A HTTP server will want to time out connections, if no new request
arrives within a certain period after the last transmitted response
has actually been sent (and ack'ed).
For a busy HTTP server, this timeout can be subsecond duration.
In order to signal to a load-balancer that the connection is truly
dead, TCP_RST will be the preferred method, as this avoids the need
for a RTT delay for FIN handshaking, with a client which, surprisingly
often, no longer at the remote IP number.
If a slow, distant client is being served a response which is big
enough to fill the window, but small enough to fit in the socket
buffer, the write(2) call will return immediately.
If the session timeout is armed at that time, all bytes in the
response may not have been transmitted by the time it fires.
FIONWRITE allows the timeout to check that no data is outstanding
on the connection, before it TCP_RST's it.
Input & Idea from: rwatson
Approved by: re (kib)
2009-06-28 11:28:14 +00:00
|
|
|
#define FIONWRITE _IOR('f', 119, int) /* get # bytes (yet) to write */
|
2009-06-30 13:38:49 +00:00
|
|
|
#define FIONSPACE _IOR('f', 118, int) /* get space in send queue */
|
2007-04-05 21:10:53 +00:00
|
|
|
/* Handle lseek SEEK_DATA and SEEK_HOLE for holey file knowledge. */
|
|
|
|
#define FIOSEEKDATA _IOWR('f', 97, off_t) /* SEEK_DATA */
|
|
|
|
#define FIOSEEKHOLE _IOWR('f', 98, off_t) /* SEEK_HOLE */
|
1994-05-24 10:09:53 +00:00
|
|
|
|
|
|
|
#endif /* !_SYS_FILIO_H_ */
|