Skip to content

Commit

Permalink
udp: add a lock for the helpers list
Browse files Browse the repository at this point in the history
  • Loading branch information
cspiel1 committed Mar 7, 2023
1 parent a3190a9 commit 86eb2dc
Showing 1 changed file with 55 additions and 8 deletions.
63 changes: 55 additions & 8 deletions src/udp/udp.c
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
#include <re_mem.h>
#include <re_mbuf.h>
#include <re_list.h>
#include <re_thread.h>
#include <re_net.h>
#include <re_main.h>
#include <re_sa.h>
Expand Down Expand Up @@ -74,6 +75,7 @@ struct udp_sock {
QOS_FLOWID qos_id; /**< QOS IPv4 flow id */
QOS_FLOWID qos_id6; /**< QOS IPv6 flow id */
#endif
mtx_t *lock; /**< A lock for helpers */
};

/** Defines a UDP helper */
Expand Down Expand Up @@ -120,8 +122,16 @@ static void udp_destructor(void *data)
{
struct udp_sock *us = data;

if (us->lock)
mtx_lock(us->lock);

list_flush(&us->helpers);

if (us->lock) {
mtx_unlock(us->lock);
mem_deref(us->lock);
}

#ifdef WIN32
if (us->qos && us->qos_id)
(void)QOSRemoveSocketFromFlow(us->qos, 0, us->qos_id, 0);
Expand Down Expand Up @@ -185,6 +195,7 @@ static void udp_read(struct udp_sock *us, re_sock_t fd)
(void)mbuf_resize(mb, mb->end);

/* call helpers */
mtx_lock(us->lock);
le = us->helpers.head;
while (le) {
struct udp_helper *uh = le->data;
Expand All @@ -200,6 +211,7 @@ static void udp_read(struct udp_sock *us, re_sock_t fd)
us->rh(&src, mb, us->arg);

out:
mtx_unlock(us->lock);
mem_deref(mb);
}

Expand Down Expand Up @@ -250,6 +262,10 @@ int udp_listen(struct udp_sock **usp, const struct sa *local,
if (!us)
return ENOMEM;

err = mutex_alloc(&us->lock);
if (err)
goto out;

list_init(&us->helpers);

us->fd = RE_BAD_SOCK;
Expand Down Expand Up @@ -382,6 +398,10 @@ int udp_alloc_sockless(struct udp_sock **usp,
if (!us)
return ENOMEM;

int err = mutex_alloc(&us->lock);
if (err)
goto out;

list_init(&us->helpers);

us->fd = RE_BAD_SOCK;
Expand All @@ -391,9 +411,13 @@ int udp_alloc_sockless(struct udp_sock **usp,
us->arg = arg;
us->rxsz = UDP_RXSZ_DEFAULT;

*usp = us;
out:
if (err)
mem_deref(us);
else
*usp = us;

return 0;
return err;
}


Expand All @@ -407,6 +431,10 @@ int udp_alloc_fd(struct udp_sock **usp, re_sock_t fd,
if (!us)
return ENOMEM;

int err = mutex_alloc(&us->lock);
if (err)
goto out;

list_init(&us->helpers);

us->fd = fd;
Expand All @@ -415,7 +443,11 @@ int udp_alloc_fd(struct udp_sock **usp, re_sock_t fd,
us->arg = arg;
us->rxsz = UDP_RXSZ_DEFAULT;

*usp = us;
out:
if (err)
mem_deref(us);
else
*usp = us;

return 0;
}
Expand All @@ -442,6 +474,10 @@ int udp_open(struct udp_sock **usp, int af)
if (!us)
return ENOMEM;

err = mutex_alloc(&us->lock);
if (err)
goto out;

us->fd = RE_BAD_SOCK;
us->fd6 = RE_BAD_SOCK;

Expand Down Expand Up @@ -879,6 +915,7 @@ int udp_register_helper(struct udp_helper **uhp, struct udp_sock *us,
if (!uh)
return ENOMEM;

mtx_lock(us->lock);
list_append(&us->helpers, &uh->le, uh);

uh->layer = layer;
Expand All @@ -891,6 +928,7 @@ int udp_register_helper(struct udp_helper **uhp, struct udp_sock *us,
if (uhp)
*uhp = uh;

mtx_unlock(us->lock);
return 0;
}

Expand Down Expand Up @@ -957,19 +995,24 @@ void udp_recv_helper(struct udp_sock *us, const struct sa *src,
struct udp_helper *udp_helper_find(const struct udp_sock *us, int layer)
{
struct le *le;
struct udp_helper *uhf = NULL;

if (!us)
return NULL;

mtx_lock(us->lock);
for (le = us->helpers.head; le; le = le->next) {

struct udp_helper *uh = le->data;

if (layer == uh->layer)
return uh;
if (layer == uh->layer) {
uhf = uh;
break;
}
}

return NULL;
mtx_unlock(us->lock);
return uhf;
}


Expand Down Expand Up @@ -1005,11 +1048,13 @@ void udp_recv_packet(struct udp_sock *us, const struct sa *src,
struct mbuf *mb)
{
struct sa hsrc;
struct le *le;

if (!us || !src || !mb)
return;

struct le *le = us->helpers.head;
mtx_lock(us->lock);
le = us->helpers.head;
while (le) {
struct udp_helper *uh = le->data;
bool hdld;
Expand All @@ -1023,8 +1068,10 @@ void udp_recv_packet(struct udp_sock *us, const struct sa *src,

hdld = uh->recvh(&hsrc, mb, uh->arg);
if (hdld)
return;
goto out;
}

us->rh(src, mb, us->arg);
out:
mtx_unlock(us->lock);
}

0 comments on commit 86eb2dc

Please sign in to comment.