Manpages

JMÉNO

bind − přiřazení adresy (jména) soketu

SYNTAXE

#include <sys/types.h>
#include <sys/socket.h>

int bind(int sockfd, struct sockaddr *my_addr, int addrlen);

POPIS

bind přiřadí soketu sockfd, lokální adresu my_addr. my_addr je addrlen bajtů dlouhá. Tradičně je tato operace nazývána "přiřazení jména soketu" (když je soket vytvořen voláním socket(2), tak existuje v jmenném prostoru (rodině adres), ale není mu přiřazeno jméno.)

POZNÁMKY

Přiřazení jména v doméně UNIX vytvoří soket na souborovém systému, který musí být smazán, jestliže již nebude dále využíván (voláním unlink(2)).

Pravidla používaná při přiřazování jména soketu závisí na komunikační doméně (jmenném prostoru). Bližší informace naleznete v sekci 4 manuálových stránek.

NÁVRATOVÁ HODNOTA

Je-li volání úspěšné, je vrácena 0. Při chybě je vrácena −1 a proměnná errno je nastavena.

CHYBY

EBADF

sockfd není platným deskriptorem.

EINVAL

Soket už má přidělenu adresu.

EACCES

Adresa je chráněna a uživatel není super uživatelem.

ENOTSOCK

Argument je souborovým deskriptorem, není to soket.

Následující chyby jsou specifické pro UNIXovou doménu (AF_UNIX):

EINVAL

Adresa addr_len je špatná nebo soket nebyl ve formátu AF_UNIX .

EROFS

I-uzel soketu se má nacházet na souborovém systému určeném pouze pro čtení.

EFAULT

my_addr ukazuje mimo přístupný adresový prostor.

ENAMETOOLONG

my_addr je příliš dlouhá.

ENOENT

Soubor neexistuje.

ENOMEM

Nedostatek paměti v jádře.

ENOTDIR

Část cesty není adresář.

EACCES

Nemáte právo k přístupu do části cesty.

ELOOP

my_addr obsahuje kruhový odkaz (např. přes symbolický odkaz)

SPLŇUJE STANDARDY

SVr4, 4.4BSD (funkce bind se poprvé objevila v BSD 4.2). SVr4 dokumentuje další chyby: EADDRNOTAVAIL, EADDRINUSE, ENOSR, a chyby specifické pro UNIXovou doménu EIO, EISDIR a EROFS.

DALŠÍ INFORMACE

accept(2), connect(2), listen(2), socket(2), getsockname(2)

VAROVÁNÍ

Překlad je pravděpodobně zastaralý. Pokud chcete pomoci s jeho aktualizací, zamiřte na http://man-pages-cs-wiki.homelinux.net/