mirror of
https://github.com/PowerShell/openssh-portable.git
synced 2025-07-31 01:35:11 +02:00
- Clean up bsd-bindresvport.c. Use arc4random() for picking initial
port, ignore EINVAL errors (Linux) when searching for free port.
This commit is contained in:
parent
62a52ef08d
commit
b9b94a74e6
@ -1,3 +1,7 @@
|
|||||||
|
20000117
|
||||||
|
- Clean up bsd-bindresvport.c. Use arc4random() for picking initial
|
||||||
|
port, ignore EINVAL errors (Linux) when searching for free port.
|
||||||
|
|
||||||
20000116
|
20000116
|
||||||
- Renamed --with-xauth-path to --with-xauth
|
- Renamed --with-xauth-path to --with-xauth
|
||||||
- Added --with-pid-dir option
|
- Added --with-pid-dir option
|
||||||
|
@ -47,19 +47,6 @@ static char *rcsid = "$OpenBSD: bindresvport.c,v 1.11 1999/12/17 19:22:08 deraad
|
|||||||
#define ENDPORT (IPPORT_RESERVED - 1)
|
#define ENDPORT (IPPORT_RESERVED - 1)
|
||||||
#define NPORTS (ENDPORT - STARTPORT + 1)
|
#define NPORTS (ENDPORT - STARTPORT + 1)
|
||||||
|
|
||||||
#if 0
|
|
||||||
/*
|
|
||||||
* Bind a socket to a privileged IP port
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
bindresvport(sd, sin)
|
|
||||||
int sd;
|
|
||||||
struct sockaddr_in *sin;
|
|
||||||
{
|
|
||||||
return bindresvport_af(sd, (struct sockaddr *)sin, AF_INET);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Bind a socket to a privileged IP port
|
* Bind a socket to a privileged IP port
|
||||||
*/
|
*/
|
||||||
@ -97,17 +84,20 @@ bindresvport_af(sd, sa, af)
|
|||||||
sa->sa_family = af;
|
sa->sa_family = af;
|
||||||
|
|
||||||
if (*portp == 0)
|
if (*portp == 0)
|
||||||
*portp = (getpid() % NPORTS) + STARTPORT;
|
*portp = (arc4random() % NPORTS) + STARTPORT;
|
||||||
|
|
||||||
for(i = 0; i < NPORTS; i++) {
|
for(i = 0; i < NPORTS; i++) {
|
||||||
error = bind(sd, sa, salen);
|
error = bind(sd, sa, salen);
|
||||||
|
|
||||||
if ((error == 0) || ((error < 0) && (errno != EADDRINUSE)))
|
/* Terminate on success */
|
||||||
|
if (error == 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
(*portp)++;
|
/* Terminate on errors, except "address already in use" */
|
||||||
if (*portp < ENDPORT)
|
if ((error < 0) && ((errno != EADDRINUSE) || (errno != EINVAL)))
|
||||||
*portp = STARTPORT;
|
break;
|
||||||
|
|
||||||
|
*portp = (i % NPORTS) + STARTPORT;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (error);
|
return (error);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user