diff options
author | Lorenzo Colitti <lorenzo@google.com> | 2013-03-11 17:27:11 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2013-03-11 17:27:11 +0000 |
commit | 5aae35d8e4ff9c9bdb92624d6ca5d5eb3df33d0c (patch) | |
tree | 52f7de6d96bebfa120d622b9c83b5dd8bfedc5c4 /services/java/com | |
parent | c4de19e250e0a7ccf2880809e461db715e16ed87 (diff) | |
parent | 13d1c27eda1465eeb09823eb9e82fccf67dfb15e (diff) | |
download | frameworks_base-5aae35d8e4ff9c9bdb92624d6ca5d5eb3df33d0c.zip frameworks_base-5aae35d8e4ff9c9bdb92624d6ca5d5eb3df33d0c.tar.gz frameworks_base-5aae35d8e4ff9c9bdb92624d6ca5d5eb3df33d0c.tar.bz2 |
am 13d1c27e: am de965891: Merge "Always specify an interface for host routes." into jb-mr2-dev
* commit '13d1c27eda1465eeb09823eb9e82fccf67dfb15e':
Always specify an interface for host routes.
Diffstat (limited to 'services/java/com')
-rw-r--r-- | services/java/com/android/server/ConnectivityService.java | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/services/java/com/android/server/ConnectivityService.java b/services/java/com/android/server/ConnectivityService.java index 3257d2c..027f0f3 100644 --- a/services/java/com/android/server/ConnectivityService.java +++ b/services/java/com/android/server/ConnectivityService.java @@ -1430,17 +1430,18 @@ public class ConnectivityService extends IConnectivityManager.Stub { private boolean modifyRouteToAddress(LinkProperties lp, InetAddress addr, boolean doAdd, boolean toDefaultTable) { + String iface = lp.getInterfaceName(); RouteInfo bestRoute = RouteInfo.selectBestRoute(lp.getRoutes(), addr); if (bestRoute == null) { - bestRoute = RouteInfo.makeHostRoute(addr); + bestRoute = RouteInfo.makeHostRoute(addr, iface); } else { if (bestRoute.getGateway().equals(addr)) { // if there is no better route, add the implied hostroute for our gateway - bestRoute = RouteInfo.makeHostRoute(addr); + bestRoute = RouteInfo.makeHostRoute(addr, iface); } else { // if we will connect to this through another route, add a direct route // to it's gateway - bestRoute = RouteInfo.makeHostRoute(addr, bestRoute.getGateway()); + bestRoute = RouteInfo.makeHostRoute(addr, bestRoute.getGateway(), iface); } } return modifyRoute(lp.getInterfaceName(), lp, bestRoute, 0, doAdd, toDefaultTable); @@ -1463,11 +1464,13 @@ public class ConnectivityService extends IConnectivityManager.Stub { if (bestRoute != null) { if (bestRoute.getGateway().equals(r.getGateway())) { // if there is no better route, add the implied hostroute for our gateway - bestRoute = RouteInfo.makeHostRoute(r.getGateway()); + bestRoute = RouteInfo.makeHostRoute(r.getGateway(), ifaceName); } else { // if we will connect to our gateway through another route, add a direct // route to it's gateway - bestRoute = RouteInfo.makeHostRoute(r.getGateway(), bestRoute.getGateway()); + bestRoute = RouteInfo.makeHostRoute(r.getGateway(), + bestRoute.getGateway(), + ifaceName); } modifyRoute(ifaceName, lp, bestRoute, cycleCount+1, doAdd, toDefaultTable); } |