Instead of calling out to external processes with a blocking IPC, pass along a Binder on which the external process can pass back the response. The calling process can then wait for the reply with a timeout. This eliminates watchdog restarts of the system_server when an external process like telephony or bluetooth hangs. Bug:26842468 Change-Id: I1b242e4ed22a63f1a4a0be8c78de8ac4d7bf56c5
189 lines
5.2 KiB
Java
189 lines
5.2 KiB
Java
/*
|
|
* 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;
|
|
|
|
import java.util.Arrays;
|
|
|
|
/**
|
|
* 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 long mControllerTxTimeMs;
|
|
|
|
/**
|
|
* @hide
|
|
*/
|
|
public long[] mControllerTxTimePerLevelMs;
|
|
|
|
/**
|
|
* @hide
|
|
*/
|
|
public long mControllerRxTimeMs;
|
|
|
|
/**
|
|
* @hide
|
|
*/
|
|
public long mControllerIdleTimeMs;
|
|
|
|
/**
|
|
* @hide
|
|
*/
|
|
public long 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,
|
|
long txTime, long[] txTimePerLevel, long rxTime, long idleTime,
|
|
long energyUsed) {
|
|
mTimestamp = timestamp;
|
|
mStackState = stackState;
|
|
mControllerTxTimeMs = txTime;
|
|
mControllerTxTimePerLevelMs = txTimePerLevel;
|
|
mControllerRxTimeMs = rxTime;
|
|
mControllerIdleTimeMs = idleTime;
|
|
mControllerEnergyUsed = energyUsed;
|
|
}
|
|
|
|
@Override
|
|
public String toString() {
|
|
return "WifiActivityEnergyInfo{"
|
|
+ " timestamp=" + mTimestamp
|
|
+ " mStackState=" + mStackState
|
|
+ " mControllerTxTimeMs=" + mControllerTxTimeMs
|
|
+ " mControllerTxTimePerLevelMs=" + Arrays.toString(mControllerTxTimePerLevelMs)
|
|
+ " 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();
|
|
long txTime = in.readLong();
|
|
long[] txTimePerLevel = in.createLongArray();
|
|
long rxTime = in.readLong();
|
|
long idleTime = in.readLong();
|
|
long energyUsed = in.readLong();
|
|
return new WifiActivityEnergyInfo(timestamp, stackState,
|
|
txTime, txTimePerLevel, 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.writeLong(mControllerTxTimeMs);
|
|
out.writeLongArray(mControllerTxTimePerLevelMs);
|
|
out.writeLong(mControllerRxTimeMs);
|
|
out.writeLong(mControllerIdleTimeMs);
|
|
out.writeLong(mControllerEnergyUsed);
|
|
}
|
|
|
|
public int describeContents() {
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* @return bt stack reported state
|
|
*/
|
|
public int getStackState() {
|
|
return mStackState;
|
|
}
|
|
|
|
/**
|
|
* @return tx time in ms
|
|
*/
|
|
public long getControllerTxTimeMillis() {
|
|
return mControllerTxTimeMs;
|
|
}
|
|
|
|
/**
|
|
* @return tx time at power level provided in ms
|
|
*/
|
|
public long getControllerTxTimeMillisAtLevel(int level) {
|
|
if (level < mControllerTxTimePerLevelMs.length) {
|
|
return mControllerTxTimePerLevelMs[level];
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* @return rx time in ms
|
|
*/
|
|
public long getControllerRxTimeMillis() {
|
|
return mControllerRxTimeMs;
|
|
}
|
|
|
|
/**
|
|
* @return idle time in ms
|
|
*/
|
|
public long getControllerIdleTimeMillis() {
|
|
return mControllerIdleTimeMs;
|
|
}
|
|
|
|
/**
|
|
* product of current(mA), voltage(V) and time(ms)
|
|
* @return energy used
|
|
*/
|
|
public long 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 ((mControllerTxTimeMs >=0) &&
|
|
(mControllerRxTimeMs >=0) &&
|
|
(mControllerIdleTimeMs >=0));
|
|
}
|
|
}
|