Skip to content

Commit

Permalink
Suppress sign-conversion warning from FD_SET.
Browse files Browse the repository at this point in the history
[BZ #14210] See <http://sourceware.org/ml/libc-alpha/2012-05/msg01794.html>.
* debug/fdelt_chk.c (__fdelt_chk): Accept and return long int,
not unsigned long int.
* misc/bits/select2.h (__fdelt_chk, __fdelt_warn, __FD_ELT): Likewise.
  • Loading branch information
Paul Pluzhnikov authored and Paul Eggert committed Jun 13, 2012
1 parent ddb2897 commit ceb9e56
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 10 deletions.
9 changes: 9 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,12 @@
2012-06-13 Paul Pluzhnikov <ppluzhnikov@google.com>

[BZ #14210]
Suppress sign-conversion warning from FD_SET.
See <http://sourceware.org/ml/libc-alpha/2012-05/msg01794.html>.
* debug/fdelt_chk.c (__fdelt_chk): Accept and return long int,
not unsigned long int.
* misc/bits/select2.h (__fdelt_chk, __fdelt_warn, __FD_ELT): Likewise.

2012-06-12 H.J. Lu <hongjiu.lu@intel.com>

[BZ #14050]
Expand Down
8 changes: 4 additions & 4 deletions debug/fdelt_chk.c
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* Copyright (C) 2011 Free Software Foundation, Inc.
/* Copyright (C) 2011, 2012 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
Expand All @@ -18,10 +18,10 @@
#include <sys/select.h>


unsigned long int
__fdelt_chk (unsigned long int d)
long int
__fdelt_chk (long int d)
{
if (d >= FD_SETSIZE)
if (d < 0 || d >= FD_SETSIZE)
__chk_fail ();

return d / __NFDBITS;
Expand Down
13 changes: 7 additions & 6 deletions misc/bits/select2.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/* Checking macros for select functions.
Copyright (C) 2011 Free Software Foundation, Inc.
Copyright (C) 2011, 2012 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
Expand All @@ -21,14 +21,15 @@
#endif

/* Helper functions to issue warnings and errors when needed. */
extern unsigned long int __fdelt_chk (unsigned long int __d);
extern unsigned long int __fdelt_warn (unsigned long int __d)
extern long int __fdelt_chk (long int __d);
extern long int __fdelt_warn (long int __d)
__warnattr ("bit outside of fd_set selected");
#undef __FD_ELT
#define __FD_ELT(d) \
__extension__ \
({ unsigned long int __d = (d); \
({ long int __d = (d); \
(__builtin_constant_p (__d) \
? (__d >= __FD_SETSIZE \
? __fdelt_warn (__d) : (__d / __NFDBITS)) \
? (0 <= __d && __d < __FD_SETSIZE \
? (__d / __NFDBITS) \
: __fdelt_warn (__d)) \
: __fdelt_chk (__d)); })

0 comments on commit ceb9e56

Please sign in to comment.