@@ -2029,8 +2029,7 @@
}
static void
-multi_io_process_flags(struct context *c, struct event_set *es, const unsigned int flags,
- unsigned int *out_socket, unsigned int *out_tuntap)
+multi_io_process_flags(struct context *c, struct event_set *es, const unsigned int flags)
{
unsigned int socket = 0;
unsigned int tuntap = 0;
@@ -2130,16 +2129,6 @@
}
tun_set(c->c1.tuntap, es, tuntap, (void *)tun_shift, NULL);
-
- if (out_socket)
- {
- *out_socket = socket;
- }
-
- if (out_tuntap)
- {
- *out_tuntap = tuntap;
- }
}
/*
@@ -2150,10 +2139,7 @@
void
get_io_flags_udp(struct context *c, struct multi_io *multi_io, const unsigned int flags)
{
- unsigned int out_socket;
-
- multi_io_process_flags(c, multi_io->es, flags, &out_socket, NULL);
- multi_io->udp_flags = (out_socket << SOCKET_SHIFT);
+ multi_io_process_flags(c, multi_io->es, flags);
}
/*
@@ -2163,8 +2149,6 @@
void
io_wait(struct context *c, const unsigned int flags)
{
- unsigned int out_socket;
- unsigned int out_tuntap;
struct event_set_return esr[4];
/* These shifts all depend on EVENT_READ and EVENT_WRITE */
@@ -2183,7 +2167,7 @@
*/
event_reset(c->c2.event_set);
- multi_io_process_flags(c, c->c2.event_set, flags, &out_socket, &out_tuntap);
+ multi_io_process_flags(c, c->c2.event_set, flags);
#if defined(TARGET_LINUX) || defined(TARGET_FREEBSD)
if (c->c1.tuntap)
@@ -336,18 +336,17 @@
* Process a UDP socket event.
*/
void
-multi_process_io_udp(struct multi_context *m, struct link_socket *sock)
+multi_process_io_udp(struct multi_context *m, struct link_socket *sock, unsigned int rwflags)
{
- const unsigned int status = m->multi_io->udp_flags;
const unsigned int mpp_flags = (MPP_PRE_SELECT | MPP_CLOSE_ON_SIGNAL);
/* UDP port ready to accept write */
- if (status & SOCKET_WRITE)
+ if (rwflags & SOCKET_WRITE)
{
multi_process_outgoing_link(m, mpp_flags);
}
/* Incoming data on UDP port */
- else if (status & SOCKET_READ)
+ else if (rwflags & SOCKET_READ)
{
read_incoming_link(&m->top, sock);
if (!IS_SIG(&m->top))
@@ -355,8 +354,6 @@
multi_process_incoming_link(m, NULL, mpp_flags, sock);
}
}
-
- m->multi_io->udp_flags = ES_ERROR;
}
/*
@@ -32,7 +32,7 @@
unsigned int p2mp_iow_flags(const struct multi_context *m);
-void multi_process_io_udp(struct multi_context *m, struct link_socket *sock);
+void multi_process_io_udp(struct multi_context *m, struct link_socket *sock, unsigned int rwflags);
/**************************************************************************/
/**
* Get, and if necessary create, the multi_instance associated with a
@@ -457,7 +457,7 @@
}
else
{
- multi_process_io_udp(m, ev_arg->u.sock);
+ multi_process_io_udp(m, ev_arg->u.sock, e->rwflags);
mi = m->pending;
}
/* monitor and/or handle events that are
@@ -55,7 +55,6 @@
int n_esr;
int maxevents;
unsigned int tun_rwflags;
- unsigned int udp_flags;
#ifdef ENABLE_MANAGEMENT
unsigned int management_persist_flags;
#endif