home *** CD-ROM | disk | FTP | other *** search
/ Celestin Apprentice 2 / Apprentice-Release2.iso / Source Code / C / Libraries / GUSI-RPC 4.0 / bindresvport.c < prev    next >
Encoding:
Text File  |  1993-08-18  |  2.3 KB  |  80 lines  |  [TEXT/MPS ]

  1. static  char sccsid[] = "@(#)bindresvport.c    2.2 88/07/29 4.0 RPCSRC 1.8 88/02/08 SMI";
  2. /*
  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 <GUSI.h>
  36. #include <sys/types.h>
  37. #include <sys/errno.h>
  38. #include <sys/socket.h>
  39. #include <netinet/in.h>
  40.  
  41. /*
  42.  * Bind a socket to a privileged IP port
  43.  */
  44. bindresvport(sd, sin)
  45.     int sd;
  46.     struct sockaddr_in *sin;
  47. {
  48.     int res;
  49.     static short port;
  50.     struct sockaddr_in myaddr;
  51.     extern int errno;
  52.     int i;
  53.  
  54. #define STARTPORT 600
  55. #define ENDPORT (IPPORT_RESERVED - 1)
  56. #define NPORTS    (ENDPORT - STARTPORT + 1)
  57.  
  58.     if (sin == (struct sockaddr_in *)0) {
  59.         sin = &myaddr;
  60.         bzero(sin, sizeof (*sin));
  61.         sin->sin_family = AF_INET;
  62.     } else if (sin->sin_family != AF_INET) {
  63.         errno = EPFNOSUPPORT;
  64.         return (-1);
  65.     }
  66.     if (port == 0) {
  67.         port = (getpid() % NPORTS) + STARTPORT;
  68.     }
  69.     res = -1;
  70.     errno = EADDRINUSE;
  71.     for (i = 0; i < NPORTS && res < 0 && errno == EADDRINUSE; i++) {
  72.         sin->sin_port = htons(port++);
  73.         if (port > ENDPORT) {
  74.             port = STARTPORT;
  75.         }
  76.         res = bind(sd, (struct sockaddr *) sin, sizeof(struct sockaddr_in));
  77.     }
  78.     return (res);
  79. }
  80.