mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-11 23:43:09 +00:00
Make sure only one bind request occurs at a time
This commit is contained in:
parent
c361a9cb90
commit
33bbd7b52e
24
msp_client.c
24
msp_client.c
@ -599,6 +599,18 @@ int msp_shutdown(MSP_SOCKET handle)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// test if there is already a socket being bound
|
||||||
|
static int pending_bind(int fd)
|
||||||
|
{
|
||||||
|
struct msp_sock *s = root;
|
||||||
|
while(s){
|
||||||
|
if (s->mdp_sock == fd && s->header.flags & MDP_FLAG_BIND)
|
||||||
|
return 1;
|
||||||
|
s=s->_next;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int process_sock(struct msp_sock *sock)
|
static int process_sock(struct msp_sock *sock)
|
||||||
{
|
{
|
||||||
time_ms_t now = gettime_ms();
|
time_ms_t now = gettime_ms();
|
||||||
@ -666,8 +678,8 @@ static int process_sock(struct msp_sock *sock)
|
|||||||
while(p){
|
while(p){
|
||||||
if (p->sent + RETRANSMIT_TIME < now){
|
if (p->sent + RETRANSMIT_TIME < now){
|
||||||
if (!sock->header.local.port){
|
if (!sock->header.local.port){
|
||||||
if (sock->header.flags & MDP_FLAG_BIND)
|
// if there's already a binding being processed, wait for it to complete
|
||||||
// wait until we have heard back from the daemon with our port number before sending another packet.
|
if (pending_bind(sock->mdp_sock))
|
||||||
break;
|
break;
|
||||||
sock->header.flags |= MDP_FLAG_BIND;
|
sock->header.flags |= MDP_FLAG_BIND;
|
||||||
}
|
}
|
||||||
@ -720,7 +732,9 @@ static void msp_release(struct msp_sock *sock){
|
|||||||
// release mdp port binding when there are no other sockets using it.
|
// release mdp port binding when there are no other sockets using it.
|
||||||
struct msp_sock *o = root;
|
struct msp_sock *o = root;
|
||||||
while(o){
|
while(o){
|
||||||
if (o!=sock && o->mdp_sock == sock->mdp_sock && o->header.local.port == sock->header.local.port)
|
if (o!=sock
|
||||||
|
&& o->mdp_sock == sock->mdp_sock
|
||||||
|
&& o->header.local.port == sock->header.local.port)
|
||||||
return;
|
return;
|
||||||
o=o->_next;
|
o=o->_next;
|
||||||
}
|
}
|
||||||
@ -729,10 +743,14 @@ static void msp_release(struct msp_sock *sock){
|
|||||||
bzero(&header, sizeof header);
|
bzero(&header, sizeof header);
|
||||||
|
|
||||||
header.local = sock->header.local;
|
header.local = sock->header.local;
|
||||||
|
header.remote.sid = SID_ANY;
|
||||||
|
header.remote.port = MDP_LISTEN;
|
||||||
header.flags = MDP_FLAG_CLOSE;
|
header.flags = MDP_FLAG_CLOSE;
|
||||||
if (config.debug.msp)
|
if (config.debug.msp)
|
||||||
DEBUGF("Releasing mdp port binding %d", header.local.port);
|
DEBUGF("Releasing mdp port binding %d", header.local.port);
|
||||||
mdp_send(sock->mdp_sock, &header, NULL, 0);
|
mdp_send(sock->mdp_sock, &header, NULL, 0);
|
||||||
|
sock->header.local.port=0;
|
||||||
|
sock->header.local.sid=SID_ANY;
|
||||||
}
|
}
|
||||||
|
|
||||||
int msp_processing(time_ms_t *next_action)
|
int msp_processing(time_ms_t *next_action)
|
||||||
|
Loading…
Reference in New Issue
Block a user