diff --git a/slirp/slirp.c b/slirp/slirp.c index 08c10f2b366c1070cc8dda6c77b029a208f13cb2..ad35c1fb24c42b3c2de4f5b1098ba5462500d756 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 2cf476cb91683470780346ddbbe8f88ce6a87593..979b1915c1cd5f339bc04aebd8c7d18b74b561b1 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 3722845cde83e0e0f268d2f58be085b0427c0031..60fe75461460daaab009d87adc0c195d3db18daa 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; }