diff options
author | Jan Kiszka <jan.kiszka@siemens.com> | 2009-06-24 14:42:29 +0200 |
---|---|---|
committer | Anthony Liguori <aliguori@us.ibm.com> | 2009-06-29 08:52:45 -0500 |
commit | 6dd5ffb661a4aec28c8296b1673abdf280038cf6 (patch) | |
tree | 372c11006fda26038578d0686c387d34b15d93d1 /slirp | |
parent | f932b6ce717e65687c3095e3e41a6c18972f996c (diff) |
slirp: Explicitely mark host-forwarding sockets
Mark sockets that describe host forwardings. This is required for their
(and only their) proper deletion and for pretty-printing.
Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
Diffstat (limited to 'slirp')
-rw-r--r-- | slirp/slirp.c | 4 | ||||
-rw-r--r-- | slirp/socket.h | 1 | ||||
-rw-r--r-- | slirp/udp.c | 2 |
3 files changed, 4 insertions, 3 deletions
diff --git a/slirp/slirp.c b/slirp/slirp.c index 08c10f2b36..ad35c1fb24 100644 --- a/slirp/slirp.c +++ b/slirp/slirp.c @@ -793,11 +793,11 @@ int slirp_add_hostfwd(int is_udp, struct in_addr host_addr, int host_port, } if (is_udp) { if (!udp_listen(host_addr.s_addr, htons(host_port), guest_addr.s_addr, - htons(guest_port), 0)) + htons(guest_port), SS_HOSTFWD)) return -1; } else { if (!tcp_listen(host_addr.s_addr, htons(host_port), guest_addr.s_addr, - htons(guest_port), 0)) + htons(guest_port), SS_HOSTFWD)) return -1; } return 0; diff --git a/slirp/socket.h b/slirp/socket.h index 2cf476cb91..979b1915c1 100644 --- a/slirp/socket.h +++ b/slirp/socket.h @@ -72,6 +72,7 @@ struct socket { #define SS_FACCEPTONCE 0x200 /* If set, the SS_FACCEPTCONN socket will die after one accept */ #define SS_PERSISTENT_MASK 0xf000 /* Unremovable state bits */ +#define SS_HOSTFWD 0x1000 /* Socket describes host->guest forwarding */ extern struct socket tcb; diff --git a/slirp/udp.c b/slirp/udp.c index 3722845cde..60fe754614 100644 --- a/slirp/udp.c +++ b/slirp/udp.c @@ -667,7 +667,7 @@ udp_listen(u_int32_t haddr, u_int hport, u_int32_t laddr, u_int lport, so->so_expire = 0; so->so_state &= SS_PERSISTENT_MASK; - so->so_state |= SS_ISFCONNECTED; + so->so_state |= SS_ISFCONNECTED | flags; return so; } |