blob: 0f73342d7c9b43f2a14d02340f6a2cdfcedc1874 [file] [log] [blame]
/*
* Copyright (C) 2014 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package android.net.wifi;
import android.os.Parcel;
import android.os.Parcelable;
/**
* Record of energy and activity information from controller and
* underlying wifi stack state. Timestamp the record with elapsed
* real-time.
* @hide
*/
public final class WifiActivityEnergyInfo implements Parcelable {
/**
* @hide
*/
public long mTimestamp;
/**
* @hide
*/
public int mStackState;
/**
* @hide
*/
public int mControllerTxTimeMs;
/**
* @hide
*/
public int mControllerRxTimeMs;
/**
* @hide
*/
public int mControllerIdleTimeMs;
/**
* @hide
*/
public int mControllerEnergyUsed;
public static final int STACK_STATE_INVALID = 0;
public static final int STACK_STATE_STATE_ACTIVE = 1;
public static final int STACK_STATE_STATE_SCANNING = 2;
public static final int STACK_STATE_STATE_IDLE = 3;
public WifiActivityEnergyInfo(long timestamp, int stackState,
int txTime, int rxTime, int idleTime, int energyUsed) {
mTimestamp = timestamp;
mStackState = stackState;
mControllerTxTimeMs = txTime;
mControllerRxTimeMs = rxTime;
mControllerIdleTimeMs = idleTime;
mControllerEnergyUsed = energyUsed;
}
@Override
public String toString() {
return "WifiActivityEnergyInfo{"
+ " timestamp=" + mTimestamp
+ " mStackState=" + mStackState
+ " mControllerTxTimeMs=" + mControllerTxTimeMs
+ " mControllerRxTimeMs=" + mControllerRxTimeMs
+ " mControllerIdleTimeMs=" + mControllerIdleTimeMs
+ " mControllerEnergyUsed=" + mControllerEnergyUsed
+ " }";
}
public static final Parcelable.Creator<WifiActivityEnergyInfo> CREATOR =
new Parcelable.Creator<WifiActivityEnergyInfo>() {
public WifiActivityEnergyInfo createFromParcel(Parcel in) {
long timestamp = in.readLong();
int stackState = in.readInt();
int txTime = in.readInt();
int rxTime = in.readInt();
int idleTime = in.readInt();
int energyUsed = in.readInt();
return new WifiActivityEnergyInfo(timestamp, stackState,
txTime, rxTime, idleTime, energyUsed);
}
public WifiActivityEnergyInfo[] newArray(int size) {
return new WifiActivityEnergyInfo[size];
}
};
public void writeToParcel(Parcel out, int flags) {
out.writeLong(mTimestamp);
out.writeInt(mStackState);
out.writeInt(mControllerTxTimeMs);
out.writeInt(mControllerRxTimeMs);
out.writeInt(mControllerIdleTimeMs);
out.writeInt(mControllerEnergyUsed);
}
public int describeContents() {
return 0;
}
/**
* @return bt stack reported state
*/
public int getStackState() {
return mStackState;
}
/**
* @return tx time in ms
*/
public int getControllerTxTimeMillis() {
return (int)mControllerTxTimeMs;
}
/**
* @return rx time in ms
*/
public int getControllerRxTimeMillis() {
return (int)mControllerRxTimeMs;
}
/**
* @return idle time in ms
*/
public int getControllerIdleTimeMillis() {
return (int)mControllerIdleTimeMs;
}
/**
* product of current(mA), voltage(V) and time(ms)
* @return energy used
*/
public int getControllerEnergyUsed() {
return mControllerEnergyUsed;
}
/**
* @return timestamp(wall clock) of record creation
*/
public long getTimeStamp() {
return mTimestamp;
}
/**
* @return if the record is valid
*/
public boolean isValid() {
return ((getControllerTxTimeMillis() !=0) ||
(getControllerRxTimeMillis() !=0) ||
(getControllerIdleTimeMillis() !=0));
}
}