mirror of
https://sourceware.org/git/glibc.git
synced 2025-07-28 00:21:52 +03:00
Add range checking for FD_SET, FD_CLR, and FD_ISSET
This commit is contained in:
@ -1,4 +1,4 @@
|
||||
# Copyright (C) 1998-2001,2004-2008, 2009 Free Software Foundation, Inc.
|
||||
# Copyright (C) 1998-2001,2004-2008, 2009, 2011 Free Software Foundation, Inc.
|
||||
# This file is part of the GNU C Library.
|
||||
|
||||
# The GNU C Library is free software; you can redistribute it and/or
|
||||
@ -44,6 +44,7 @@ routines = backtrace backtracesyms backtracesymsfd noophooks \
|
||||
wcstombs_chk asprintf_chk vasprintf_chk dprintf_chk \
|
||||
vdprintf_chk obprintf_chk \
|
||||
longjmp_chk ____longjmp_chk \
|
||||
fdelt_chk \
|
||||
stack_chk_fail fortify_fail \
|
||||
$(static-only-routines)
|
||||
static-only-routines := warning-nop stack_chk_fail_local
|
||||
|
@ -49,6 +49,9 @@ libc {
|
||||
GLIBC_2.11 {
|
||||
__longjmp_chk;
|
||||
}
|
||||
GLIBC_2.15 {
|
||||
__fdelt_chk; __fdelt_warn;
|
||||
}
|
||||
GLIBC_PRIVATE {
|
||||
__fortify_fail;
|
||||
}
|
||||
|
30
debug/fdelt_chk.c
Normal file
30
debug/fdelt_chk.c
Normal file
@ -0,0 +1,30 @@
|
||||
/* Copyright (C) 2011 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
|
||||
The GNU C Library is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU Lesser General Public
|
||||
License as published by the Free Software Foundation; either
|
||||
version 2.1 of the License, or (at your option) any later version.
|
||||
|
||||
The GNU C Library is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
Lesser General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with the GNU C Library; if not, write to the Free
|
||||
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
||||
02111-1307 USA. */
|
||||
|
||||
#include <sys/select.h>
|
||||
|
||||
|
||||
unsigned long int
|
||||
__fdelt_chk (unsigned long int d)
|
||||
{
|
||||
if (d >= FD_SETSIZE)
|
||||
__chk_fail ();
|
||||
|
||||
return d / __NFDBITS;
|
||||
}
|
||||
strong_alias (__fdelt_chk, __fdelt_warn)
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 2004,2005,2006,2007,2008,2011 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
Contributed by Jakub Jelinek <jakub@redhat.com>, 2004.
|
||||
|
||||
@ -29,6 +29,7 @@
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
#include <wchar.h>
|
||||
#include <sys/select.h>
|
||||
#include <sys/socket.h>
|
||||
#include <sys/un.h>
|
||||
|
||||
@ -107,11 +108,11 @@ int num2 = 987654;
|
||||
FAIL (); \
|
||||
}
|
||||
#if __USE_FORTIFY_LEVEL >= 2 && (!defined __cplusplus || defined __va_arg_pack)
|
||||
#define CHK_FAIL2_START CHK_FAIL_START
|
||||
#define CHK_FAIL2_END CHK_FAIL_END
|
||||
# define CHK_FAIL2_START CHK_FAIL_START
|
||||
# define CHK_FAIL2_END CHK_FAIL_END
|
||||
#else
|
||||
#define CHK_FAIL2_START
|
||||
#define CHK_FAIL2_END
|
||||
# define CHK_FAIL2_START
|
||||
# define CHK_FAIL2_END
|
||||
#endif
|
||||
|
||||
static int
|
||||
@ -1448,5 +1449,26 @@ do_test (void)
|
||||
CHK_FAIL_END
|
||||
#endif
|
||||
|
||||
fd_set s;
|
||||
FD_ZERO (&s);
|
||||
FD_SET (FD_SETSIZE - 1, &s);
|
||||
#if __USE_FORTIFY_LEVEL >= 1
|
||||
CHK_FAIL_START
|
||||
FD_SET (FD_SETSIZE, &s);
|
||||
CHK_FAIL_END
|
||||
#endif
|
||||
FD_CLR (FD_SETSIZE - 1, &s);
|
||||
#if __USE_FORTIFY_LEVEL >= 1
|
||||
CHK_FAIL_START
|
||||
FD_CLR (FD_SETSIZE, &s);
|
||||
CHK_FAIL_END
|
||||
#endif
|
||||
FD_ISSET (FD_SETSIZE - 1, &s);
|
||||
#if __USE_FORTIFY_LEVEL >= 1
|
||||
CHK_FAIL_START
|
||||
FD_ISSET (FD_SETSIZE, &s);
|
||||
CHK_FAIL_END
|
||||
#endif
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
Reference in New Issue
Block a user