Merge "Support requesting and receiving wakeup events" am: 10a2e83a7e am: 4971745cf4

am: 880974f111

Change-Id: I98aa768cf47938aa0996ddabbbc9feb9dae96f1e
This commit is contained in:
Joel Scherpelz
2017-05-29 03:51:25 +00:00
committed by android-build-merger

View File

@@ -209,6 +209,13 @@ public class ConnectivityService extends IConnectivityManager.Stub
// See Settings.Secure.CONNECTIVITY_RELEASE_PENDING_INTENT_DELAY_MS // See Settings.Secure.CONNECTIVITY_RELEASE_PENDING_INTENT_DELAY_MS
private final int mReleasePendingIntentDelayMs; private final int mReleasePendingIntentDelayMs;
// Driver specific constants used to select packets received via
// WiFi that caused the phone to exit sleep state. Currently there
// is only one kernel implementation so we can get away with
// constants.
private static final int mWakeupPacketMark = 0x80000000;
private static final int mWakeupPacketMask = 0x80000000;
private MockableSystemProperties mSystemProperties; private MockableSystemProperties mSystemProperties;
private Tethering mTethering; private Tethering mTethering;
@@ -4352,7 +4359,7 @@ public class ConnectivityService extends IConnectivityManager.Stub
networkAgent.clatd.fixupLinkProperties(oldLp); networkAgent.clatd.fixupLinkProperties(oldLp);
} }
updateInterfaces(newLp, oldLp, netId); updateInterfaces(newLp, oldLp, netId, networkAgent.networkCapabilities);
updateMtu(newLp, oldLp); updateMtu(newLp, oldLp);
// TODO - figure out what to do for clat // TODO - figure out what to do for clat
// for (LinkProperties lp : newLp.getStackedLinks()) { // for (LinkProperties lp : newLp.getStackedLinks()) {
@@ -4390,7 +4397,26 @@ public class ConnectivityService extends IConnectivityManager.Stub
} }
} }
private void updateInterfaces(LinkProperties newLp, LinkProperties oldLp, int netId) { private void wakeupAddInterface(String iface, NetworkCapabilities caps) throws RemoteException {
// Marks are only available on WiFi interaces. Checking for
// marks on unsupported interfaces is harmless.
if (!caps.hasTransport(NetworkCapabilities.TRANSPORT_WIFI)) {
return;
}
mNetd.getNetdService().wakeupAddInterface(
iface, "iface:" + iface, mWakeupPacketMark, mWakeupPacketMask);
}
private void wakeupDelInterface(String iface, NetworkCapabilities caps) throws RemoteException {
if (!caps.hasTransport(NetworkCapabilities.TRANSPORT_WIFI)) {
return;
}
mNetd.getNetdService().wakeupDelInterface(
iface, "iface:" + iface, mWakeupPacketMark, mWakeupPacketMask);
}
private void updateInterfaces(LinkProperties newLp, LinkProperties oldLp, int netId,
NetworkCapabilities caps) {
CompareResult<String> interfaceDiff = new CompareResult<String>(); CompareResult<String> interfaceDiff = new CompareResult<String>();
if (oldLp != null) { if (oldLp != null) {
interfaceDiff = oldLp.compareAllInterfaceNames(newLp); interfaceDiff = oldLp.compareAllInterfaceNames(newLp);
@@ -4401,6 +4427,7 @@ public class ConnectivityService extends IConnectivityManager.Stub
try { try {
if (DBG) log("Adding iface " + iface + " to network " + netId); if (DBG) log("Adding iface " + iface + " to network " + netId);
mNetd.addInterfaceToNetwork(iface, netId); mNetd.addInterfaceToNetwork(iface, netId);
wakeupAddInterface(iface, caps);
} catch (Exception e) { } catch (Exception e) {
loge("Exception adding interface: " + e); loge("Exception adding interface: " + e);
} }
@@ -4409,6 +4436,7 @@ public class ConnectivityService extends IConnectivityManager.Stub
try { try {
if (DBG) log("Removing iface " + iface + " from network " + netId); if (DBG) log("Removing iface " + iface + " from network " + netId);
mNetd.removeInterfaceFromNetwork(iface, netId); mNetd.removeInterfaceFromNetwork(iface, netId);
wakeupDelInterface(iface, caps);
} catch (Exception e) { } catch (Exception e) {
loge("Exception removing interface: " + e); loge("Exception removing interface: " + e);
} }