.\" -*- 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 "2 мая 2024 г." "Справочные страницы Linux 6.9.1" .SH НАИМЕНОВАНИЕ bindresvport \- привязывает сокет к привилегированному порту IP .SH БИБЛИОТЕКА Стандартная библиотека языка C (\fIlibc\fP, \fI\-lc\fP) .SH ОБЗОР .nf \fB#include \fP \fB#include \fP .P \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. .P Если \fBbind\fP(2), вызываемый из \fBbindresvport\fP(), выполнен без ошибок, и значение \fIsin\fP не равно NULL, то в \fIsin\->sin_port\fP возвращается выделенный номер порта. .P Значение \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 .P До 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 , Иван Павлов и Kirill Rekhov . .PP Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, .UR https://www.gnu.org/licenses/gpl-3.0.html .UE версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ. .PP Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику(ам) по его(их) адресу(ам) электронной почты или по адресу .MT списка рассылки русских переводчиков .ME .