Finish the range checking on all FD_SET calls for select().
authorJeremy Allison <jra@samba.org>
Mon, 28 Feb 2011 19:23:53 +0000 (11:23 -0800)
committerJeremy Allison <jra@samba.org>
Mon, 28 Feb 2011 20:10:08 +0000 (21:10 +0100)
Autobuild-User: Jeremy Allison <jra@samba.org>
Autobuild-Date: Mon Feb 28 21:10:08 CET 2011 on sn-devel-104

lib/tevent/tevent_select.c
lib/tevent/tevent_standard.c

index 8cc6d06a59d6042f4c43ac1a86d71a68bdcd298a..94faa8659340a7d5ab1bb4d0833520a8b56ebe09 100644 (file)
@@ -111,6 +111,11 @@ static struct tevent_fd *select_event_add_fd(struct tevent_context *ev, TALLOC_C
                                                           struct select_event_context);
        struct tevent_fd *fde;
 
+       if (fd < 0 || fd >= FD_SETSIZE) {
+               errno = EBADF;
+               return NULL;
+       }
+
        fde = tevent_common_add_fd(ev, mem_ctx, fd, flags,
                                   handler, private_data,
                                   handler_name, location);
@@ -144,6 +149,11 @@ static int select_event_loop_select(struct select_event_context *select_ev, stru
 
        /* setup any fd events */
        for (fde = select_ev->ev->fd_events; fde; fde = fde->next) {
+               if (fde->fd < 0 || fde->fd >= FD_SETSIZE) {
+                       errno = EBADF;
+                       return -1;
+               }
+
                if (fde->flags & TEVENT_FD_READ) {
                        FD_SET(fde->fd, &r_fds);
                }
index a68a03c2acb8ef080c2cd421d06a3ea72f04159f..35f7ded9b703792e4abfdf389bf9c74b0e1bde4e 100644 (file)
@@ -457,6 +457,10 @@ static int std_event_loop_select(struct std_event_context *std_ev, struct timeva
 
        /* setup any fd events */
        for (fde = std_ev->ev->fd_events; fde; fde = fde->next) {
+               if (fde->fd < 0 || fde->fd >= FD_SETSIZE) {
+                       std_ev->exit_code = EBADF;
+                       return -1;
+               }
                if (fde->flags & TEVENT_FD_READ) {
                        FD_SET(fde->fd, &r_fds);
                }