SINOPSIS
#include <sys/types.h>#include <sys/socket.h>
int bind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen);
DESCRIPCIÓN
bind da al conector sockfd la dirección local my_addr. my_addr tiene una longitud de addrlen bytes. Tradicionalmente, esto se conoce como "asignar un nombre a un conector." Cuando un conector se crea con socket(2), existe en un espacio de nombres (familia de direcciones) pero carece de nombre.Normalmente, es necesario asignar una dirección local usando bind a un conector SOCK_STREAM antes de que éste pueda recibir conexiones (vea accept(2)).
Las reglas usadas en el enlace de nombres varían entre familias de direcciones. Consulte las entradas de manual de la Sección 7 para obtener una información más detallada. Para AF_INET vea ip(7), para AF_UNIX vea unix(7), para AF_APPLETALK vea ddp(7), para AF_PACKET vea packet(7), para AF_X25 vea x25(7) y para AF_NETLINK vea netlink(7).
VALOR DEVUELTO
Se devuelve 0 en caso de éxito. En caso de error, se devuelve -1 y a errno se le asigna un valor apropiado.ERRORES
- EBADF
- sockfd no es un descriptor válido.
- EINVAL
- El conector ya está enlazado a una dirección. Esto puede cambiar en el futuro: véase linux/unix/sock.c para más detalles.
- EACCES
- La dirección está protegida y el usuario no es el superusuario.
Los siguientes errores son específicos a los conectores del dominio UNIX (AF_UNIX):
- EINVAL
- La dirección addr_len es incorrecta o el conector no pertenecia a la familia AF_UNIX.
- EROFS
- El nodo-i del conector reside en un sistema de ficheros de `sólo lectura'.
- EFAULT
- my_addr señala fuera del espacio de direcciones accesible por el usuario.
- ENAMETOOLONG
- my_addr es demasiado larga.
- ENOENT
- El fichero no existe.
- ENOMEM
- No hay suficiente memoria disponible en el núcleo.
- ENOTDIR
- Un componente del camino no es un directorio.
- EACCES
- El permiso de búsqueda ha sido denegado en uno de los componentes del camino.
- ELOOP
- Se han encontrado demasiados enlaces simbólicos al resolver my_addr.