X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fsd-daemon.h;h=e209af64896d12d6c027db6480502b5e579915e5;hb=bc0f8771f23dc3952bf4b06301dc842ba625a0f2;hp=b7100bcd5e3cb8a65d5f0f36204c2bef5e28619e;hpb=7c394faa38de389638e19b19212ed50aca870e3c;p=elogind.git diff --git a/src/sd-daemon.h b/src/sd-daemon.h index b7100bcd5..e209af648 100644 --- a/src/sd-daemon.h +++ b/src/sd-daemon.h @@ -73,20 +73,26 @@ int sd_listen_fds(int unset_environment); int sd_is_fifo(int fd, const char *path); /* Helper call for identifying a passed file descriptor. Returns 1 if - * the file descriptor is a socket of the specified type (SOCK_DGRAM, - * SOCK_STREAM, ...), 0 otherwise. If type is 0 a socket type check - * will not be done and the call only verifies if the file descriptor - * refers to a socket. Returns a negative errno style error code on - * failure. */ -int sd_is_socket(int fd, int type, int listening); + * the file descriptor is a socket of the specified family (AF_INET, + * ...) and type (SOCK_DGRAM, SOCK_STREAM, ...), 0 otherwise. If + * family is 0 a socket family check will not be done. If type is 0 a + * socket type check will not be done and the call only verifies if + * the file descriptor refers to a socket. If listening is > 0 it is + * verified that the socket is in listening mode. (i.e. listen() has + * been called) If listening is == 0 it is verified that the socket is + * not in listening mode. If listening is < 0 no listening mode check + * is done. Returns a negative errno style error code on failure. */ +int sd_is_socket(int fd, int family, int type, int listening); /* Helper call for identifying a passed file descriptor. Returns 1 if - * the file descriptor is an Internet socket (either AF_INET or - * AF_INET6) of the specified type (SOCK_DGRAM, SOCK_STREAM, ...), 0 - * otherwise. If type is 0 a socket type check will not be done. If - * port is 0 a socket port check will not be done. Returns a negative - * errno style error code on failure. */ -int sd_is_socket_inet(int fd, int type, int listening, uint16_t port); + * the file descriptor is an Internet socket, of the specified family + * (either AF_INET or AF_INET6) of the specified type (SOCK_DGRAM, + * SOCK_STREAM, ...), 0 otherwise. If version is 0 a protocol version + * check is not done. If type is 0 a socket type check will not be + * done. If port is 0 a socket port check will not be done. The + * listening flag is used the same way as in sd_is_socket(). Returns a + * negative errno style error code on failure. */ +int sd_is_socket_inet(int fd, int family, int type, int listening, uint16_t port); /* Helper call for identifying a passed file descriptor. Returns 1 if * the file descriptor is an AF_UNIX socket of the specified type @@ -94,7 +100,9 @@ int sd_is_socket_inet(int fd, int type, int listening, uint16_t port); * a socket type check will not be done. If path is NULL a socket path * check will not be done. For normal AF_UNIX sockets set length to * 0. For abstract namespace sockets set length to the length of the - * socket name (excluding the initial 0 byte). Returns a negative + * socket name (including the initial 0 byte), and pass the full + * socket path in path (including the initial 0 byte). The listening + * flag is used the same way as in sd_is_socket(). Returns a negative * errno style error code on failure. */ int sd_is_socket_unix(int fd, int type, int listening, const char *path, size_t length);