mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2025-01-20 16:01:53 +00:00
Socket closing has its dedicated function
This commit is contained in:
parent
074739e0e9
commit
b3f805ce29
@ -88,6 +88,7 @@ sock *sock_new(pool *); /* Allocate new socket */
|
|||||||
|
|
||||||
int sk_open(sock *, struct birdloop *); /* Open socket */
|
int sk_open(sock *, struct birdloop *); /* Open socket */
|
||||||
void sk_reloop(sock *, struct birdloop *); /* Move socket to another loop. Both loops must be locked. */
|
void sk_reloop(sock *, struct birdloop *); /* Move socket to another loop. Both loops must be locked. */
|
||||||
|
static inline void sk_close(sock *s) { rfree(&s->r); } /* Explicitly close socket */
|
||||||
|
|
||||||
int sk_rx_ready(sock *s);
|
int sk_rx_ready(sock *s);
|
||||||
_Bool sk_tx_pending(sock *s);
|
_Bool sk_tx_pending(sock *s);
|
||||||
|
@ -417,7 +417,7 @@ cli_free(cli *c)
|
|||||||
|
|
||||||
if (defer)
|
if (defer)
|
||||||
{
|
{
|
||||||
rfree(c->sock);
|
sk_close(c->sock);
|
||||||
c->sock = NULL;
|
c->sock = NULL;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1680,7 +1680,7 @@ babel_open_socket(struct babel_iface *ifa)
|
|||||||
|
|
||||||
err:
|
err:
|
||||||
sk_log_error(sk, p->p.name);
|
sk_log_error(sk, p->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -604,10 +604,10 @@ bfd_free_iface(struct bfd_iface *ifa)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (ifa->sk)
|
if (ifa->sk)
|
||||||
rfree(ifa->sk);
|
sk_close(ifa->sk);
|
||||||
|
|
||||||
if (ifa->rx)
|
if (ifa->rx)
|
||||||
rfree(ifa->rx);
|
sk_close(ifa->rx);
|
||||||
|
|
||||||
rem_node(&ifa->n);
|
rem_node(&ifa->n);
|
||||||
mb_free(ifa);
|
mb_free(ifa);
|
||||||
|
@ -439,7 +439,7 @@ bfd_open_rx_sk(struct bfd_proto *p, int multihop, int af)
|
|||||||
|
|
||||||
err:
|
err:
|
||||||
sk_log_error(sk, p->p.name);
|
sk_log_error(sk, p->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -470,7 +470,7 @@ bfd_open_rx_sk_bound(struct bfd_proto *p, ip_addr local, struct iface *ifa)
|
|||||||
|
|
||||||
err:
|
err:
|
||||||
sk_log_error(sk, p->p.name);
|
sk_log_error(sk, p->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -501,6 +501,6 @@ bfd_open_tx_sk(struct bfd_proto *p, ip_addr local, struct iface *ifa)
|
|||||||
|
|
||||||
err:
|
err:
|
||||||
sk_log_error(sk, p->p.name);
|
sk_log_error(sk, p->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -294,7 +294,7 @@ bgp_listen_create(void *_ UNUSED)
|
|||||||
{
|
{
|
||||||
sk_log_error(sk, p->p.name);
|
sk_log_error(sk, p->p.name);
|
||||||
log(L_ERR "%s: Cannot open listening socket", p->p.name);
|
log(L_ERR "%s: Cannot open listening socket", p->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
UNLOCK_DOMAIN(rtable, bgp_listen_domain);
|
UNLOCK_DOMAIN(rtable, bgp_listen_domain);
|
||||||
|
|
||||||
bgp_initiate_disable(p, BEM_NO_SOCKET);
|
bgp_initiate_disable(p, BEM_NO_SOCKET);
|
||||||
@ -335,7 +335,7 @@ bgp_listen_create(void *_ UNUSED)
|
|||||||
WALK_LIST_DELSAFE(bs, nxt, bgp_sockets)
|
WALK_LIST_DELSAFE(bs, nxt, bgp_sockets)
|
||||||
if (EMPTY_LIST(bs->requests))
|
if (EMPTY_LIST(bs->requests))
|
||||||
{
|
{
|
||||||
rfree(bs->sk);
|
sk_close(bs->sk);
|
||||||
rem_node(&bs->n);
|
rem_node(&bs->n);
|
||||||
mb_free(bs);
|
mb_free(bs);
|
||||||
}
|
}
|
||||||
@ -465,7 +465,7 @@ bgp_close_conn(struct bgp_conn *conn)
|
|||||||
rfree(conn->tx_ev);
|
rfree(conn->tx_ev);
|
||||||
conn->tx_ev = NULL;
|
conn->tx_ev = NULL;
|
||||||
|
|
||||||
rfree(conn->sk);
|
sk_close(conn->sk);
|
||||||
conn->sk = NULL;
|
conn->sk = NULL;
|
||||||
|
|
||||||
mb_free(conn->local_caps);
|
mb_free(conn->local_caps);
|
||||||
@ -1336,7 +1336,7 @@ bgp_incoming_connection(sock *sk, uint dummy UNUSED)
|
|||||||
{
|
{
|
||||||
log(L_WARN "BGP: Unexpected connect from unknown address %I%J (port %d)",
|
log(L_WARN "BGP: Unexpected connect from unknown address %I%J (port %d)",
|
||||||
sk->daddr, ipa_is_link_local(sk->daddr) ? sk->iface : NULL, sk->dport);
|
sk->daddr, ipa_is_link_local(sk->daddr) ? sk->iface : NULL, sk->dport);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1370,7 +1370,7 @@ bgp_incoming_connection(sock *sk, uint dummy UNUSED)
|
|||||||
|
|
||||||
if (!acc)
|
if (!acc)
|
||||||
{
|
{
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1410,7 +1410,7 @@ bgp_incoming_connection(sock *sk, uint dummy UNUSED)
|
|||||||
err:
|
err:
|
||||||
sk_log_error(sk, p->p.name);
|
sk_log_error(sk, p->p.name);
|
||||||
log(L_ERR "%s: Incoming connection aborted", p->p.name);
|
log(L_ERR "%s: Incoming connection aborted", p->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
|
|
||||||
leave:
|
leave:
|
||||||
birdloop_leave(p->p.loop);
|
birdloop_leave(p->p.loop);
|
||||||
|
@ -173,7 +173,7 @@ ospf_sk_open(struct ospf_iface *ifa)
|
|||||||
|
|
||||||
err:
|
err:
|
||||||
sk_log_error(sk, p->p.name);
|
sk_log_error(sk, p->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -234,7 +234,7 @@ ospf_open_vlink_sk(struct ospf_proto *p)
|
|||||||
err:
|
err:
|
||||||
sk_log_error(sk, p->p.name);
|
sk_log_error(sk, p->p.name);
|
||||||
log(L_ERR "%s: Cannot open virtual link socket", p->p.name);
|
log(L_ERR "%s: Cannot open virtual link socket", p->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -511,7 +511,7 @@ radv_sk_open(struct radv_iface *ifa)
|
|||||||
|
|
||||||
err:
|
err:
|
||||||
sk_log_error(sk, ifa->ra->p.name);
|
sk_log_error(sk, ifa->ra->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1040,6 +1040,6 @@ rip_open_socket(struct rip_iface *ifa)
|
|||||||
|
|
||||||
err:
|
err:
|
||||||
sk_log_error(sk, p->p.name);
|
sk_log_error(sk, p->p.name);
|
||||||
rfree(sk);
|
sk_close(sk);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -750,7 +750,7 @@ rip_remove_iface(struct rip_proto *p, struct rip_iface *ifa)
|
|||||||
|
|
||||||
rem_node(NODE ifa);
|
rem_node(NODE ifa);
|
||||||
|
|
||||||
rfree(ifa->sk);
|
sk_close(ifa->sk);
|
||||||
rfree(ifa->lock);
|
rfree(ifa->lock);
|
||||||
rfree(ifa->timer);
|
rfree(ifa->timer);
|
||||||
|
|
||||||
|
@ -120,7 +120,7 @@ rpki_tr_close(struct rpki_tr_sock *tr)
|
|||||||
|
|
||||||
if (tr->sk)
|
if (tr->sk)
|
||||||
{
|
{
|
||||||
rfree(tr->sk);
|
sk_close(tr->sk);
|
||||||
tr->sk = NULL;
|
tr->sk = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1118,7 +1118,7 @@ krt_sock_close_shared(void)
|
|||||||
|
|
||||||
if (!krt_sock_count)
|
if (!krt_sock_count)
|
||||||
{
|
{
|
||||||
rfree(krt_sock);
|
sk_close(krt_sock);
|
||||||
krt_sock = NULL;
|
krt_sock = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1181,7 +1181,7 @@ krt_sys_shutdown(struct krt_proto *p)
|
|||||||
{
|
{
|
||||||
krt_table_cf[(KRT_CF->sys.table_id)/32][!!(p->af == AF_INET6)] &= ~(1 << ((KRT_CF->sys.table_id)%32));
|
krt_table_cf[(KRT_CF->sys.table_id)/32][!!(p->af == AF_INET6)] &= ~(1 << ((KRT_CF->sys.table_id)%32));
|
||||||
|
|
||||||
rfree(p->sys.sk);
|
sk_close(p->sys.sk);
|
||||||
p->sys.sk = NULL;
|
p->sys.sk = NULL;
|
||||||
|
|
||||||
krt_buffer_release(&p->p);
|
krt_buffer_release(&p->p);
|
||||||
|
@ -1081,7 +1081,7 @@ sk_passive_connected(sock *s, int type)
|
|||||||
/* FIXME: handle it better in rfree() */
|
/* FIXME: handle it better in rfree() */
|
||||||
close(t->fd);
|
close(t->fd);
|
||||||
t->fd = -1;
|
t->fd = -1;
|
||||||
rfree(t);
|
sk_close(t);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user