diff options
| -rw-r--r-- | services/java/com/android/server/ConnectivityService.java | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/services/java/com/android/server/ConnectivityService.java b/services/java/com/android/server/ConnectivityService.java index 14a6b96ab0b0..fcb4c23af276 100644 --- a/services/java/com/android/server/ConnectivityService.java +++ b/services/java/com/android/server/ConnectivityService.java @@ -1415,10 +1415,13 @@ public class ConnectivityService extends IConnectivityManager.Stub { if (TextUtils.isEmpty(interfaceName)) return; for (InetAddress gateway : p.getGateways()) { - if (!NetworkUtils.addDefaultRoute(interfaceName, gateway) && DBG) { - NetworkInfo networkInfo = nt.getNetworkInfo(); - log("addDefaultRoute for " + networkInfo.getTypeName() + - " (" + interfaceName + "), GatewayAddr=" + gateway.getHostAddress()); + if (NetworkUtils.addHostRoute(interfaceName, gateway, null) && + NetworkUtils.addDefaultRoute(interfaceName, gateway)) { + if (DBG) { + NetworkInfo networkInfo = nt.getNetworkInfo(); + log("addDefaultRoute for " + networkInfo.getTypeName() + + " (" + interfaceName + "), GatewayAddr=" + gateway.getHostAddress()); + } } } } @@ -1430,10 +1433,12 @@ public class ConnectivityService extends IConnectivityManager.Stub { String interfaceName = p.getInterfaceName(); if (interfaceName != null) { - if ((NetworkUtils.removeDefaultRoute(interfaceName) >= 0) && DBG) { - NetworkInfo networkInfo = nt.getNetworkInfo(); - log("removeDefaultRoute for " + networkInfo.getTypeName() + " (" + - interfaceName + ")"); + if (NetworkUtils.removeDefaultRoute(interfaceName) >= 0) { + if (DBG) { + NetworkInfo networkInfo = nt.getNetworkInfo(); + log("removeDefaultRoute for " + networkInfo.getTypeName() + " (" + + interfaceName + ")"); + } } } } |