Skip to content

Commit

Permalink
Merge branch 'bugfix/newlib_FD_ISSET_v4.2' into 'release/v4.2'
Browse files Browse the repository at this point in the history
newlib: Fix a case in FD_ISSET macro when n==-1 (v4.2)

See merge request espressif/esp-idf!13691
  • Loading branch information
Zim Kalinowski committed Jul 19, 2021
2 parents 5bb0706 + 1214dce commit 469be5f
Showing 1 changed file with 13 additions and 0 deletions.
13 changes: 13 additions & 0 deletions components/newlib/platform_include/sys/select.h
Original file line number Diff line number Diff line change
Expand Up @@ -34,4 +34,17 @@ int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *errorfds, struct

#endif // fd_set

#if defined(FD_ISSET) || defined(FD_SET) || defined(FD_CLR)
#undef FD_SET
#undef FD_CLR
#undef FD_ISSET

#define __FD_SAFE_SET(n, code) do { if ((unsigned)(n) < FD_SETSIZE) { code; } } while(0)
#define __FD_SAFE_GET(n, code) (((unsigned)(n) < FD_SETSIZE) ? (code) : 0)

#define FD_SET(n, p) __FD_SAFE_SET(n, ((p)->fds_bits[(n) / NFDBITS] |= (1L << ((n) % NFDBITS))))
#define FD_CLR(n, p) __FD_SAFE_SET(n, ((p)->fds_bits[(n) / NFDBITS] &= ~(1L << ((n) % NFDBITS))))
#define FD_ISSET(n, p) __FD_SAFE_GET(n, ((p)->fds_bits[(n) / NFDBITS] & (1L << ((n) % NFDBITS))))
#endif // FD_ISSET || FD_SET || FD_CLR

#endif //__ESP_SYS_SELECT_H__

0 comments on commit 469be5f

Please sign in to comment.