bindresvport.c 2.4 KB

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