Skip to content

Commit

Permalink
MITKRB5-SA-2008-002
Browse files Browse the repository at this point in the history
Fix MITKRB5-SA-2008-002: array overrun in libgssrpc.

Don't update the internally-tracked maximum file descriptor value if
the new one is FD_SETSIZE (or NOFILE) or above.  Reject TCP file
descriptors of FD_SETSIZE (NOFILE) or above.

ticket: new
target_version: 1.6.4
tags: pullup

git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@20278 dc483132-0cff-0310-8789-dd5450dbe970
  • Loading branch information
Ken Raeburn committed Mar 18, 2008
1 parent f621122 commit d8d990c
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 2 deletions.
6 changes: 4 additions & 2 deletions src/lib/rpc/svc.c
Expand Up @@ -109,15 +109,17 @@ xprt_register(SVCXPRT *xprt)
if (sock < FD_SETSIZE) {
xports[sock] = xprt;
FD_SET(sock, &svc_fdset);
if (sock > svc_maxfd)
svc_maxfd = sock;
}
#else
if (sock < NOFILE) {
xports[sock] = xprt;
svc_fds |= (1 << sock);
if (sock > svc_maxfd)
svc_maxfd = sock;
}
#endif /* def FD_SETSIZE */
if (sock > svc_maxfd)
svc_maxfd = sock;
}

/*
Expand Down
25 changes: 25 additions & 0 deletions src/lib/rpc/svc_tcp.c
Expand Up @@ -54,6 +54,14 @@ static char sccsid[] = "@(#)svc_tcp.c 1.21 87/08/11 Copyr 1984 Sun Micro";
extern errno;
*/

#ifndef FD_SETSIZE
#ifdef NBBY
#define NOFILE (sizeof(int) * NBBY)
#else
#define NOFILE (sizeof(int) * 8)
#endif
#endif

/*
* Ops vector for TCP/IP based rpc service handle
*/
Expand Down Expand Up @@ -215,6 +223,19 @@ makefd_xprt(
register SVCXPRT *xprt;
register struct tcp_conn *cd;

#ifdef FD_SETSIZE
if (fd >= FD_SETSIZE) {
(void) fprintf(stderr, "svc_tcp: makefd_xprt: fd too high\n");
xprt = NULL;
goto done;
}
#else
if (fd >= NOFILE) {
(void) fprintf(stderr, "svc_tcp: makefd_xprt: fd too high\n");
xprt = NULL;
goto done;
}
#endif
xprt = (SVCXPRT *)mem_alloc(sizeof(SVCXPRT));
if (xprt == (SVCXPRT *)NULL) {
(void) fprintf(stderr, "svc_tcp: makefd_xprt: out of memory\n");
Expand Down Expand Up @@ -271,6 +292,10 @@ rendezvous_request(
* make a new transporter (re-uses xprt)
*/
xprt = makefd_xprt(sock, r->sendsize, r->recvsize);
if (xprt == NULL) {
close(sock);
return (FALSE);
}
xprt->xp_raddr = addr;
xprt->xp_addrlen = len;
xprt->xp_laddr = laddr;
Expand Down

0 comments on commit d8d990c

Please sign in to comment.