Rechercher une page de manuel
bind
Langue: de
Version: 13. Mai 1996 (openSuse - 09/10/07)
Section: 2 (Appels système)
BEZEICHNUNG
bind - verbindet einen Namen mit einem Socket.ÜBERSICHT
#include <sys/types.h>#include <sys/socket.h>
int bind(int sockfd, struct sockaddr *my_addr, int addrlen);
BESCHREIBUNG
bind weist dem Socket sockfd die lokale Adresse my_addr zu. my_addr ist addrlen Bytes lang. Traditionsgemäß wird dies "einem Socket einen Namen zuweisen" genannt (wenn ein Socket mit socket(2) erzeugt wird, existiert er in einer Adressfamilie (Namespace), hat aber keinen eigenen Namen.BEMERKUNGEN
Einen Namen in einer UNIX-Domäne zu binden, erzeugt einen Socket im Dateisystem, welches vom Erzeuger gelöscht werden muss, wenn dieser nicht mehr gebraucht wird (hierzu wird unlink(2) benutzt).Die Regeln, um zwischen verschiedenen Domänen zu Kommunizieren, variieren. Hier sei auf die Handbuchseite in Abschnitt 4 verwiesen.
RÜCKGABEWERTE
Bei erfolgreicher Ausführung wird null zurückgeliefert, bei einem Fehler -1 und errno entsprecht gesetzt.FEHLER
- EBADF
- sockfd ist kein gültiger Deskriptor.
- EINVAL
- Der Socket ist bereits an eine Adresse gebunden. Dies kann sich in Zukunft ändern. Siehe linux/unix/sock.c für Details.
- EACCES
- Die Adresse ist geschützt und der Benutzer ist nicht der Super-User.
Die folgenden Fehlermeldungen sind spezifisch für UNIX-Domänensockets (AF_UNIX):
- EINVAL
- Die addr_len war falsch oder der Socket gehörte nicht zur AF_UNIX Familie.
- EROFS
- Die Socket "Inode" sollte auf einem schreibgeschützten Dateisystem residieren.
- EFAULT
- my_addr weist auf eine Adresse außerhalb des erreichbaren Adressraumes zu.
- ENAMETOOLONG
- my_addr ist zu lang.
- ENOENT
- Die Datei existiert nicht.
- ENOMEM
- Nicht genug Kernelspeicher vorhanden.
- ENOTDIR
- Eine Komponente des Pfad-Präfixes ist kein Verzeichnis.
- EACCES
- Keine berechtigung um eine Komponente des Pfad-prefixes zu durchsuchen.
- ELOOP
- my_addr enthält eine Kreis-Referenz (zum Beispiel durch einen symbolischen Link)
GESCHICHTE
Der bind Funktionruf erschien zuerst in BSD 4.2.SIEHE AUCH
accept(2), connect(2), listen(2), socket(2), getsockname(2).Contenus ©2006-2023 Benjamin Poulain
Design ©2006-2023 Maxime Vantorre