summaryrefslogtreecommitdiffstats
path: root/libnetutils
diff options
context:
space:
mode:
authorSreeram Ramachandran <sreeram@google.com>2014-09-08 16:05:09 -0700
committerSreeram Ramachandran <sreeram@google.com>2014-09-08 23:35:52 -0700
commit17622d09d5ba54ae3c8b11644c6d7556bdc6644c (patch)
treec3fac859878ec4a57e1e7018f8837b09feba10ee /libnetutils
parent97b536f1fbfd1fa711833b7dc92aed902dea4bdf (diff)
downloadsystem_core-17622d09d5ba54ae3c8b11644c6d7556bdc6644c.zip
system_core-17622d09d5ba54ae3c8b11644c6d7556bdc6644c.tar.gz
system_core-17622d09d5ba54ae3c8b11644c6d7556bdc6644c.tar.bz2
Support resetting connections tied to any nonexistent address.
Bug: 15414453 Change-Id: Ibf1f052e12b88838a328148e25817a96f10d50f5
Diffstat (limited to 'libnetutils')
-rw-r--r--libnetutils/ifc_utils.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/libnetutils/ifc_utils.c b/libnetutils/ifc_utils.c
index 3f6c6b5..913f51e 100644
--- a/libnetutils/ifc_utils.c
+++ b/libnetutils/ifc_utils.c
@@ -599,14 +599,16 @@ int ifc_reset_connections(const char *ifname, const int reset_mask)
{
#ifdef HAVE_ANDROID_OS
int result, success;
- in_addr_t myaddr;
+ in_addr_t myaddr = 0;
struct ifreq ifr;
struct in6_ifreq ifr6;
if (reset_mask & RESET_IPV4_ADDRESSES) {
/* IPv4. Clear connections on the IP address. */
ifc_init();
- ifc_get_info(ifname, &myaddr, NULL, NULL);
+ if (!(reset_mask & RESET_IGNORE_INTERFACE_ADDRESS)) {
+ ifc_get_info(ifname, &myaddr, NULL, NULL);
+ }
ifc_init_ifr(ifname, &ifr);
init_sockaddr_in(&ifr.ifr_addr, myaddr);
result = ioctl(ifc_ctl_sock, SIOCKILLADDR, &ifr);