Merge "Show/hide 5G preferred network type also consider allowed_network_type"

This commit is contained in:
Bonian Chen
2020-08-10 11:07:41 +00:00
committed by Gerrit Code Review
4 changed files with 161 additions and 157 deletions

View File

@@ -122,6 +122,8 @@ public class EnabledNetworkModePreferenceController extends
super.updateState(preference); super.updateState(preference);
final ListPreference listPreference = (ListPreference) preference; final ListPreference listPreference = (ListPreference) preference;
final int networkMode = getPreferredNetworkMode(); final int networkMode = getPreferredNetworkMode();
Log.d(LOG_TAG, "updateState networkMode: " + networkMode);
updatePreferenceEntries(listPreference); updatePreferenceEntries(listPreference);
updatePreferenceValueAndSummary(listPreference, networkMode); updatePreferenceValueAndSummary(listPreference, networkMode);
} }
@@ -132,9 +134,6 @@ public class EnabledNetworkModePreferenceController extends
if (mTelephonyManager.setPreferredNetworkTypeBitmask( if (mTelephonyManager.setPreferredNetworkTypeBitmask(
MobileNetworkUtils.getRafFromNetworkType(newPreferredNetworkMode))) { MobileNetworkUtils.getRafFromNetworkType(newPreferredNetworkMode))) {
Settings.Global.putInt(mContext.getContentResolver(),
Settings.Global.PREFERRED_NETWORK_MODE + mSubId,
newPreferredNetworkMode);
updatePreferenceValueAndSummary((ListPreference) preference, newPreferredNetworkMode); updatePreferenceValueAndSummary((ListPreference) preference, newPreferredNetworkMode);
return true; return true;
} }
@@ -156,16 +155,21 @@ public class EnabledNetworkModePreferenceController extends
: false; : false;
final long supportedRadioBitmask = mTelephonyManager.getSupportedRadioAccessFamily(); final long supportedRadioBitmask = mTelephonyManager.getSupportedRadioAccessFamily();
final boolean is5gEnabledByCarrier = (mTelephonyManager.getAllowedNetworkTypes()
& TelephonyManager.NETWORK_TYPE_BITMASK_NR) > 0;
mDisplay5gList = checkSupportedRadioBitmask( mDisplay5gList = checkSupportedRadioBitmask(
supportedRadioBitmask, mTelephonyManager.NETWORK_TYPE_BITMASK_NR); supportedRadioBitmask, mTelephonyManager.NETWORK_TYPE_BITMASK_NR)
&& is5gEnabledByCarrier;
lifecycle.addObserver(this); lifecycle.addObserver(this);
} }
private int getPreferredNetworkMode() { private int getPreferredNetworkMode() {
return Settings.Global.getInt(mContext.getContentResolver(), long preferredNetworkBitMask = MobileNetworkUtils.getRafFromNetworkType(
Settings.Global.getInt(mContext.getContentResolver(),
Settings.Global.PREFERRED_NETWORK_MODE + mSubId, Settings.Global.PREFERRED_NETWORK_MODE + mSubId,
TelephonyManager.DEFAULT_PREFERRED_NETWORK_MODE); TelephonyManager.DEFAULT_PREFERRED_NETWORK_MODE));
return MobileNetworkUtils.getNetworkTypeFromRaf((int)
(preferredNetworkBitMask & mTelephonyManager.getAllowedNetworkTypes()));
} }
private void updatePreferenceEntries(ListPreference preference) { private void updatePreferenceEntries(ListPreference preference) {
@@ -176,10 +180,7 @@ public class EnabledNetworkModePreferenceController extends
mContext.getContentResolver(), mContext.getContentResolver(),
android.provider.Settings.Global.LTE_SERVICE_FORCED + mSubId, android.provider.Settings.Global.LTE_SERVICE_FORCED + mSubId,
0); 0);
final int settingsNetworkMode = android.provider.Settings.Global.getInt( final int settingsNetworkMode = getPreferredNetworkMode();
mContext.getContentResolver(),
android.provider.Settings.Global.PREFERRED_NETWORK_MODE + mSubId,
TelephonyManager.DEFAULT_PREFERRED_NETWORK_MODE);
if (mTelephonyManager.isLteCdmaEvdoGsmWcdmaEnabled()) { if (mTelephonyManager.isLteCdmaEvdoGsmWcdmaEnabled()) {
if (lteForced == 0) { if (lteForced == 0) {
preference.setEntries( preference.setEntries(

View File

@@ -80,6 +80,15 @@ import java.util.List;
import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future; import java.util.concurrent.Future;
import static com.android.settings.network.telephony.TelephonyConstants.RadioAccessFamily.CDMA;
import static com.android.settings.network.telephony.TelephonyConstants.RadioAccessFamily.EVDO;
import static com.android.settings.network.telephony.TelephonyConstants.RadioAccessFamily.GSM;
import static com.android.settings.network.telephony.TelephonyConstants.RadioAccessFamily.LTE;
import static com.android.settings.network.telephony.TelephonyConstants.RadioAccessFamily.NR;
import static com.android.settings.network.telephony.TelephonyConstants.RadioAccessFamily.RAF_TD_SCDMA;
import static com.android.settings.network.telephony.TelephonyConstants.RadioAccessFamily.RAF_UNKNOWN;
import static com.android.settings.network.telephony.TelephonyConstants.RadioAccessFamily.WCDMA;
public class MobileNetworkUtils { public class MobileNetworkUtils {
private static final String TAG = "MobileNetworkUtils"; private static final String TAG = "MobileNetworkUtils";
@@ -767,144 +776,166 @@ public class MobileNetworkUtils {
public static long getRafFromNetworkType(int type) { public static long getRafFromNetworkType(int type) {
switch (type) { switch (type) {
case TelephonyManagerConstants.NETWORK_MODE_WCDMA_PREF: case TelephonyManagerConstants.NETWORK_MODE_WCDMA_PREF:
return TelephonyManagerConstants.GSM return GSM | WCDMA;
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_GSM_ONLY: case TelephonyManagerConstants.NETWORK_MODE_GSM_ONLY:
return TelephonyManagerConstants.GSM; return GSM;
case TelephonyManagerConstants.NETWORK_MODE_WCDMA_ONLY: case TelephonyManagerConstants.NETWORK_MODE_WCDMA_ONLY:
return TelephonyManagerConstants.WCDMA; return WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_GSM_UMTS: case TelephonyManagerConstants.NETWORK_MODE_GSM_UMTS:
return TelephonyManagerConstants.GSM return GSM | WCDMA;
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_CDMA_EVDO: case TelephonyManagerConstants.NETWORK_MODE_CDMA_EVDO:
return TelephonyManagerConstants.CDMA return CDMA | EVDO;
| TelephonyManagerConstants.EVDO;
case TelephonyManagerConstants.NETWORK_MODE_LTE_CDMA_EVDO: case TelephonyManagerConstants.NETWORK_MODE_LTE_CDMA_EVDO:
return TelephonyManagerConstants.LTE return LTE | CDMA | EVDO;
| TelephonyManagerConstants.CDMA
| TelephonyManagerConstants.EVDO;
case TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA: case TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA:
return TelephonyManagerConstants.LTE return LTE | GSM | WCDMA;
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_LTE_CDMA_EVDO_GSM_WCDMA: case TelephonyManagerConstants.NETWORK_MODE_LTE_CDMA_EVDO_GSM_WCDMA:
return TelephonyManagerConstants.LTE return LTE | CDMA | EVDO | GSM | WCDMA;
| TelephonyManagerConstants.CDMA
| TelephonyManagerConstants.EVDO
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_LTE_ONLY: case TelephonyManagerConstants.NETWORK_MODE_LTE_ONLY:
return TelephonyManagerConstants.LTE; return LTE;
case TelephonyManagerConstants.NETWORK_MODE_LTE_WCDMA: case TelephonyManagerConstants.NETWORK_MODE_LTE_WCDMA:
return TelephonyManagerConstants.LTE return LTE | WCDMA;
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_CDMA_NO_EVDO: case TelephonyManagerConstants.NETWORK_MODE_CDMA_NO_EVDO:
return TelephonyManagerConstants.CDMA; return CDMA;
case TelephonyManagerConstants.NETWORK_MODE_EVDO_NO_CDMA: case TelephonyManagerConstants.NETWORK_MODE_EVDO_NO_CDMA:
return TelephonyManagerConstants.EVDO; return EVDO;
case TelephonyManagerConstants.NETWORK_MODE_GLOBAL: case TelephonyManagerConstants.NETWORK_MODE_GLOBAL:
return TelephonyManagerConstants.GSM return GSM | WCDMA | CDMA | EVDO;
| TelephonyManagerConstants.WCDMA
| TelephonyManagerConstants.CDMA
| TelephonyManagerConstants.EVDO;
case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_ONLY: case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_ONLY:
return TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA; return RAF_TD_SCDMA;
case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_WCDMA: case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_WCDMA:
return TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA return RAF_TD_SCDMA | WCDMA;
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA: case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA:
return TelephonyManagerConstants.LTE return LTE | RAF_TD_SCDMA;
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA;
case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_GSM: case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_GSM:
return TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA return RAF_TD_SCDMA | GSM;
| TelephonyManagerConstants.GSM;
case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_GSM: case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_GSM:
return TelephonyManagerConstants.LTE return LTE | RAF_TD_SCDMA | GSM;
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA
| TelephonyManagerConstants.GSM;
case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_GSM_WCDMA: case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_GSM_WCDMA:
return TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA return RAF_TD_SCDMA | GSM | WCDMA;
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_WCDMA: case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_WCDMA:
return TelephonyManagerConstants.LTE return LTE | RAF_TD_SCDMA | WCDMA;
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_GSM_WCDMA: case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_GSM_WCDMA:
return TelephonyManagerConstants.LTE return LTE | RAF_TD_SCDMA | GSM | WCDMA;
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_CDMA_EVDO_GSM_WCDMA: case TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_CDMA_EVDO_GSM_WCDMA:
return TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA return RAF_TD_SCDMA | CDMA | EVDO | GSM | WCDMA;
| TelephonyManagerConstants.CDMA
| TelephonyManagerConstants.EVDO
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_CDMA_EVDO_GSM_WCDMA: case TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_CDMA_EVDO_GSM_WCDMA:
return TelephonyManagerConstants.LTE return LTE | RAF_TD_SCDMA | CDMA | EVDO | GSM | WCDMA;
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA
| TelephonyManagerConstants.CDMA
| TelephonyManagerConstants.EVDO
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
case (TelephonyManagerConstants.NETWORK_MODE_NR_ONLY): case (TelephonyManagerConstants.NETWORK_MODE_NR_ONLY):
return TelephonyManagerConstants.NR; return NR;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE):
return TelephonyManagerConstants.NR return NR | LTE;
| TelephonyManagerConstants.LTE;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_CDMA_EVDO): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_CDMA_EVDO):
return TelephonyManagerConstants.NR return NR | LTE | CDMA | EVDO;
| TelephonyManagerConstants.LTE
| TelephonyManagerConstants.CDMA
| TelephonyManagerConstants.EVDO;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_GSM_WCDMA): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_GSM_WCDMA):
return TelephonyManagerConstants.NR return NR | LTE | GSM | WCDMA;
| TelephonyManagerConstants.LTE
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_CDMA_EVDO_GSM_WCDMA): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_CDMA_EVDO_GSM_WCDMA):
return TelephonyManagerConstants.NR return NR | LTE | CDMA | EVDO | GSM | WCDMA;
| TelephonyManagerConstants.LTE
| TelephonyManagerConstants.CDMA
| TelephonyManagerConstants.EVDO
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_WCDMA): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_WCDMA):
return TelephonyManagerConstants.NR return NR | LTE | WCDMA;
| TelephonyManagerConstants.LTE
| TelephonyManagerConstants.WCDMA;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA):
return TelephonyManagerConstants.NR return NR | LTE | RAF_TD_SCDMA;
| TelephonyManagerConstants.LTE
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_GSM): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_GSM):
return TelephonyManagerConstants.NR return NR | LTE | RAF_TD_SCDMA | GSM;
| TelephonyManagerConstants.LTE
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA
| TelephonyManagerConstants.GSM;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_WCDMA): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_WCDMA):
return TelephonyManagerConstants.NR return NR | LTE | RAF_TD_SCDMA | WCDMA;
| TelephonyManagerConstants.LTE
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA
| TelephonyManagerConstants.WCDMA;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_GSM_WCDMA): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_GSM_WCDMA):
return TelephonyManagerConstants.NR return NR | LTE | RAF_TD_SCDMA | GSM | WCDMA;
| TelephonyManagerConstants.LTE
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_CDMA_EVDO_GSM_WCDMA): case (TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_CDMA_EVDO_GSM_WCDMA):
return TelephonyManagerConstants.NR return NR | LTE | RAF_TD_SCDMA | CDMA | EVDO | GSM | WCDMA;
| TelephonyManagerConstants.LTE
| TelephonyManager.NETWORK_TYPE_BITMASK_TD_SCDMA
| TelephonyManagerConstants.CDMA
| TelephonyManagerConstants.EVDO
| TelephonyManagerConstants.GSM
| TelephonyManagerConstants.WCDMA;
default: default:
return TelephonyManager.NETWORK_TYPE_BITMASK_UNKNOWN; return RAF_UNKNOWN;
} }
} }
/**
* Imported from {@link android.telephony.RadioAccessFamily}
*/
public static int getNetworkTypeFromRaf(int raf) {
raf = getAdjustedRaf(raf);
switch (raf) {
case (GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_WCDMA_PREF;
case GSM:
return TelephonyManagerConstants.NETWORK_MODE_GSM_ONLY;
case WCDMA:
return TelephonyManagerConstants.NETWORK_MODE_WCDMA_ONLY;
case (CDMA | EVDO):
return TelephonyManagerConstants.NETWORK_MODE_CDMA_EVDO;
case (LTE | CDMA | EVDO):
return TelephonyManagerConstants.NETWORK_MODE_LTE_CDMA_EVDO;
case (LTE | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA;
case (LTE | CDMA | EVDO | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_LTE_CDMA_EVDO_GSM_WCDMA;
case LTE:
return TelephonyManagerConstants.NETWORK_MODE_LTE_ONLY;
case (LTE | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_LTE_WCDMA;
case CDMA:
return TelephonyManagerConstants.NETWORK_MODE_CDMA_NO_EVDO;
case EVDO:
return TelephonyManagerConstants.NETWORK_MODE_EVDO_NO_CDMA;
case (GSM | WCDMA | CDMA | EVDO):
return TelephonyManagerConstants.NETWORK_MODE_GLOBAL;
case RAF_TD_SCDMA:
return TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_ONLY;
case (RAF_TD_SCDMA | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_WCDMA;
case (LTE | RAF_TD_SCDMA):
return TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA;
case (RAF_TD_SCDMA | GSM):
return TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_GSM;
case (LTE | RAF_TD_SCDMA | GSM):
return TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_GSM;
case (RAF_TD_SCDMA | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_GSM_WCDMA;
case (LTE | RAF_TD_SCDMA | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_WCDMA;
case (LTE | RAF_TD_SCDMA | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_GSM_WCDMA;
case (RAF_TD_SCDMA | CDMA | EVDO | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_CDMA_EVDO_GSM_WCDMA;
case (LTE | RAF_TD_SCDMA | CDMA | EVDO | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_LTE_TDSCDMA_CDMA_EVDO_GSM_WCDMA;
case (NR):
return TelephonyManagerConstants.NETWORK_MODE_NR_ONLY;
case (NR | LTE):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE;
case (NR | LTE | CDMA | EVDO):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE_CDMA_EVDO;
case (NR | LTE | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE_GSM_WCDMA;
case (NR | LTE | CDMA | EVDO | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE_CDMA_EVDO_GSM_WCDMA;
case (NR | LTE | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE_WCDMA;
case (NR | LTE | RAF_TD_SCDMA):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA;
case (NR | LTE | RAF_TD_SCDMA | GSM):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_GSM;
case (NR | LTE | RAF_TD_SCDMA | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_WCDMA;
case (NR | LTE | RAF_TD_SCDMA | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_GSM_WCDMA;
case (NR | LTE | RAF_TD_SCDMA | CDMA | EVDO | GSM | WCDMA):
return TelephonyManagerConstants.NETWORK_MODE_NR_LTE_TDSCDMA_CDMA_EVDO_GSM_WCDMA;
default:
return TelephonyManagerConstants.NETWORK_MODE_UNKNOWN;
}
}
/**
* Imported from {@link android.telephony.RadioAccessFamily}
*/
private static int getAdjustedRaf(int raf) {
raf = ((GSM & raf) > 0) ? (GSM | raf) : raf;
raf = ((WCDMA & raf) > 0) ? (WCDMA | raf) : raf;
raf = ((CDMA & raf) > 0) ? (CDMA | raf) : raf;
raf = ((EVDO & raf) > 0) ? (EVDO | raf) : raf;
raf = ((LTE & raf) > 0) ? (LTE | raf) : raf;
raf = ((NR & raf) > 0) ? (NR | raf) : raf;
return raf;
}
} }

View File

@@ -205,47 +205,12 @@ public class TelephonyConstants {
* NR 5G, LTE, TD-SCDMA, CDMA, EVDO, GSM and WCDMA * NR 5G, LTE, TD-SCDMA, CDMA, EVDO, GSM and WCDMA
*/ */
public static final int NETWORK_MODE_NR_LTE_TDSCDMA_CDMA_EVDO_GSM_WCDMA = 33; public static final int NETWORK_MODE_NR_LTE_TDSCDMA_CDMA_EVDO_GSM_WCDMA = 33;
// Grouping of RAFs
// imported from {@link android.telephony.RadioAccessFamily}
// 2G
public static final long GSM = TelephonyManager.NETWORK_TYPE_BITMASK_GSM
| TelephonyManager.NETWORK_TYPE_BITMASK_GPRS
| TelephonyManager.NETWORK_TYPE_BITMASK_EDGE;
public static final long CDMA = TelephonyManager.NETWORK_TYPE_BITMASK_CDMA
| TelephonyManager.NETWORK_TYPE_BITMASK_1xRTT;
// 3G
public static final long EVDO = TelephonyManager.NETWORK_TYPE_BITMASK_EVDO_0
| TelephonyManager.NETWORK_TYPE_BITMASK_EVDO_A
| TelephonyManager.NETWORK_TYPE_BITMASK_EVDO_B
| TelephonyManager.NETWORK_TYPE_BITMASK_EHRPD;
public static final long HS = TelephonyManager.NETWORK_TYPE_BITMASK_HSUPA
| TelephonyManager.NETWORK_TYPE_BITMASK_HSDPA
| TelephonyManager.NETWORK_TYPE_BITMASK_HSPA
| TelephonyManager.NETWORK_TYPE_BITMASK_HSPAP;
public static final long WCDMA = HS | TelephonyManager.NETWORK_TYPE_BITMASK_UMTS;
// 4G
public static final long LTE = TelephonyManager.NETWORK_TYPE_BITMASK_LTE
| TelephonyManager.NETWORK_TYPE_BITMASK_LTE_CA;
// 5G
public static final long NR = TelephonyManager.NETWORK_TYPE_BITMASK_NR;
} }
/** /**
* Copied from {@link android.telephony.RadioAccessFamily} * Copied from {@link android.telephony.RadioAccessFamily}
*/ */
public static class RadioAccessFamily { public static class RadioAccessFamily {
/**
* TODO: get rid of RAF definition in RadioAccessFamily and
* use {@link TelephonyManager.NetworkTypeBitMask}
* TODO: public definition {@link TelephonyManager.NetworkTypeBitMask} is long.
* TODO: Convert from int * to long everywhere including HAL definitions.
*/
// 2G // 2G
public static final int RAF_UNKNOWN = (int) TelephonyManager.NETWORK_TYPE_BITMASK_UNKNOWN; public static final int RAF_UNKNOWN = (int) TelephonyManager.NETWORK_TYPE_BITMASK_UNKNOWN;
public static final int RAF_GSM = (int) TelephonyManager.NETWORK_TYPE_BITMASK_GSM; public static final int RAF_GSM = (int) TelephonyManager.NETWORK_TYPE_BITMASK_GSM;
@@ -281,7 +246,9 @@ public class TelephonyConstants {
public static final int WCDMA = HS | RAF_UMTS; public static final int WCDMA = HS | RAF_UMTS;
// 4G // 4G
public static final int LTE = RAF_LTE | RAF_LTE_CA; public static final int LTE = RAF_LTE | RAF_LTE_CA;
// 5G // 5G
public static final int NR = RAF_NR; public static final int NR = RAF_NR;
} }
} }

View File

@@ -153,8 +153,9 @@ public class EnabledNetworkModePreferenceControllerTest {
public void init_initDisplay5gList_returnTrue() { public void init_initDisplay5gList_returnTrue() {
long testBitmask = TelephonyManager.NETWORK_TYPE_BITMASK_NR long testBitmask = TelephonyManager.NETWORK_TYPE_BITMASK_NR
| TelephonyManager.NETWORK_TYPE_BITMASK_LTE; | TelephonyManager.NETWORK_TYPE_BITMASK_LTE;
long allowedNetworkTypes = -1;
doReturn(testBitmask).when(mTelephonyManager).getSupportedRadioAccessFamily(); doReturn(testBitmask).when(mTelephonyManager).getSupportedRadioAccessFamily();
doReturn(allowedNetworkTypes).when(mTelephonyManager).getAllowedNetworkTypes();
mController.init(mLifecycle, SUB_ID); mController.init(mLifecycle, SUB_ID);
assertThat(mController.mDisplay5gList).isTrue(); assertThat(mController.mDisplay5gList).isTrue();
@@ -171,6 +172,8 @@ public class EnabledNetworkModePreferenceControllerTest {
@Test @Test
public void updateState_updateByNetworkMode() { public void updateState_updateByNetworkMode() {
long allowedNetworkTypes = -1;
doReturn(allowedNetworkTypes).when(mTelephonyManager).getAllowedNetworkTypes();
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.putInt(mContext.getContentResolver(),
Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID, Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID,
TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_GSM_WCDMA); TelephonyManagerConstants.NETWORK_MODE_TDSCDMA_GSM_WCDMA);
@@ -184,6 +187,8 @@ public class EnabledNetworkModePreferenceControllerTest {
@Test @Test
public void updateState_updateByNetworkMode_useDefaultValue() { public void updateState_updateByNetworkMode_useDefaultValue() {
long allowedNetworkTypes = -1;
doReturn(allowedNetworkTypes).when(mTelephonyManager).getAllowedNetworkTypes();
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.putInt(mContext.getContentResolver(),
Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID, Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID,
TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA); TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA);
@@ -399,9 +404,8 @@ public class EnabledNetworkModePreferenceControllerTest {
mController.onPreferenceChange(mPreference, mController.onPreferenceChange(mPreference,
String.valueOf(TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA)); String.valueOf(TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA));
assertThat(Settings.Global.getInt(mContext.getContentResolver(), assertThat(mPreference.getValue()).isEqualTo(
Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID, 0)).isEqualTo( String.valueOf(TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA));
TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA);
} }
@Test @Test
@@ -412,14 +416,15 @@ public class EnabledNetworkModePreferenceControllerTest {
mController.onPreferenceChange(mPreference, mController.onPreferenceChange(mPreference,
String.valueOf(TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA)); String.valueOf(TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA));
assertThat(Settings.Global.getInt(mContext.getContentResolver(), assertThat(mPreference.getValue()).isNotEqualTo(
Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID, 0)).isNotEqualTo( String.valueOf(TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA));
TelephonyManagerConstants.NETWORK_MODE_LTE_GSM_WCDMA);
} }
@Test @Test
public void preferredNetworkModeNotification_preferenceUpdates() { public void preferredNetworkModeNotification_preferenceUpdates() {
PreferenceScreen screen = mock(PreferenceScreen.class); PreferenceScreen screen = mock(PreferenceScreen.class);
long allowedNetworkTypes = -1;
doReturn(allowedNetworkTypes).when(mTelephonyManager).getAllowedNetworkTypes();
doReturn(mPreference).when(screen).findPreference(KEY); doReturn(mPreference).when(screen).findPreference(KEY);
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.putInt(mContext.getContentResolver(),
Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID, Settings.Global.PREFERRED_NETWORK_MODE + SUB_ID,