1 /* 2 * Copyright (C) 2019 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package android.net.wifi; 18 19 import android.annotation.IntDef; 20 import android.annotation.SystemApi; 21 import android.os.Parcel; 22 import android.os.Parcelable; 23 import android.telephony.TelephonyManager.NetworkType; 24 25 import java.lang.annotation.Retention; 26 import java.lang.annotation.RetentionPolicy; 27 28 /** 29 * This class makes a subset of 30 * com.android.server.wifi.nano.WifiMetricsProto.WifiUsabilityStatsEntry parcelable. 31 * 32 * @hide 33 */ 34 @SystemApi 35 public final class WifiUsabilityStatsEntry implements Parcelable { 36 /** {@hide} */ 37 @Retention(RetentionPolicy.SOURCE) 38 @IntDef(prefix = {"PROBE_STATUS_"}, value = { 39 PROBE_STATUS_UNKNOWN, 40 PROBE_STATUS_NO_PROBE, 41 PROBE_STATUS_SUCCESS, 42 PROBE_STATUS_FAILURE}) 43 public @interface ProbeStatus {} 44 45 /** Link probe status is unknown */ 46 public static final int PROBE_STATUS_UNKNOWN = 0; 47 /** Link probe is not triggered */ 48 public static final int PROBE_STATUS_NO_PROBE = 1; 49 /** Link probe is triggered and the result is success */ 50 public static final int PROBE_STATUS_SUCCESS = 2; 51 /** Link probe is triggered and the result is failure */ 52 public static final int PROBE_STATUS_FAILURE = 3; 53 54 /** Absolute milliseconds from device boot when these stats were sampled */ 55 private final long mTimeStampMillis; 56 /** The RSSI (in dBm) at the sample time */ 57 private final int mRssi; 58 /** Link speed at the sample time in Mbps */ 59 private final int mLinkSpeedMbps; 60 /** The total number of tx success counted from the last radio chip reset */ 61 private final long mTotalTxSuccess; 62 /** The total number of MPDU data packet retries counted from the last radio chip reset */ 63 private final long mTotalTxRetries; 64 /** The total number of tx bad counted from the last radio chip reset */ 65 private final long mTotalTxBad; 66 /** The total number of rx success counted from the last radio chip reset */ 67 private final long mTotalRxSuccess; 68 /** The total time the wifi radio is on in ms counted from the last radio chip reset */ 69 private final long mTotalRadioOnTimeMillis; 70 /** The total time the wifi radio is doing tx in ms counted from the last radio chip reset */ 71 private final long mTotalRadioTxTimeMillis; 72 /** The total time the wifi radio is doing rx in ms counted from the last radio chip reset */ 73 private final long mTotalRadioRxTimeMillis; 74 /** The total time spent on all types of scans in ms counted from the last radio chip reset */ 75 private final long mTotalScanTimeMillis; 76 /** The total time spent on nan scans in ms counted from the last radio chip reset */ 77 private final long mTotalNanScanTimeMillis; 78 /** The total time spent on background scans in ms counted from the last radio chip reset */ 79 private final long mTotalBackgroundScanTimeMillis; 80 /** The total time spent on roam scans in ms counted from the last radio chip reset */ 81 private final long mTotalRoamScanTimeMillis; 82 /** The total time spent on pno scans in ms counted from the last radio chip reset */ 83 private final long mTotalPnoScanTimeMillis; 84 /** The total time spent on hotspot2.0 scans and GAS exchange in ms counted from the last radio 85 * chip reset */ 86 private final long mTotalHotspot2ScanTimeMillis; 87 /** The total time CCA is on busy status on the current frequency in ms counted from the last 88 * radio chip reset */ 89 private final long mTotalCcaBusyFreqTimeMillis; 90 /** The total radio on time on the current frequency from the last radio chip reset */ 91 private final long mTotalRadioOnFreqTimeMillis; 92 /** The total number of beacons received from the last radio chip reset */ 93 private final long mTotalBeaconRx; 94 /** The status of link probe since last stats update */ 95 @ProbeStatus private final int mProbeStatusSinceLastUpdate; 96 /** The elapsed time of the most recent link probe since last stats update */ 97 private final int mProbeElapsedTimeSinceLastUpdateMillis; 98 /** The MCS rate of the most recent link probe since last stats update */ 99 private final int mProbeMcsRateSinceLastUpdate; 100 /** Rx link speed at the sample time in Mbps */ 101 private final int mRxLinkSpeedMbps; 102 private final @NetworkType int mCellularDataNetworkType; 103 private final int mCellularSignalStrengthDbm; 104 private final int mCellularSignalStrengthDb; 105 private final boolean mIsSameRegisteredCell; 106 107 /** Constructor function {@hide} */ WifiUsabilityStatsEntry(long timeStampMillis, int rssi, int linkSpeedMbps, long totalTxSuccess, long totalTxRetries, long totalTxBad, long totalRxSuccess, long totalRadioOnTimeMillis, long totalRadioTxTimeMillis, long totalRadioRxTimeMillis, long totalScanTimeMillis, long totalNanScanTimeMillis, long totalBackgroundScanTimeMillis, long totalRoamScanTimeMillis, long totalPnoScanTimeMillis, long totalHotspot2ScanTimeMillis, long totalCcaBusyFreqTimeMillis, long totalRadioOnFreqTimeMillis, long totalBeaconRx, @ProbeStatus int probeStatusSinceLastUpdate, int probeElapsedTimeSinceLastUpdateMillis, int probeMcsRateSinceLastUpdate, int rxLinkSpeedMbps, @NetworkType int cellularDataNetworkType, int cellularSignalStrengthDbm, int cellularSignalStrengthDb, boolean isSameRegisteredCell)108 public WifiUsabilityStatsEntry(long timeStampMillis, int rssi, int linkSpeedMbps, 109 long totalTxSuccess, long totalTxRetries, long totalTxBad, long totalRxSuccess, 110 long totalRadioOnTimeMillis, long totalRadioTxTimeMillis, long totalRadioRxTimeMillis, 111 long totalScanTimeMillis, long totalNanScanTimeMillis, 112 long totalBackgroundScanTimeMillis, 113 long totalRoamScanTimeMillis, long totalPnoScanTimeMillis, 114 long totalHotspot2ScanTimeMillis, 115 long totalCcaBusyFreqTimeMillis, long totalRadioOnFreqTimeMillis, long totalBeaconRx, 116 @ProbeStatus int probeStatusSinceLastUpdate, int probeElapsedTimeSinceLastUpdateMillis, 117 int probeMcsRateSinceLastUpdate, int rxLinkSpeedMbps, 118 @NetworkType int cellularDataNetworkType, 119 int cellularSignalStrengthDbm, int cellularSignalStrengthDb, 120 boolean isSameRegisteredCell) { 121 mTimeStampMillis = timeStampMillis; 122 mRssi = rssi; 123 mLinkSpeedMbps = linkSpeedMbps; 124 mTotalTxSuccess = totalTxSuccess; 125 mTotalTxRetries = totalTxRetries; 126 mTotalTxBad = totalTxBad; 127 mTotalRxSuccess = totalRxSuccess; 128 mTotalRadioOnTimeMillis = totalRadioOnTimeMillis; 129 mTotalRadioTxTimeMillis = totalRadioTxTimeMillis; 130 mTotalRadioRxTimeMillis = totalRadioRxTimeMillis; 131 mTotalScanTimeMillis = totalScanTimeMillis; 132 mTotalNanScanTimeMillis = totalNanScanTimeMillis; 133 mTotalBackgroundScanTimeMillis = totalBackgroundScanTimeMillis; 134 mTotalRoamScanTimeMillis = totalRoamScanTimeMillis; 135 mTotalPnoScanTimeMillis = totalPnoScanTimeMillis; 136 mTotalHotspot2ScanTimeMillis = totalHotspot2ScanTimeMillis; 137 mTotalCcaBusyFreqTimeMillis = totalCcaBusyFreqTimeMillis; 138 mTotalRadioOnFreqTimeMillis = totalRadioOnFreqTimeMillis; 139 mTotalBeaconRx = totalBeaconRx; 140 mProbeStatusSinceLastUpdate = probeStatusSinceLastUpdate; 141 mProbeElapsedTimeSinceLastUpdateMillis = probeElapsedTimeSinceLastUpdateMillis; 142 mProbeMcsRateSinceLastUpdate = probeMcsRateSinceLastUpdate; 143 mRxLinkSpeedMbps = rxLinkSpeedMbps; 144 mCellularDataNetworkType = cellularDataNetworkType; 145 mCellularSignalStrengthDbm = cellularSignalStrengthDbm; 146 mCellularSignalStrengthDb = cellularSignalStrengthDb; 147 mIsSameRegisteredCell = isSameRegisteredCell; 148 } 149 150 /** Implement the Parcelable interface */ describeContents()151 public int describeContents() { 152 return 0; 153 } 154 155 /** Implement the Parcelable interface */ writeToParcel(Parcel dest, int flags)156 public void writeToParcel(Parcel dest, int flags) { 157 dest.writeLong(mTimeStampMillis); 158 dest.writeInt(mRssi); 159 dest.writeInt(mLinkSpeedMbps); 160 dest.writeLong(mTotalTxSuccess); 161 dest.writeLong(mTotalTxRetries); 162 dest.writeLong(mTotalTxBad); 163 dest.writeLong(mTotalRxSuccess); 164 dest.writeLong(mTotalRadioOnTimeMillis); 165 dest.writeLong(mTotalRadioTxTimeMillis); 166 dest.writeLong(mTotalRadioRxTimeMillis); 167 dest.writeLong(mTotalScanTimeMillis); 168 dest.writeLong(mTotalNanScanTimeMillis); 169 dest.writeLong(mTotalBackgroundScanTimeMillis); 170 dest.writeLong(mTotalRoamScanTimeMillis); 171 dest.writeLong(mTotalPnoScanTimeMillis); 172 dest.writeLong(mTotalHotspot2ScanTimeMillis); 173 dest.writeLong(mTotalCcaBusyFreqTimeMillis); 174 dest.writeLong(mTotalRadioOnFreqTimeMillis); 175 dest.writeLong(mTotalBeaconRx); 176 dest.writeInt(mProbeStatusSinceLastUpdate); 177 dest.writeInt(mProbeElapsedTimeSinceLastUpdateMillis); 178 dest.writeInt(mProbeMcsRateSinceLastUpdate); 179 dest.writeInt(mRxLinkSpeedMbps); 180 dest.writeInt(mCellularDataNetworkType); 181 dest.writeInt(mCellularSignalStrengthDbm); 182 dest.writeInt(mCellularSignalStrengthDb); 183 dest.writeBoolean(mIsSameRegisteredCell); 184 } 185 186 /** Implement the Parcelable interface */ 187 public static final @android.annotation.NonNull Creator<WifiUsabilityStatsEntry> CREATOR = 188 new Creator<WifiUsabilityStatsEntry>() { 189 public WifiUsabilityStatsEntry createFromParcel(Parcel in) { 190 return new WifiUsabilityStatsEntry( 191 in.readLong(), in.readInt(), 192 in.readInt(), in.readLong(), in.readLong(), 193 in.readLong(), in.readLong(), in.readLong(), 194 in.readLong(), in.readLong(), in.readLong(), 195 in.readLong(), in.readLong(), in.readLong(), 196 in.readLong(), in.readLong(), in.readLong(), 197 in.readLong(), in.readLong(), in.readInt(), 198 in.readInt(), in.readInt(), in.readInt(), 199 in.readInt(), in.readInt(), in.readInt(), 200 in.readBoolean() 201 ); 202 } 203 204 public WifiUsabilityStatsEntry[] newArray(int size) { 205 return new WifiUsabilityStatsEntry[size]; 206 } 207 }; 208 209 /** Absolute milliseconds from device boot when these stats were sampled */ getTimeStampMillis()210 public long getTimeStampMillis() { 211 return mTimeStampMillis; 212 } 213 214 /** The RSSI (in dBm) at the sample time */ getRssi()215 public int getRssi() { 216 return mRssi; 217 } 218 219 /** Link speed at the sample time in Mbps */ getLinkSpeedMbps()220 public int getLinkSpeedMbps() { 221 return mLinkSpeedMbps; 222 } 223 224 /** The total number of tx success counted from the last radio chip reset */ getTotalTxSuccess()225 public long getTotalTxSuccess() { 226 return mTotalTxSuccess; 227 } 228 229 /** The total number of MPDU data packet retries counted from the last radio chip reset */ getTotalTxRetries()230 public long getTotalTxRetries() { 231 return mTotalTxRetries; 232 } 233 234 /** The total number of tx bad counted from the last radio chip reset */ getTotalTxBad()235 public long getTotalTxBad() { 236 return mTotalTxBad; 237 } 238 239 /** The total number of rx success counted from the last radio chip reset */ getTotalRxSuccess()240 public long getTotalRxSuccess() { 241 return mTotalRxSuccess; 242 } 243 244 /** The total time the wifi radio is on in ms counted from the last radio chip reset */ getTotalRadioOnTimeMillis()245 public long getTotalRadioOnTimeMillis() { 246 return mTotalRadioOnTimeMillis; 247 } 248 249 /** The total time the wifi radio is doing tx in ms counted from the last radio chip reset */ getTotalRadioTxTimeMillis()250 public long getTotalRadioTxTimeMillis() { 251 return mTotalRadioTxTimeMillis; 252 } 253 254 /** The total time the wifi radio is doing rx in ms counted from the last radio chip reset */ getTotalRadioRxTimeMillis()255 public long getTotalRadioRxTimeMillis() { 256 return mTotalRadioRxTimeMillis; 257 } 258 259 /** The total time spent on all types of scans in ms counted from the last radio chip reset */ getTotalScanTimeMillis()260 public long getTotalScanTimeMillis() { 261 return mTotalScanTimeMillis; 262 } 263 264 /** The total time spent on nan scans in ms counted from the last radio chip reset */ getTotalNanScanTimeMillis()265 public long getTotalNanScanTimeMillis() { 266 return mTotalNanScanTimeMillis; 267 } 268 269 /** The total time spent on background scans in ms counted from the last radio chip reset */ getTotalBackgroundScanTimeMillis()270 public long getTotalBackgroundScanTimeMillis() { 271 return mTotalBackgroundScanTimeMillis; 272 } 273 274 /** The total time spent on roam scans in ms counted from the last radio chip reset */ getTotalRoamScanTimeMillis()275 public long getTotalRoamScanTimeMillis() { 276 return mTotalRoamScanTimeMillis; 277 } 278 279 /** The total time spent on pno scans in ms counted from the last radio chip reset */ getTotalPnoScanTimeMillis()280 public long getTotalPnoScanTimeMillis() { 281 return mTotalPnoScanTimeMillis; 282 } 283 284 /** The total time spent on hotspot2.0 scans and GAS exchange in ms counted from the last radio 285 * chip reset */ getTotalHotspot2ScanTimeMillis()286 public long getTotalHotspot2ScanTimeMillis() { 287 return mTotalHotspot2ScanTimeMillis; 288 } 289 290 /** The total time CCA is on busy status on the current frequency in ms counted from the last 291 * radio chip reset */ getTotalCcaBusyFreqTimeMillis()292 public long getTotalCcaBusyFreqTimeMillis() { 293 return mTotalCcaBusyFreqTimeMillis; 294 } 295 296 /** The total radio on time on the current frequency from the last radio chip reset */ getTotalRadioOnFreqTimeMillis()297 public long getTotalRadioOnFreqTimeMillis() { 298 return mTotalRadioOnFreqTimeMillis; 299 } 300 301 /** The total number of beacons received from the last radio chip reset */ getTotalBeaconRx()302 public long getTotalBeaconRx() { 303 return mTotalBeaconRx; 304 } 305 306 /** The status of link probe since last stats update */ getProbeStatusSinceLastUpdate()307 @ProbeStatus public int getProbeStatusSinceLastUpdate() { 308 return mProbeStatusSinceLastUpdate; 309 } 310 311 /** The elapsed time of the most recent link probe since last stats update */ getProbeElapsedTimeSinceLastUpdateMillis()312 public int getProbeElapsedTimeSinceLastUpdateMillis() { 313 return mProbeElapsedTimeSinceLastUpdateMillis; 314 } 315 316 /** The MCS rate of the most recent link probe since last stats update */ getProbeMcsRateSinceLastUpdate()317 public int getProbeMcsRateSinceLastUpdate() { 318 return mProbeMcsRateSinceLastUpdate; 319 } 320 321 /** Rx link speed at the sample time in Mbps */ getRxLinkSpeedMbps()322 public int getRxLinkSpeedMbps() { 323 return mRxLinkSpeedMbps; 324 } 325 326 /** Cellular data network type currently in use on the device for data transmission */ getCellularDataNetworkType()327 @NetworkType public int getCellularDataNetworkType() { 328 return mCellularDataNetworkType; 329 } 330 331 /** 332 * Cellular signal strength in dBm, NR: CsiRsrp, LTE: Rsrp, WCDMA/TDSCDMA: Rscp, 333 * CDMA: Rssi, EVDO: Rssi, GSM: Rssi 334 */ getCellularSignalStrengthDbm()335 public int getCellularSignalStrengthDbm() { 336 return mCellularSignalStrengthDbm; 337 } 338 339 /** 340 * Cellular signal strength in dB, NR: CsiSinr, LTE: Rsrq, WCDMA: EcNo, TDSCDMA: invalid, 341 * CDMA: Ecio, EVDO: SNR, GSM: invalid 342 */ getCellularSignalStrengthDb()343 public int getCellularSignalStrengthDb() { 344 return mCellularSignalStrengthDb; 345 } 346 347 /** Whether the primary registered cell of current entry is same as that of previous entry */ isSameRegisteredCell()348 public boolean isSameRegisteredCell() { 349 return mIsSameRegisteredCell; 350 } 351 } 352