summaryrefslogtreecommitdiffstats
path: root/src/com/android/settings/applications
diff options
context:
space:
mode:
authorDianne Hackborn <hackbod@google.com>2013-09-15 13:22:28 -0700
committerDianne Hackborn <hackbod@google.com>2013-09-15 13:22:28 -0700
commit49759af6b06b884d3a1af9dbb120370893744b94 (patch)
treef68130fa2a361d5eacd7eb275cc044b1acda3fc3 /src/com/android/settings/applications
parentb8e39041a5e8994376e44f7b5c5b9cd32a09377e (diff)
downloadpackages_apps_Settings-49759af6b06b884d3a1af9dbb120370893744b94.tar.gz
packages_apps_Settings-49759af6b06b884d3a1af9dbb120370893744b94.tar.bz2
packages_apps_Settings-49759af6b06b884d3a1af9dbb120370893744b94.zip
Various proc stats UI improvements.
- Option to include system processes. - Option to use uss instead of pss sizes. - Option to select type of stats: background processes, foreground (top) processes, cached processes. - Details now shows max mem usage. Change-Id: Ic994564ce846bc1021bf35576feeb9ef095b0e48
Diffstat (limited to 'src/com/android/settings/applications')
-rw-r--r--src/com/android/settings/applications/ProcStatsEntry.java23
-rw-r--r--src/com/android/settings/applications/ProcessStatsDetail.java11
-rw-r--r--src/com/android/settings/applications/ProcessStatsUi.java154
3 files changed, 163 insertions, 25 deletions
diff --git a/src/com/android/settings/applications/ProcStatsEntry.java b/src/com/android/settings/applications/ProcStatsEntry.java
index d6311dc81..830878438 100644
--- a/src/com/android/settings/applications/ProcStatsEntry.java
+++ b/src/com/android/settings/applications/ProcStatsEntry.java
@@ -38,6 +38,9 @@ public final class ProcStatsEntry implements Parcelable {
final boolean mUnique;
final long mDuration;
final long mAvgPss;
+ final long mMaxPss;
+ final long mAvgUss;
+ final long mMaxUss;
final long mWeight;
String mBestTargetPackage;
@@ -50,7 +53,7 @@ public final class ProcStatsEntry implements Parcelable {
public String mUiPackage;
public ProcStatsEntry(ProcessStats.ProcessState proc,
- ProcessStats.ProcessDataCollection tmpTotals) {
+ ProcessStats.ProcessDataCollection tmpTotals, boolean useUss, boolean weightWithTime) {
ProcessStats.computeProcessData(proc, tmpTotals, 0);
mPackage = proc.mPackage;
mUid = proc.mUid;
@@ -58,7 +61,10 @@ public final class ProcStatsEntry implements Parcelable {
mUnique = proc.mCommonProcess == proc;
mDuration = tmpTotals.totalTime;
mAvgPss = tmpTotals.avgPss;
- mWeight = mDuration * mAvgPss;
+ mMaxPss = tmpTotals.maxPss;
+ mAvgUss = tmpTotals.avgUss;
+ mMaxUss = tmpTotals.maxUss;
+ mWeight = (weightWithTime ? mDuration : 1) * (useUss ? mAvgUss : mAvgPss);
}
public ProcStatsEntry(Parcel in) {
@@ -68,13 +74,16 @@ public final class ProcStatsEntry implements Parcelable {
mUnique = in.readInt() != 0;
mDuration = in.readLong();
mAvgPss = in.readLong();
+ mMaxPss = in.readLong();
+ mAvgUss = in.readLong();
+ mMaxUss = in.readLong();
mWeight = in.readLong();
mBestTargetPackage = in.readString();
in.readTypedList(mServices, Service.CREATOR);
}
- public void evaluateTargetPackage(ProcessStats stats,
- ProcessStats.ProcessDataCollection totals, Comparator<ProcStatsEntry> compare) {
+ public void evaluateTargetPackage(ProcessStats stats, ProcessStats.ProcessDataCollection totals,
+ Comparator<ProcStatsEntry> compare, boolean useUss, boolean weightWithTime) {
mBestTargetPackage = null;
if (mUnique) {
mBestTargetPackage = mPackage;
@@ -93,7 +102,8 @@ public final class ProcStatsEntry implements Parcelable {
ProcessStats.ProcessState subProc =
pkgState.mProcesses.valueAt(iproc);
if (subProc.mName.equals(mName)) {
- subProcs.add(new ProcStatsEntry(subProc, totals));
+ subProcs.add(new ProcStatsEntry(subProc, totals, useUss,
+ weightWithTime));
}
}
}
@@ -184,6 +194,9 @@ public final class ProcStatsEntry implements Parcelable {
dest.writeInt(mUnique ? 1 : 0);
dest.writeLong(mDuration);
dest.writeLong(mAvgPss);
+ dest.writeLong(mMaxPss);
+ dest.writeLong(mAvgUss);
+ dest.writeLong(mMaxUss);
dest.writeLong(mWeight);
dest.writeString(mBestTargetPackage);
dest.writeTypedList(mServices);
diff --git a/src/com/android/settings/applications/ProcessStatsDetail.java b/src/com/android/settings/applications/ProcessStatsDetail.java
index 5ec3b0774..fad374523 100644
--- a/src/com/android/settings/applications/ProcessStatsDetail.java
+++ b/src/com/android/settings/applications/ProcessStatsDetail.java
@@ -52,6 +52,7 @@ public class ProcessStatsDetail extends Fragment implements Button.OnClickListen
public static final int ACTION_FORCE_STOP = 1;
public static final String EXTRA_ENTRY = "entry";
+ public static final String EXTRA_USE_USS = "use_uss";
public static final String EXTRA_MAX_WEIGHT = "max_weight";
public static final String EXTRA_TOTAL_TIME = "total_time";
@@ -59,6 +60,7 @@ public class ProcessStatsDetail extends Fragment implements Button.OnClickListen
private DevicePolicyManager mDpm;
private ProcStatsEntry mEntry;
+ private boolean mUseUss;
private long mMaxWeight;
private long mTotalTime;
@@ -83,6 +85,7 @@ public class ProcessStatsDetail extends Fragment implements Button.OnClickListen
final Bundle args = getArguments();
mEntry = (ProcStatsEntry)args.getParcelable(EXTRA_ENTRY);
mEntry.retrieveUiData(mPm);
+ mUseUss = args.getBoolean(EXTRA_USE_USS);
mMaxWeight = args.getLong(EXTRA_MAX_WEIGHT);
mTotalTime = args.getLong(EXTRA_TOTAL_TIME);
}
@@ -177,8 +180,12 @@ public class ProcessStatsDetail extends Fragment implements Button.OnClickListen
}
private void fillDetailsSection() {
- addDetailsItem(mDetailsParent, getResources().getText(R.string.process_stats_ram_use),
- Formatter.formatShortFileSize(getActivity(), mEntry.mAvgPss * 1024));
+ addDetailsItem(mDetailsParent, getResources().getText(R.string.process_stats_avg_ram_use),
+ Formatter.formatShortFileSize(getActivity(),
+ (mUseUss ? mEntry.mAvgUss : mEntry.mAvgPss) * 1024));
+ addDetailsItem(mDetailsParent, getResources().getText(R.string.process_stats_max_ram_use),
+ Formatter.formatShortFileSize(getActivity(),
+ (mUseUss ? mEntry.mMaxUss : mEntry.mMaxPss) * 1024));
addDetailsItem(mDetailsParent, getResources().getText(R.string.process_stats_run_time),
makePercentString(getResources(), mEntry.mDuration, mTotalTime));
}
diff --git a/src/com/android/settings/applications/ProcessStatsUi.java b/src/com/android/settings/applications/ProcessStatsUi.java
index 5c5355dc7..7601309fd 100644
--- a/src/com/android/settings/applications/ProcessStatsUi.java
+++ b/src/com/android/settings/applications/ProcessStatsUi.java
@@ -37,6 +37,7 @@ import android.util.TimeUtils;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
+import android.view.SubMenu;
import com.android.internal.app.IProcessStats;
import com.android.internal.app.ProcessStats;
import com.android.settings.R;
@@ -56,9 +57,14 @@ public class ProcessStatsUi extends PreferenceFragment {
private static final String KEY_MEM_STATUS = "mem_status";
private static final int MENU_STATS_REFRESH = Menu.FIRST;
- private static final int MENU_HELP = Menu.FIRST + 2;
+ private static final int MENU_SHOW_SYSTEM = Menu.FIRST + 1;
+ private static final int MENU_USE_USS = Menu.FIRST + 2;
+ private static final int MENU_TYPE_BACKGROUND = Menu.FIRST + 3;
+ private static final int MENU_TYPE_FOREGROUND = Menu.FIRST + 4;
+ private static final int MENU_TYPE_CACHED = Menu.FIRST + 5;
+ private static final int MENU_HELP = Menu.FIRST + 6;
- static final int MAX_ITEMS_TO_LIST = 20;
+ static final int MAX_ITEMS_TO_LIST = 40;
final static Comparator<ProcStatsEntry> sEntryCompare = new Comparator<ProcStatsEntry>() {
@Override
@@ -79,6 +85,16 @@ public class ProcessStatsUi extends PreferenceFragment {
ProcessStats mStats;
int mMemState;
+ private boolean mShowSystem;
+ private boolean mUseUss;
+ private int mStatsType;
+
+ private MenuItem mShowSystemMenu;
+ private MenuItem mUseUssMenu;
+ private MenuItem mTypeBackgroundMenu;
+ private MenuItem mTypeForegroundMenu;
+ private MenuItem mTypeCachedMenu;
+
private PreferenceGroup mAppListGroup;
private Preference mMemStatusPref;
@@ -99,6 +115,10 @@ public class ProcessStatsUi extends PreferenceFragment {
mUm = (UserManager)getActivity().getSystemService(Context.USER_SERVICE);
mAppListGroup = (PreferenceGroup) findPreference(KEY_APP_LIST);
mMemStatusPref = mAppListGroup.findPreference(KEY_MEM_STATUS);
+ mShowSystem = icicle != null ? icicle.getBoolean("show_system") : false;
+ mUseUss = icicle != null ? icicle.getBoolean("use_uss") : false;
+ mStatsType = icicle != null ? icicle.getInt("stats_type", MENU_TYPE_BACKGROUND)
+ : MENU_TYPE_BACKGROUND;
setHasOptionsMenu(true);
}
@@ -114,6 +134,14 @@ public class ProcessStatsUi extends PreferenceFragment {
}
@Override
+ public void onSaveInstanceState(Bundle outState) {
+ super.onSaveInstanceState(outState);
+ outState.putBoolean("show_system", mShowSystem);
+ outState.putBoolean("use_uss", mUseUss);
+ outState.putInt("stats_type", mStatsType);
+ }
+
+ @Override
public void onDestroy() {
super.onDestroy();
if (getActivity().isChangingConfigurations()) {
@@ -130,6 +158,7 @@ public class ProcessStatsUi extends PreferenceFragment {
ProcessStatsPreference pgp = (ProcessStatsPreference) preference;
Bundle args = new Bundle();
args.putParcelable(ProcessStatsDetail.EXTRA_ENTRY, pgp.getEntry());
+ args.putBoolean(ProcessStatsDetail.EXTRA_USE_USS, mUseUss);
args.putLong(ProcessStatsDetail.EXTRA_MAX_WEIGHT, mMaxWeight);
args.putLong(ProcessStatsDetail.EXTRA_TOTAL_TIME, mTotalTime);
((PreferenceActivity) getActivity()).startPreferencePanel(
@@ -145,6 +174,31 @@ public class ProcessStatsUi extends PreferenceFragment {
.setAlphabeticShortcut('r');
refresh.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM |
MenuItem.SHOW_AS_ACTION_WITH_TEXT);
+ mShowSystemMenu = menu.add(0, MENU_SHOW_SYSTEM, 0, R.string.menu_show_system)
+ .setAlphabeticShortcut('s')
+ .setCheckable(true)
+ .setChecked(mShowSystem)
+ .setEnabled(mStatsType == MENU_TYPE_BACKGROUND);
+ mUseUssMenu = menu.add(0, MENU_USE_USS, 0, R.string.menu_use_uss)
+ .setAlphabeticShortcut('s')
+ .setCheckable(true)
+ .setChecked(mUseUss);
+ SubMenu subMenu = menu.addSubMenu(R.string.menu_proc_stats_type);
+ mTypeBackgroundMenu = subMenu.add(0, MENU_TYPE_BACKGROUND, 0,
+ R.string.menu_proc_stats_type_background)
+ .setAlphabeticShortcut('b')
+ .setCheckable(true)
+ .setChecked(mStatsType == MENU_TYPE_BACKGROUND);
+ mTypeForegroundMenu = subMenu.add(0, MENU_TYPE_FOREGROUND, 0,
+ R.string.menu_proc_stats_type_foreground)
+ .setAlphabeticShortcut('f')
+ .setCheckable(true)
+ .setChecked(mStatsType == MENU_TYPE_FOREGROUND);
+ mTypeCachedMenu = subMenu.add(0, MENU_TYPE_CACHED, 0,
+ R.string.menu_proc_stats_type_cached)
+ .setAlphabeticShortcut('c')
+ .setCheckable(true)
+ .setChecked(mStatsType == MENU_TYPE_CACHED);
/*
String helpUrl;
@@ -162,6 +216,20 @@ public class ProcessStatsUi extends PreferenceFragment {
mStats = null;
refreshStats();
return true;
+ case MENU_SHOW_SYSTEM:
+ mShowSystem = !mShowSystem;
+ refreshStats();
+ return true;
+ case MENU_USE_USS:
+ mUseUss = !mUseUss;
+ refreshStats();
+ return true;
+ case MENU_TYPE_BACKGROUND:
+ case MENU_TYPE_FOREGROUND:
+ case MENU_TYPE_CACHED:
+ mStatsType = item.getItemId();
+ refreshStats();
+ return true;
default:
return false;
}
@@ -173,18 +241,65 @@ public class ProcessStatsUi extends PreferenceFragment {
mAppListGroup.addPreference(notAvailable);
}
+ public static final int[] BACKGROUND_AND_SYSTEM_PROC_STATES = new int[] {
+ ProcessStats.STATE_PERSISTENT, ProcessStats.STATE_IMPORTANT_FOREGROUND,
+ ProcessStats.STATE_IMPORTANT_BACKGROUND, ProcessStats.STATE_BACKUP,
+ ProcessStats.STATE_HEAVY_WEIGHT, ProcessStats.STATE_SERVICE,
+ ProcessStats.STATE_SERVICE_RESTARTING, ProcessStats.STATE_RECEIVER
+ };
+
+ public static final int[] FOREGROUND_PROC_STATES = new int[] {
+ ProcessStats.STATE_TOP
+ };
+
+ public static final int[] CACHED_PROC_STATES = new int[] {
+ ProcessStats.STATE_CACHED_ACTIVITY, ProcessStats.STATE_CACHED_ACTIVITY_CLIENT,
+ ProcessStats.STATE_CACHED_EMPTY
+ };
+
private void refreshStats() {
if (mStats == null) {
load();
}
+ if (mShowSystemMenu != null) {
+ mShowSystemMenu.setChecked(mShowSystem);
+ mShowSystemMenu.setEnabled(mStatsType == MENU_TYPE_BACKGROUND);
+ }
+ if (mUseUssMenu != null) {
+ mUseUssMenu.setChecked(mUseUss);
+ }
+ if (mTypeBackgroundMenu != null) {
+ mTypeBackgroundMenu.setChecked(mStatsType == MENU_TYPE_BACKGROUND);
+ }
+ if (mTypeForegroundMenu != null) {
+ mTypeForegroundMenu.setChecked(mStatsType == MENU_TYPE_FOREGROUND);
+ }
+ if (mTypeCachedMenu != null) {
+ mTypeCachedMenu.setChecked(mStatsType == MENU_TYPE_CACHED);
+ }
+
+ int[] stats;
+ int statsLabel;
+ if (mStatsType == MENU_TYPE_FOREGROUND) {
+ stats = FOREGROUND_PROC_STATES;
+ statsLabel = R.string.process_stats_type_foreground;
+ } else if (mStatsType == MENU_TYPE_CACHED) {
+ stats = CACHED_PROC_STATES;
+ statsLabel = R.string.process_stats_type_cached;
+ } else {
+ stats = mShowSystem ? BACKGROUND_AND_SYSTEM_PROC_STATES
+ : ProcessStats.BACKGROUND_PROC_STATES;
+ statsLabel = R.string.process_stats_type_background;
+ }
+
mAppListGroup.removeAll();
mAppListGroup.setOrderingAsAdded(false);
mMemStatusPref.setOrder(-2);
mAppListGroup.addPreference(mMemStatusPref);
String durationString = Utils.formatElapsedTime(getActivity(),
- mStats.mTimePeriodEndRealtime-mStats.mTimePeriodStartRealtime);
+ mStats.mTimePeriodEndRealtime-mStats.mTimePeriodStartRealtime, false);
CharSequence memString;
CharSequence[] memStates = getResources().getTextArray(R.array.ram_states);
if (mMemState >= 0 && mMemState < memStates.length) {
@@ -193,7 +308,7 @@ public class ProcessStatsUi extends PreferenceFragment {
memString = "?";
}
mMemStatusPref.setTitle(getActivity().getString(R.string.process_stats_total_duration,
- durationString));
+ getActivity().getString(statsLabel), durationString));
mMemStatusPref.setSummary(getActivity().getString(R.string.process_stats_memory_status,
memString));
/*
@@ -208,8 +323,7 @@ public class ProcessStatsUi extends PreferenceFragment {
*/
ProcessStats.ProcessDataCollection totals = new ProcessStats.ProcessDataCollection(
- ProcessStats.ALL_SCREEN_ADJ, ProcessStats.ALL_MEM_ADJ,
- ProcessStats.BACKGROUND_PROC_STATES);
+ ProcessStats.ALL_SCREEN_ADJ, ProcessStats.ALL_MEM_ADJ, stats);
long now = SystemClock.uptimeMillis();
@@ -251,7 +365,8 @@ public class ProcessStatsUi extends PreferenceFragment {
for (int ip=0, N=mStats.mProcesses.getMap().size(); ip<N; ip++) {
SparseArray<ProcessStats.ProcessState> uids = mStats.mProcesses.getMap().valueAt(ip);
for (int iu=0; iu<uids.size(); iu++) {
- ProcStatsEntry ent = new ProcStatsEntry(uids.valueAt(iu), totals);
+ ProcStatsEntry ent = new ProcStatsEntry(uids.valueAt(iu), totals, mUseUss,
+ mStatsType == MENU_TYPE_BACKGROUND);
procs.add(ent);
processes.put(ent.mName, ent);
}
@@ -275,9 +390,10 @@ public class ProcessStatsUi extends PreferenceFragment {
ProcStatsEntry proc = procs.get(i);
final double percentOfWeight = (((double)proc.mWeight) / maxWeight) * 100;
final double percentOfTime = (((double)proc.mDuration) / mTotalTime) * 100;
- if (percentOfWeight < 1) continue;
+ if (percentOfWeight < 2) break;
ProcessStatsPreference pref = new ProcessStatsPreference(getActivity(), null, proc);
- proc.evaluateTargetPackage(mStats, totals, sEntryCompare);
+ proc.evaluateTargetPackage(mStats, totals, sEntryCompare, mUseUss,
+ mStatsType == MENU_TYPE_BACKGROUND);
proc.retrieveUiData(pm);
pref.setTitle(proc.mUiLabel);
if (proc.mUiTargetApp != null) {
@@ -290,15 +406,17 @@ public class ProcessStatsUi extends PreferenceFragment {
}
// Add in service info.
- for (int ip=0, N=mStats.mPackages.getMap().size(); ip<N; ip++) {
- SparseArray<ProcessStats.PackageState> uids = mStats.mPackages.getMap().valueAt(ip);
- for (int iu=0; iu<uids.size(); iu++) {
- ProcessStats.PackageState ps = uids.valueAt(iu);
- for (int is=0, NS=ps.mServices.size(); is<NS; is++) {
- ProcessStats.ServiceState ss = ps.mServices.valueAt(is);
- if (ss.mProcessName != null) {
- ProcStatsEntry ent = processes.get(ss.mProcessName);
- ent.addService(ss);
+ if (mStatsType == MENU_TYPE_BACKGROUND) {
+ for (int ip=0, N=mStats.mPackages.getMap().size(); ip<N; ip++) {
+ SparseArray<ProcessStats.PackageState> uids = mStats.mPackages.getMap().valueAt(ip);
+ for (int iu=0; iu<uids.size(); iu++) {
+ ProcessStats.PackageState ps = uids.valueAt(iu);
+ for (int is=0, NS=ps.mServices.size(); is<NS; is++) {
+ ProcessStats.ServiceState ss = ps.mServices.valueAt(is);
+ if (ss.mProcessName != null) {
+ ProcStatsEntry ent = processes.get(ss.mProcessName);
+ ent.addService(ss);
+ }
}
}
}