НАЗВАНИЕ
bind − привязать имя к сокету
ОБЗОР
#include
<sys/types.h>
#include <sys/socket.h>
int bind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen);
ОПИСАНИЕ
bind привязывает к сокету sockfd локальный адрес my_addr длиной addrlen. Традиционно, эта операция называется “присваивание сокету имени.” Когда сокет только что создан с помощью socket(2), он существует в пространстве имён (семействе адресов), но не имеет назначенного имени.
Обычно сокету типа SOCK_STREAM требуется назначить локальный адрес с помощью bind, перед тем, как он сможет принимать соединения (см. accept(2)).
Правила, используемые при привязке имён, разные в разных семействах адресов. Обратитесь к соответствующему руководству в секции 7 за дальнейшей информацией. Для AF_INET смотри ip(7), для AF_UNIX смотри unix(7), для AF_APPLETALK смотри ddp(7), для AF_PACKET смотри packet(7), для AF_X25 смотри x25(7), а для AF_NETLINK смотри netlink(7).
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
В случае успеха возвращается ноль. При ошибке возвращается −1, а errno устанавливается должным образом.
ОШИБКИ
EBADF |
sockfd не является правильным дескриптором. | ||
EINVAL |
Сокет уже привязан к какому-то адресу. Эта ошибка в будущем может не выдаваться, смотри linux/unix/sock.c, где описаны детали. | ||
EACCES |
Адрес защищен, или пользователь не является суперпользователем. |
ENOTSOCK
Аргумент системного вызова является дескриптором файла, а не сокета.
Нижеследующие ошибки специфичны для сокетов домена UNIX (AF_UNIX):
EINVAL |
Параметр addrlen неверен, или сокет не был найден в семействе адресов AF_UNIX. | ||
EROFS |
Попытка создания inode сокета на файловой системе "только для чтения". | ||
EFAULT |
my_addr указывает за пределы доступного адресного пространства. |
ENAMETOOLONG
my_addr слишком длинно.
ENOENT |
Файл не существует. | ||
ENOMEM |
Ядру не хватило памяти. | ||
ENOTDIR |
Компонент пути, использованный как каталог, в действительности таковым не является. | ||
EACCES |
Не разрешен поиск в одном из компонентов пути. | ||
ELOOP |
my_addr является зацикленной символической ссылкой, то есть при подстановке возникает ссылка на неё саму. |
ОШИБКИ
Не описываются ключи, связанные с работой прозрачных прокси.
СООТВЕТСТВИЕ СТАНДАРТАМ
SVr4, 4.4BSD (функция bind впервые появилась в BSD 4.2). SVr4 документирует дополнительные коды ошибок EADDRNOTAVAIL, EADDRINUSE, и ENOSR, и дополнительные коды ошибок домена Unix: EIO и EISDIR
ЗАМЕЧАНИЕ
Третий аргумент вызова bind в действительности имеет тип int (это именно так в BSD 4.*, libc4 и libc5). При разработке стандарта POSIX случилось некоторое недопонимание, и появился тип socklen_t. Смотри также accept(2).
СМОТРИ ТАКЖЕ
accept(2), connect(2), listen(2), socket(2), getsockname(2), ip(7), socket(7)
ПЕРЕВОД
Copyright (C) Alexey Mahotkin <alexm [AT] hsys.ru> 1999