slirp: Clean up timeout handling around slirp_select_fill/poll
authorJan Kiszka <jan.kiszka@siemens.com>
Wed, 24 Jun 2009 12:42:30 +0000 (14:42 +0200)
committerAnthony Liguori <aliguori@us.ibm.com>
Mon, 29 Jun 2009 13:52:49 +0000 (08:52 -0500)
Again lot of dead code. Remove it.

Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
slirp/misc.c
slirp/misc.h
slirp/slirp.c

index cffb3a0dac9e707526c2a7a678cc80eadfd83c2e..ee14db5e38e6d23063260d6d2f1211a0a28793e5 100644 (file)
@@ -14,8 +14,6 @@
 int slirp_debug = DBG_CALL|DBG_MISC|DBG_ERROR;
 #endif
 
-u_int curtime, time_fasttimo, last_slowtimo;
-
 struct quehead {
        struct quehead *qh_link;
        struct quehead *qh_rlink;
index c21f69b0681d1b177b41805cd82d996fee3adec8..2f478885de23fa15480c1b376ac2802e7a43d734 100644 (file)
@@ -17,7 +17,6 @@ struct ex_list {
 };
 
 extern struct ex_list *exec_list;
-extern u_int time_fasttimo, last_slowtimo;
 
 #ifndef HAVE_STRDUP
 char *strdup _P((const char *));
index cf52d36ece42d7d9190a3b492af8c9fac5e80e69..9b51c0b0108e4ce16f7373cd0ec07e1b2202a1e9 100644 (file)
@@ -52,13 +52,16 @@ static struct in_addr client_ipaddr;
 static const uint8_t zero_ethaddr[6] = { 0, 0, 0, 0, 0, 0 };
 
 int slirp_restrict;
-static int do_slowtimo;
 int link_up;
 struct ex_list *exec_list;
 
 /* XXX: suppress those select globals */
 fd_set *global_readfds, *global_writefds, *global_xfds;
 
+u_int curtime;
+static u_int time_fasttimo, last_slowtimo;
+static int do_slowtimo;
+
 char slirp_hostname[33];
 
 #ifdef _WIN32
@@ -267,9 +270,7 @@ void slirp_select_fill(int *pnfds,
                        fd_set *readfds, fd_set *writefds, fd_set *xfds)
 {
     struct socket *so, *so_next;
-    struct timeval timeout;
     int nfds;
-    int tmp_time;
 
     if (!link_up) {
         return;
@@ -380,39 +381,6 @@ void slirp_select_fill(int *pnfds,
                        }
                }
 
-       /*
-        * Setup timeout to use minimum CPU usage, especially when idle
-        */
-
-       /*
-        * First, see the timeout needed by *timo
-        */
-       timeout.tv_sec = 0;
-       timeout.tv_usec = -1;
-       /*
-        * If a slowtimo is needed, set timeout to 500ms from the last
-        * slow timeout. If a fast timeout is needed, set timeout within
-        * 200ms of when it was requested.
-        */
-       if (do_slowtimo) {
-               /* XXX + 10000 because some select()'s aren't that accurate */
-               timeout.tv_usec = ((500 - (curtime - last_slowtimo)) * 1000) + 10000;
-               if (timeout.tv_usec < 0)
-                  timeout.tv_usec = 0;
-               else if (timeout.tv_usec > 510000)
-                  timeout.tv_usec = 510000;
-
-               /* Can only fasttimo if we also slowtimo */
-               if (time_fasttimo) {
-                       tmp_time = (200 - (curtime - time_fasttimo)) * 1000;
-                       if (tmp_time < 0)
-                          tmp_time = 0;
-
-                       /* Choose the smallest of the 2 */
-                       if (tmp_time < timeout.tv_usec)
-                          timeout.tv_usec = (u_int)tmp_time;
-               }
-       }
         *pnfds = nfds;
 }