.\" -*- coding: UTF-8 -*- '\" t .\" Copyright (C) 2007, Michael Kerrisk .\" and Copyright (C) 2008, Linux Foundation, written by Michael Kerrisk .\" .\" .\" SPDX-License-Identifier: Linux-man-pages-copyleft .\" .\" 2007-05-31, mtk: Rewrite and substantial additional text. .\" 2008-12-03, mtk: Rewrote some pieces and fixed some errors .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH bindresvport 3 "20 июля 2023 г." "Linux man\-pages 6.05.01" .SH ИМЯ bindresvport \- привязывает сокет к привилегированному порту IP .SH LIBRARY Standard C library (\fIlibc\fP, \fI\-lc\fP) .SH СИНТАКСИС .nf \fB#include \fP \fB#include \fP .PP \fBint bindresvport(int \fP\fIsockfd\fP\fB, struct sockaddr_in *\fP\fIsin\fP\fB);\fP .fi .SH ОПИСАНИЕ .\" glibc actually starts searching with a port # in the range 600 to 1023 Функция \fBbindresvport\fP() используется для привязки сокета, на который указывает файловый дескриптор \fIsockfd\fP, к привилегированному анонимному порту IP, то есть произвольно выбранному порту с номером из диапазона от 512 до 1023. .PP Если \fBbind\fP(2), вызываемый из \fBbindresvport\fP(), выполнен без ошибок, и значение \fIsin\fP не равно NULL, то в \fIsin\->sin_port\fP возвращается выделенный номер порта. .PP Значение \fIsin\fP может быть NULL; в этом случае \fIsin\->sin_family\fP неявно присваивается значение \fBAF_INET\fP. Однако в этом случае \fBbindresvport\fP() не возвращает номер порта, который был в действительности выделен (эта информация может быть получена позже с помощью \fBgetsockname\fP(2)). .SH "ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ" \fBbindresvport\fP() returns 0 on success; otherwise \-1 is returned and \fIerrno\fP is set to indicate the error. .SH ОШИБКИ Функция \fBbindresvport\fP() может завершиться с ошибкой по тем же причинам что и \fBbind\fP(2). Также могут возникать следующие ошибки: .TP \fBEACCES\fP Вызывающий процесс не имеет прав (в Linux: вызывающий процесс не имеет мандата \fBCAP_NET_BIND_SERVICE\fP в пользовательском пространстве, управляющим своим сетевым пространством имён). .TP \fBEADDRINUSE\fP Все привилегированные порты заняты. .TP \fBEAFNOSUPPORT\fP (\fBEPFNOSUPPORT\fP в glibc 2.7 и старше) Значение \fIsin\fP не равно NULL и \fIsin\->sin_family\fP не равно \fBAF_INET\fP. .SH АТРИБУТЫ Описание терминов данного раздела смотрите в \fBattributes\fP(7). .TS allbox; lb lb lbx l l l. Интерфейс Атрибут Значение T{ .na .nh \fBbindresvport\fP() T} Безвредность в нитях T{ .na .nh .\" commit f6da27e53695ad1cc0e2a9490358decbbfdff5e5 glibc\ >=\ 2.17: MT\-Safe; glibc\ <\ 2.17: MT\-Unsafe T} .TE .sp 1 .PP До glibc 2.17 в функции \fBbindresvport\fP() используется статическая незащищённая блокировкой переменная, поэтому функцию нельзя использовать в нескольких нитях одновременно. .SH ВЕРСИИ Present on the BSDs, Solaris, and many other systems. .SH ЗАМЕЧАНИЯ В отличие от других реализаций \fBbindresvport\fP(), версия glibc игнорирует любые значения, которые передал вызывающий в \fIsin\->sin_port\fP. .SH СТАНДАРТЫ BSD. .SH "СМ. ТАКЖЕ" \fBbind\fP(2), \fBgetsockname\fP(2) .PP .SH ПЕРЕВОД Русский перевод этой страницы руководства был сделан Artyom Kunyov , Azamat Hackimov , Dmitriy Ovchinnikov , Dmitry Bolkhovskikh , ITriskTI , Yuri Kozlov и Иван Павлов . .PP Этот перевод является бесплатной документацией; прочитайте .UR https://www.gnu.org/licenses/gpl-3.0.html Стандартную общественную лицензию GNU версии 3 .UE или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ. .PP Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на .MT man-pages-ru-talks@lists.sourceforge.net .ME .