From 43558316bc4e6ddac92dd198b07a4803c21dc77b Mon Sep 17 00:00:00 2001 From: Holger Hans Peter Freyther Date: Fri, 6 Aug 2010 06:48:43 +0800 Subject: bsc_fd: Add a build option to be able to debug fd list corruption bsc_register_fd on an already registered fd can corrupt the list in a heavy way and make the select end in an infinite loop, this code will workaround the issue and provide a way to set a breakpoint at the right position in the code. --- src/select.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'src/select.c') diff --git a/src/select.c b/src/select.c index 2f6afa7f..f52b0a0c 100644 --- a/src/select.c +++ b/src/select.c @@ -19,6 +19,8 @@ */ #include +#include + #include #include #include @@ -48,6 +50,16 @@ int bsc_register_fd(struct bsc_fd *fd) if (fd->fd > maxfd) maxfd = fd->fd; +#ifdef BSC_FD_CHECK + struct bsc_fd *entry; + llist_for_each_entry(entry, &bsc_fds, list) { + if (entry == fd) { + fprintf(stderr, "Adding a bsc_fd that is already in the list.\n"); + return 0; + } + } +#endif + llist_add_tail(&fd->list, &bsc_fds); return 0; -- cgit v1.2.3