aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJan Kiszka <jan.kiszka@siemens.com>2012-02-29 19:14:23 +0100
committerJan Kiszka <jan.kiszka@siemens.com>2012-03-13 14:05:49 +0100
commit1b4a91fe675c59d22e95b67b91603801e8bbe71f (patch)
treea64a380e0749009734d4bac8a6e1b14590d0324d
parent0bca327c21750001cd21562743dc4d92eb00feb6 (diff)
downloadslirp-1b4a91fe675c59d22e95b67b91603801e8bbe71f.zip
slirp-1b4a91fe675c59d22e95b67b91603801e8bbe71f.tar.gz
slirp-1b4a91fe675c59d22e95b67b91603801e8bbe71f.tar.bz2
slirp: Cleanup resources on instance removal
Close & free sockets when shutting down a slirp instance, also release all buffers. CC: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
-rw-r--r--ip_icmp.c7
-rw-r--r--ip_icmp.h1
-rw-r--r--ip_input.c7
-rw-r--r--mbuf.c21
-rw-r--r--mbuf.h1
-rw-r--r--slirp.c3
-rw-r--r--slirp.h2
-rw-r--r--tcp_subr.c7
-rw-r--r--udp.c8
-rw-r--r--udp.h1
10 files changed, 58 insertions, 0 deletions
diff --git a/ip_icmp.c b/ip_icmp.c
index 98e6ef0..7a75fe7 100644
--- a/ip_icmp.c
+++ b/ip_icmp.c
@@ -68,6 +68,13 @@ void icmp_init(Slirp *slirp)
slirp->icmp_last_so = &slirp->icmp;
}
+void icmp_cleanup(Slirp *slirp)
+{
+ while (slirp->icmp.so_next != &slirp->icmp) {
+ icmp_detach(slirp->icmp.so_next);
+ }
+}
+
static int icmp_send(struct socket *so, struct mbuf *m, int hlen)
{
struct ip *ip = mtod(m, struct ip *);
diff --git a/ip_icmp.h b/ip_icmp.h
index 7c006ff..4ce0a4e 100644
--- a/ip_icmp.h
+++ b/ip_icmp.h
@@ -154,6 +154,7 @@ struct icmp {
(type) == ICMP_MASKREQ || (type) == ICMP_MASKREPLY)
void icmp_init(Slirp *slirp);
+void icmp_cleanup(Slirp *slirp);
void icmp_input(struct mbuf *, int);
void icmp_error(struct mbuf *msrc, u_char type, u_char code, int minsize,
const char *message);
diff --git a/ip_input.c b/ip_input.c
index 5c273f7..07884ca 100644
--- a/ip_input.c
+++ b/ip_input.c
@@ -59,6 +59,13 @@ void ip_init(Slirp *slirp)
icmp_init(slirp);
}
+void ip_cleanup(Slirp *slirp)
+{
+ udp_cleanup(slirp);
+ tcp_cleanup(slirp);
+ icmp_cleanup(slirp);
+}
+
/*
* Ip input routine. Checksum and byte swap header. If fragmented
* try to reassemble. Process options. Pass to next level.
diff --git a/mbuf.c b/mbuf.c
index bdac040..bbd5f0d 100644
--- a/mbuf.c
+++ b/mbuf.c
@@ -31,6 +31,27 @@ void m_init(Slirp *slirp)
slirp->m_usedlist.m_next = slirp->m_usedlist.m_prev = &slirp->m_usedlist;
}
+void m_cleanup(Slirp *slirp)
+{
+ struct mbuf *m, *next;
+
+ m = slirp->m_usedlist.m_next;
+ while (m != &slirp->m_usedlist) {
+ next = m->m_next;
+ if (m->m_flags & M_EXT) {
+ free(m->m_ext);
+ }
+ free(m);
+ m = next;
+ }
+ m = slirp->m_freelist.m_next;
+ while (m != &slirp->m_freelist) {
+ next = m->m_next;
+ free(m);
+ m = next;
+ }
+}
+
/*
* Get an mbuf from the free list, if there are none
* malloc one
diff --git a/mbuf.h b/mbuf.h
index 1a43838..f02e189 100644
--- a/mbuf.h
+++ b/mbuf.h
@@ -116,6 +116,7 @@ struct mbuf {
* it rather than putting it on the free list */
void m_init(Slirp *);
+void m_cleanup(Slirp *slirp);
struct mbuf *m_get(Slirp *);
void m_free(struct mbuf *);
void m_cat(register struct mbuf *, register struct mbuf *);
diff --git a/slirp.c b/slirp.c
index 1bfea50..aec7250 100644
--- a/slirp.c
+++ b/slirp.c
@@ -245,6 +245,9 @@ void slirp_cleanup(Slirp *slirp)
unregister_savevm(NULL, "slirp", slirp);
+ ip_cleanup(slirp);
+ m_cleanup(slirp);
+
g_free(slirp->tftp_prefix);
g_free(slirp->bootp_filename);
g_free(slirp);
diff --git a/slirp.h b/slirp.h
index df66351..0d309bf 100644
--- a/slirp.h
+++ b/slirp.h
@@ -315,6 +315,7 @@ void if_output(struct socket *, struct mbuf *);
/* ip_input.c */
void ip_init(Slirp *);
+void ip_cleanup(Slirp *);
void ip_input(struct mbuf *);
void ip_slowtimo(Slirp *);
void ip_stripoptions(register struct mbuf *, struct mbuf *);
@@ -332,6 +333,7 @@ void tcp_setpersist(register struct tcpcb *);
/* tcp_subr.c */
void tcp_init(Slirp *);
+void tcp_cleanup(Slirp *);
void tcp_template(struct tcpcb *);
void tcp_respond(struct tcpcb *, register struct tcpiphdr *,
register struct mbuf *, tcp_seq, tcp_seq, int);
diff --git a/tcp_subr.c b/tcp_subr.c
index 708db51..d57c142 100644
--- a/tcp_subr.c
+++ b/tcp_subr.c
@@ -54,6 +54,13 @@ void tcp_init(Slirp *slirp)
slirp->tcp_last_so = &slirp->tcb;
}
+void tcp_cleanup(Slirp *slirp)
+{
+ while (slirp->tcb.so_next != &slirp->tcb) {
+ tcp_close(sototcpcb(slirp->tcb.so_next));
+ }
+}
+
/*
* Create template to be used to send tcp packets on a connection.
* Call after host entry created, fills
diff --git a/udp.c b/udp.c
index 38f3f55..2bceb08 100644
--- a/udp.c
+++ b/udp.c
@@ -48,6 +48,14 @@ void udp_init(Slirp *slirp)
slirp->udb.so_next = slirp->udb.so_prev = &slirp->udb;
slirp->udp_last_so = &slirp->udb;
}
+
+void udp_cleanup(Slirp *slirp)
+{
+ while (slirp->udb.so_next != &slirp->udb) {
+ udp_detach(slirp->udb.so_next);
+ }
+}
+
/* m->m_data points at ip packet header
* m->m_len length ip packet
* ip->ip_len length data (IPDU)
diff --git a/udp.h b/udp.h
index 3ff4d97..a28050d 100644
--- a/udp.h
+++ b/udp.h
@@ -74,6 +74,7 @@ struct udpiphdr {
struct mbuf;
void udp_init(Slirp *);
+void udp_cleanup(Slirp *);
void udp_input(register struct mbuf *, int);
int udp_output(struct socket *, struct mbuf *, struct sockaddr_in *);
int udp_attach(struct socket *);