Cleanup read/write socket handling somewhat.
This commit is contained in:
parent
90078ad4b6
commit
4abdc3edbd
100
src/netevent.c
100
src/netevent.c
@ -131,32 +131,11 @@ int net_user_recv_ssl(void* ptr, void* buf, size_t len)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void net_on_read(int fd, short ev, void *arg)
|
int handle_net_read(struct user* user)
|
||||||
{
|
{
|
||||||
static char buf[MAX_RECV_BUF];
|
static char buf[MAX_RECV_BUF];
|
||||||
struct user* user = (struct user*) arg;
|
|
||||||
struct hub_recvq* q = user->net.recv_queue;
|
struct hub_recvq* q = user->net.recv_queue;
|
||||||
size_t buf_size;
|
size_t buf_size;
|
||||||
int more = 1;
|
|
||||||
int flag_close = 0;
|
|
||||||
|
|
||||||
#ifdef DEBUG_SENDQ
|
|
||||||
hub_log(log_trace, "net_on_read() : fd=%d, ev=%d, arg=%p", fd, (int) ev, arg);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (ev == EV_TIMEOUT)
|
|
||||||
{
|
|
||||||
more = 0;
|
|
||||||
if (user_is_connecting(user))
|
|
||||||
{
|
|
||||||
flag_close = quit_timeout;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// FIXME: hub is not neccesarily set!
|
|
||||||
// hub_send_ping(hub, user);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
buf_size = hub_recvq_get(q, buf, MAX_RECV_BUF);
|
buf_size = hub_recvq_get(q, buf, MAX_RECV_BUF);
|
||||||
|
|
||||||
@ -168,12 +147,12 @@ void net_on_read(int fd, short ev, void *arg)
|
|||||||
|
|
||||||
if (size == -1)
|
if (size == -1)
|
||||||
{
|
{
|
||||||
if (net_error() != EWOULDBLOCK)
|
if (net_error() != EWOULDBLOCK || net_error() != EINTR)
|
||||||
flag_close = quit_socket_error;
|
return quit_socket_error;
|
||||||
}
|
}
|
||||||
else if (size == 0)
|
else if (size == 0)
|
||||||
{
|
{
|
||||||
flag_close = quit_disconnected;
|
return quit_disconnected;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -193,7 +172,7 @@ void net_on_read(int fd, short ev, void *arg)
|
|||||||
|
|
||||||
if (hub_handle_message(g_hub, user, line, length) == -1)
|
if (hub_handle_message(g_hub, user, line, length) == -1)
|
||||||
{
|
{
|
||||||
flag_close = quit_protocol_error;
|
return quit_protocol_error;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -211,6 +190,54 @@ void net_on_read(int fd, short ev, void *arg)
|
|||||||
hub_recvq_set(q, 0, 0);
|
hub_recvq_set(q, 0, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int handle_net_write(struct user* user)
|
||||||
|
{
|
||||||
|
for (;;)
|
||||||
|
{
|
||||||
|
int ret = hub_sendq_send(user->net.send_queue, net_user_send, user);
|
||||||
|
if (ret <= 0)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hub_sendq_get_bytes(user->net.send_queue))
|
||||||
|
{
|
||||||
|
user_net_io_want_write(user);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void net_event(int fd, short ev, void *arg)
|
||||||
|
{
|
||||||
|
struct user* user = (struct user*) arg;
|
||||||
|
int flag_close = 0;
|
||||||
|
|
||||||
|
#ifdef DEBUG_SENDQ
|
||||||
|
hub_log(log_trace, "net_on_read() : fd=%d, ev=%d, arg=%p", fd, (int) ev, arg);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (ev == EV_TIMEOUT)
|
||||||
|
{
|
||||||
|
if (user_is_connecting(user))
|
||||||
|
{
|
||||||
|
flag_close = quit_timeout;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// FIXME: hub is not neccesarily set!
|
||||||
|
// hub_send_ping(hub, user);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (ev == EV_READ)
|
||||||
|
{
|
||||||
|
flag_close = handle_net_read(user);
|
||||||
|
}
|
||||||
|
else if (ev == EV_WRITE)
|
||||||
|
{
|
||||||
|
flag_close = handle_net_write(user);
|
||||||
|
}
|
||||||
|
|
||||||
if (flag_close)
|
if (flag_close)
|
||||||
{
|
{
|
||||||
@ -237,23 +264,6 @@ void net_on_read(int fd, short ev, void *arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void net_on_write(int fd, short ev, void *arg)
|
|
||||||
{
|
|
||||||
struct user* user = (struct user*) arg;
|
|
||||||
|
|
||||||
for (;;)
|
|
||||||
{
|
|
||||||
int ret = hub_sendq_send(user->net.send_queue, net_user_send, user);
|
|
||||||
if (ret <= 0)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hub_sendq_get_bytes(user->net.send_queue))
|
|
||||||
{
|
|
||||||
user_net_io_want_write(user);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void prepare_user_net(struct hub_info* hub, struct user* user)
|
static void prepare_user_net(struct hub_info* hub, struct user* user)
|
||||||
{
|
{
|
||||||
int fd = user->net.sd;
|
int fd = user->net.sd;
|
||||||
@ -279,8 +289,8 @@ static void prepare_user_net(struct hub_info* hub, struct user* user)
|
|||||||
net_set_nonblocking(fd, 1);
|
net_set_nonblocking(fd, 1);
|
||||||
net_set_nosigpipe(fd, 1);
|
net_set_nosigpipe(fd, 1);
|
||||||
|
|
||||||
event_set(user->net.ev_read, fd, EV_READ | EV_PERSIST, net_on_read, user);
|
event_set(user->net.ev_read, fd, EV_READ | EV_PERSIST, net_event, user);
|
||||||
event_set(user->net.ev_write, fd, EV_WRITE, net_on_write, user);
|
event_set(user->net.ev_write, fd, EV_WRITE, net_event, user);
|
||||||
event_base_set(hub->evbase, user->net.ev_read);
|
event_base_set(hub->evbase, user->net.ev_read);
|
||||||
event_base_set(hub->evbase, user->net.ev_write);
|
event_base_set(hub->evbase, user->net.ev_write);
|
||||||
event_add(user->net.ev_read, &timeout);
|
event_add(user->net.ev_read, &timeout);
|
||||||
|
@ -20,27 +20,13 @@
|
|||||||
#ifndef HAVE_UHUB_NET_EVENT_H
|
#ifndef HAVE_UHUB_NET_EVENT_H
|
||||||
#define HAVE_UHUB_NET_EVENT_H
|
#define HAVE_UHUB_NET_EVENT_H
|
||||||
|
|
||||||
/**
|
|
||||||
* Network callback for reading data from a socket.
|
|
||||||
*/
|
|
||||||
extern void net_on_read(int fd, short ev, void *arg);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Network callback for writing data to a socket.
|
|
||||||
*/
|
|
||||||
extern void net_on_write(int fd, short ev, void *arg);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Network callback for timers.
|
|
||||||
*/
|
|
||||||
extern void net_on_read_timeout(int fd, short ev, void* arg);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Network callback to accept incoming connections.
|
* Network callback to accept incoming connections.
|
||||||
*/
|
*/
|
||||||
extern void net_on_accept(int fd, short ev, void *arg);
|
extern void net_on_accept(int fd, short ev, void *arg);
|
||||||
|
|
||||||
|
extern int handle_net_read(struct user* user);
|
||||||
|
extern int handle_net_write(struct user* user);
|
||||||
|
|
||||||
|
|
||||||
#endif /* HAVE_UHUB_NET_EVENT_H */
|
#endif /* HAVE_UHUB_NET_EVENT_H */
|
||||||
|
@ -107,9 +107,8 @@ int route_to_user(struct hub_info* hub, struct user* user, struct adc_message* m
|
|||||||
|
|
||||||
if (empty)
|
if (empty)
|
||||||
{
|
{
|
||||||
/* Perform oportunistic write - it might work */
|
/* Perform oportunistic write */
|
||||||
/* FIXME: This is a *BAD* hack! */
|
handle_net_write(user);
|
||||||
net_on_write(user->net.sd, EV_WRITE, user);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hub_sendq_get_bytes(user->net.send_queue))
|
if (hub_sendq_get_bytes(user->net.send_queue))
|
||||||
|
Loading…
Reference in New Issue
Block a user