home *** CD-ROM | disk | FTP | other *** search
/ Serving the Web / ServingTheWeb1995.disc1of1.iso / linux / slacksrce / d / libc / libc-4.6 / libc-4 / libc-linux / inet / bindresvport.c next >
Encoding:
C/C++ Source or Header  |  1992-11-20  |  2.3 KB  |  82 lines

  1. /*
  2. static  char sccsid[] = "@(#)bindresvport.c    2.2 88/07/29 4.0 RPCSRC 1.8 88/02/08 SMI";
  3.  * Sun RPC is a product of Sun Microsystems, Inc. and is provided for
  4.  * unrestricted use provided that this legend is included on all tape
  5.  * media and as a part of the software program in whole or part.  Users
  6.  * may copy or modify Sun RPC without charge, but are not authorized
  7.  * to license or distribute it to anyone else except as part of a product or
  8.  * program developed by the user.
  9.  * 
  10.  * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE
  11.  * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
  12.  * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE.
  13.  * 
  14.  * Sun RPC is provided with no support and without any obligation on the
  15.  * part of Sun Microsystems, Inc. to assist in its use, correction,
  16.  * modification or enhancement.
  17.  * 
  18.  * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE
  19.  * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC
  20.  * OR ANY PART THEREOF.
  21.  * 
  22.  * In no event will Sun Microsystems, Inc. be liable for any lost revenue
  23.  * or profits or other special, indirect and consequential damages, even if
  24.  * Sun has been advised of the possibility of such damages.
  25.  * 
  26.  * Sun Microsystems, Inc.
  27.  * 2550 Garcia Avenue
  28.  * Mountain View, California  94043
  29.  */
  30.  
  31. /*
  32.  * Copyright (c) 1987 by Sun Microsystems, Inc.
  33.  */
  34.  
  35. #include <strings.h>
  36. #include <unistd.h>
  37. #include <sys/types.h>
  38. #include <sys/errno.h>
  39. #include <sys/socket.h>
  40. #include <netinet/in.h>
  41.  
  42. /*
  43.  * Bind a socket to a privileged IP port
  44.  */
  45. int bindresvport(sd, sin)
  46.     int sd;
  47.     struct sockaddr_in *sin;
  48. {
  49.     int res;
  50.     static short port;
  51.     struct sockaddr_in myaddr;
  52.     extern int errno;
  53.     int i;
  54.  
  55. #define STARTPORT 600
  56. #define ENDPORT (IPPORT_RESERVED - 1)
  57. #define NPORTS    (ENDPORT - STARTPORT + 1)
  58.  
  59.     if (sin == (struct sockaddr_in *)0) {
  60.         sin = &myaddr;
  61.         bzero(sin, sizeof (*sin));
  62.         sin->sin_family = AF_INET;
  63.     } else if (sin->sin_family != AF_INET) {
  64.         errno = EPFNOSUPPORT;
  65.         return (-1);
  66.     }
  67.     if (port == 0) {
  68.         port = (getpid() % NPORTS) + STARTPORT;
  69.     }
  70.     res = -1;
  71.     errno = EADDRINUSE;
  72.     for (i = 0; i < NPORTS && res < 0 && errno == EADDRINUSE; i++) {
  73.         sin->sin_port = htons(port++);
  74.         if (port > ENDPORT) {
  75.             port = STARTPORT;
  76.         }
  77.         res = bind(sd, (struct sockaddr *) sin,
  78.             sizeof(struct sockaddr_in));
  79.     }
  80.     return (res);
  81. }
  82.