Merge "[NS D02] Mix in the ignore on wifi policy."

This commit is contained in:
Chalard Jean
2020-02-18 05:46:33 +00:00
committed by Android (Google) Code Review
2 changed files with 54 additions and 8 deletions

View File

@@ -21,7 +21,6 @@ import android.annotation.NonNull;
import android.annotation.Nullable; import android.annotation.Nullable;
import android.annotation.SystemApi; import android.annotation.SystemApi;
import android.annotation.TestApi; import android.annotation.TestApi;
import android.os.Bundle;
import android.os.Parcel; import android.os.Parcel;
import android.os.Parcelable; import android.os.Parcelable;
@@ -354,17 +353,27 @@ public final class NetworkScore implements Parcelable {
private Metrics mLinkLayerMetrics = new Metrics(Metrics.LATENCY_UNKNOWN, private Metrics mLinkLayerMetrics = new Metrics(Metrics.LATENCY_UNKNOWN,
Metrics.BANDWIDTH_UNKNOWN, Metrics.BANDWIDTH_UNKNOWN); Metrics.BANDWIDTH_UNKNOWN, Metrics.BANDWIDTH_UNKNOWN);
@NonNull @NonNull
private Metrics mEndToMetrics = new Metrics(Metrics.LATENCY_UNKNOWN, private Metrics mEndToEndMetrics = new Metrics(Metrics.LATENCY_UNKNOWN,
Metrics.BANDWIDTH_UNKNOWN, Metrics.BANDWIDTH_UNKNOWN); Metrics.BANDWIDTH_UNKNOWN, Metrics.BANDWIDTH_UNKNOWN);
private int mSignalStrength = UNKNOWN_SIGNAL_STRENGTH; private int mSignalStrength = UNKNOWN_SIGNAL_STRENGTH;
private int mRange = RANGE_UNKNOWN; private int mRange = RANGE_UNKNOWN;
private boolean mExiting = false; private boolean mExiting = false;
private int mLegacyScore = 0; private int mLegacyScore = 0;
@NonNull private Bundle mExtensions = new Bundle();
/** Create a new builder. */ /** Create a new builder. */
public Builder() { } public Builder() { }
/** @hide */
public Builder(@NonNull final NetworkScore source) {
mPolicy = source.mPolicy;
mLinkLayerMetrics = source.mLinkLayerMetrics;
mEndToEndMetrics = source.mEndToEndMetrics;
mSignalStrength = source.mSignalStrength;
mRange = source.mRange;
mExiting = source.mExiting;
mLegacyScore = source.mLegacyScore;
}
/** Add a policy flag. */ /** Add a policy flag. */
@NonNull public Builder addPolicy(@Policy final int policy) { @NonNull public Builder addPolicy(@Policy final int policy) {
mPolicy |= policy; mPolicy |= policy;
@@ -385,7 +394,7 @@ public final class NetworkScore implements Parcelable {
/** Set the end-to-end metrics. */ /** Set the end-to-end metrics. */
@NonNull public Builder setEndToEndMetrics(@NonNull final Metrics endToEndMetrics) { @NonNull public Builder setEndToEndMetrics(@NonNull final Metrics endToEndMetrics) {
mEndToMetrics = endToEndMetrics; mEndToEndMetrics = endToEndMetrics;
return this; return this;
} }
@@ -417,7 +426,7 @@ public final class NetworkScore implements Parcelable {
/** Build the NetworkScore object represented by this builder. */ /** Build the NetworkScore object represented by this builder. */
@NonNull public NetworkScore build() { @NonNull public NetworkScore build() {
return new NetworkScore(mPolicy, mLinkLayerMetrics, mEndToMetrics, return new NetworkScore(mPolicy, mLinkLayerMetrics, mEndToEndMetrics,
mSignalStrength, mRange, mExiting, mLegacyScore); mSignalStrength, mRange, mExiting, mLegacyScore);
} }
} }

View File

@@ -3817,8 +3817,9 @@ public class ConnectivityService extends IConnectivityManager.Stub
return avoidBadWifi(); return avoidBadWifi();
} }
private void rematchForAvoidBadWifiUpdate() { private void rematchForAvoidBadWifiUpdate() {
ensureRunningOnConnectivityServiceThread();
mixInAllNetworkScores();
rematchAllNetworksAndRequests(); rematchAllNetworksAndRequests();
for (NetworkAgentInfo nai: mNetworkAgentInfos.values()) { for (NetworkAgentInfo nai: mNetworkAgentInfos.values()) {
if (nai.networkCapabilities.hasTransport(NetworkCapabilities.TRANSPORT_WIFI)) { if (nai.networkCapabilities.hasTransport(NetworkCapabilities.TRANSPORT_WIFI)) {
@@ -7035,9 +7036,45 @@ public class ConnectivityService extends IConnectivityManager.Stub
} }
} }
/**
* Re-mixin all network scores.
* This is called when some global setting like avoidBadWifi has changed.
* TODO : remove this when all usages have been removed.
*/
private void mixInAllNetworkScores() {
ensureRunningOnConnectivityServiceThread();
for (final NetworkAgentInfo nai : mNetworkAgentInfos.values()) {
nai.setNetworkScore(mixInNetworkScore(nai, nai.getNetworkScore()));
}
}
/**
* Mix in the Connectivity-managed parts of the NetworkScore.
* @param nai The NAI this score applies to.
* @param sourceScore the score sent by the network agent, or the previous score of this NAI.
* @return A new score with the Connectivity-managed parts mixed in.
*/
@NonNull
private NetworkScore mixInNetworkScore(@NonNull final NetworkAgentInfo nai,
@NonNull final NetworkScore sourceScore) {
final NetworkScore.Builder score = new NetworkScore.Builder(sourceScore);
// TODO : this should be done in Telephony. It should be handled per-network because
// it's a carrier-dependent config.
if (nai.networkCapabilities.hasTransport(TRANSPORT_CELLULAR)) {
if (mMultinetworkPolicyTracker.getAvoidBadWifi()) {
score.clearPolicy(NetworkScore.POLICY_IGNORE_ON_WIFI);
} else {
score.addPolicy(NetworkScore.POLICY_IGNORE_ON_WIFI);
}
}
return score.build();
}
private void updateNetworkScore(NetworkAgentInfo nai, NetworkScore ns) { private void updateNetworkScore(NetworkAgentInfo nai, NetworkScore ns) {
if (VDBG || DDBG) log("updateNetworkScore for " + nai.toShortString() + " to " + ns); if (VDBG || DDBG) log("updateNetworkScore for " + nai.toShortString() + " to " + ns);
nai.setNetworkScore(ns); nai.setNetworkScore(mixInNetworkScore(nai, ns));
rematchAllNetworksAndRequests(); rematchAllNetworksAndRequests();
sendUpdatedScoreToFactories(nai); sendUpdatedScoreToFactories(nai);
} }