1c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn/* 2c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * Copyright (C) 2013 The Android Open Source Project 3c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * 4c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * Licensed under the Apache License, Version 2.0 (the "License"); 5c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * you may not use this file except in compliance with the License. 6c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * You may obtain a copy of the License at 7c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * 8c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * http://www.apache.org/licenses/LICENSE-2.0 9c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * 10c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * Unless required by applicable law or agreed to in writing, software 11c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * distributed under the License is distributed on an "AS IS" BASIS, 12c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * See the License for the specific language governing permissions and 14c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn * limitations under the License. 15c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn */ 16c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 17c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornpackage com.android.settings.applications; 18c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 19c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.content.Context; 20c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.content.pm.PackageManager; 21c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.os.Bundle; 22c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.os.ParcelFileDescriptor; 23c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.os.RemoteException; 24c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.os.ServiceManager; 25c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.os.SystemClock; 26c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.os.UserManager; 27c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.preference.Preference; 2804486738342fa5e11a78df836efe34b85bee125aDianne Hackbornimport android.preference.PreferenceActivity; 29c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.preference.PreferenceFragment; 30c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.preference.PreferenceGroup; 31c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.preference.PreferenceScreen; 32c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.util.Log; 33a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackbornimport android.util.SparseArray; 34c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackbornimport android.util.TimeUtils; 35c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.view.Menu; 36c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.view.MenuInflater; 37c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport android.view.MenuItem; 3849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackbornimport android.view.SubMenu; 39c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport com.android.internal.app.IProcessStats; 405635594c38fb319e050054e42109eb736f274accDianne Hackbornimport com.android.internal.app.ProcessMap; 41c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport com.android.internal.app.ProcessStats; 42c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport com.android.settings.R; 43c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackbornimport com.android.settings.fuelgauge.Utils; 44c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 45c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport java.io.IOException; 46c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackbornimport java.io.InputStream; 47c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackbornimport java.util.ArrayList; 48c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackbornimport java.util.Collections; 49c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackbornimport java.util.Comparator; 50c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 51b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackbornpublic class ProcessStatsUi extends PreferenceFragment 52b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn implements LinearColorBar.OnRegionTappedListener { 535635594c38fb319e050054e42109eb736f274accDianne Hackborn static final String TAG = "ProcessStatsUi"; 545635594c38fb319e050054e42109eb736f274accDianne Hackborn static final boolean DEBUG = false; 55c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 56c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn private static final String KEY_APP_LIST = "app_list"; 57c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn private static final String KEY_MEM_STATUS = "mem_status"; 58c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 5988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static final int NUM_DURATIONS = 4; 6088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn 61c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn private static final int MENU_STATS_REFRESH = Menu.FIRST; 6288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static final int MENU_DURATION = Menu.FIRST + 1; 6388cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static final int MENU_SHOW_SYSTEM = MENU_DURATION + NUM_DURATIONS; 6488cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static final int MENU_USE_USS = MENU_SHOW_SYSTEM + 1; 6588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static final int MENU_TYPE_BACKGROUND = MENU_USE_USS + 1; 6688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static final int MENU_TYPE_FOREGROUND = MENU_TYPE_BACKGROUND + 1; 6788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static final int MENU_TYPE_CACHED = MENU_TYPE_FOREGROUND + 1; 6888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static final int MENU_HELP = MENU_TYPE_CACHED + 1; 69c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 7088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn static final int MAX_ITEMS_TO_LIST = 60; 71c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 72a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn final static Comparator<ProcStatsEntry> sEntryCompare = new Comparator<ProcStatsEntry>() { 73a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn @Override 74a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn public int compare(ProcStatsEntry lhs, ProcStatsEntry rhs) { 75a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn if (lhs.mWeight < rhs.mWeight) { 76a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn return 1; 77a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn } else if (lhs.mWeight > rhs.mWeight) { 78a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn return -1; 795635594c38fb319e050054e42109eb736f274accDianne Hackborn } else if (lhs.mDuration < rhs.mDuration) { 805635594c38fb319e050054e42109eb736f274accDianne Hackborn return 1; 815635594c38fb319e050054e42109eb736f274accDianne Hackborn } else if (lhs.mDuration > rhs.mDuration) { 825635594c38fb319e050054e42109eb736f274accDianne Hackborn return -1; 83a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn } 84a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn return 0; 85a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn } 86a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn }; 87a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn 88c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn private static ProcessStats sStatsXfer; 89c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 90c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn IProcessStats mProcessStats; 91c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn UserManager mUm; 92c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn ProcessStats mStats; 93a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn int mMemState; 94c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 9588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private long mDuration; 9688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private long mLastDuration; 9749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn private boolean mShowSystem; 9849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn private boolean mUseUss; 9949759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn private int mStatsType; 100b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn private int mMemRegion; 10149759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn 10288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private MenuItem[] mDurationMenus = new MenuItem[NUM_DURATIONS]; 10349759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn private MenuItem mShowSystemMenu; 10449759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn private MenuItem mUseUssMenu; 10549759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn private MenuItem mTypeBackgroundMenu; 10649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn private MenuItem mTypeForegroundMenu; 10749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn private MenuItem mTypeCachedMenu; 10849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn 109c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn private PreferenceGroup mAppListGroup; 110c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn private Preference mMemStatusPref; 111c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 11204486738342fa5e11a78df836efe34b85bee125aDianne Hackborn long mMaxWeight; 113c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn long mTotalTime; 114c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 11588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn // The actual duration value to use for each duration option. Note these 11688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn // are lower than the actual duration, since our durations are computed in 11788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn // batches of 3 hours so we want to allow the time we use to be slightly 11888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn // smaller than the actual time selected instead of bumping up to 3 hours 11988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn // beyond it. 1205635594c38fb319e050054e42109eb736f274accDianne Hackborn private static final long DURATION_QUANTUM = ProcessStats.COMMIT_PERIOD; 12188cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static long[] sDurations = new long[] { 12288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn 3*60*60*1000 - DURATION_QUANTUM/2, 6*60*60*1000 - DURATION_QUANTUM/2, 12388cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn 12*60*60*1000 - DURATION_QUANTUM/2, 24*60*60*1000 - DURATION_QUANTUM/2 12488cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn }; 12588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn private static int[] sDurationLabels = new int[] { 12688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn R.string.menu_duration_3h, R.string.menu_duration_6h, 12788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn R.string.menu_duration_12h, R.string.menu_duration_1d 12888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn }; 12988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn 130c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn @Override 131c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn public void onCreate(Bundle icicle) { 132c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn super.onCreate(icicle); 133c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 134c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn if (icicle != null) { 135c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mStats = sStatsXfer; 136c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 137c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 138c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn addPreferencesFromResource(R.xml.process_stats_summary); 139c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mProcessStats = IProcessStats.Stub.asInterface( 140c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn ServiceManager.getService(ProcessStats.SERVICE_NAME)); 141c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mUm = (UserManager)getActivity().getSystemService(Context.USER_SERVICE); 142c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mAppListGroup = (PreferenceGroup) findPreference(KEY_APP_LIST); 143c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mMemStatusPref = mAppListGroup.findPreference(KEY_MEM_STATUS); 14488cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mDuration = icicle != null ? icicle.getLong("duration", sDurations[0]) : sDurations[0]; 14549759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mShowSystem = icicle != null ? icicle.getBoolean("show_system") : false; 14649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mUseUss = icicle != null ? icicle.getBoolean("use_uss") : false; 14749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mStatsType = icicle != null ? icicle.getInt("stats_type", MENU_TYPE_BACKGROUND) 14849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn : MENU_TYPE_BACKGROUND; 149b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn mMemRegion = icicle != null ? icicle.getInt("mem_region", LinearColorBar.REGION_GREEN) 150b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn : LinearColorBar.REGION_GREEN; 151c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn setHasOptionsMenu(true); 152c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 153c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 154c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn @Override 155c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn public void onResume() { 156c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn super.onResume(); 157c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn refreshStats(); 158c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 159c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 160c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn @Override 161c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn public void onPause() { 162c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn super.onPause(); 163c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 164c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 165c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn @Override 16649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn public void onSaveInstanceState(Bundle outState) { 16749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn super.onSaveInstanceState(outState); 16888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn outState.putLong("duration", mDuration); 16949759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn outState.putBoolean("show_system", mShowSystem); 17049759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn outState.putBoolean("use_uss", mUseUss); 17149759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn outState.putInt("stats_type", mStatsType); 172b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn outState.putInt("mem_region", mMemRegion); 17349759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn } 17449759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn 17549759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn @Override 176c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn public void onDestroy() { 177c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn super.onDestroy(); 178c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn if (getActivity().isChangingConfigurations()) { 179c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn sStatsXfer = mStats; 180c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 181c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 182c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 183c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn @Override 184c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn public boolean onPreferenceTreeClick(PreferenceScreen preferenceScreen, Preference preference) { 185c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn if (!(preference instanceof ProcessStatsPreference)) { 186c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn return false; 187c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 188c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 18904486738342fa5e11a78df836efe34b85bee125aDianne Hackborn ProcessStatsPreference pgp = (ProcessStatsPreference) preference; 19004486738342fa5e11a78df836efe34b85bee125aDianne Hackborn Bundle args = new Bundle(); 19104486738342fa5e11a78df836efe34b85bee125aDianne Hackborn args.putParcelable(ProcessStatsDetail.EXTRA_ENTRY, pgp.getEntry()); 19249759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn args.putBoolean(ProcessStatsDetail.EXTRA_USE_USS, mUseUss); 19304486738342fa5e11a78df836efe34b85bee125aDianne Hackborn args.putLong(ProcessStatsDetail.EXTRA_MAX_WEIGHT, mMaxWeight); 19404486738342fa5e11a78df836efe34b85bee125aDianne Hackborn args.putLong(ProcessStatsDetail.EXTRA_TOTAL_TIME, mTotalTime); 19504486738342fa5e11a78df836efe34b85bee125aDianne Hackborn ((PreferenceActivity) getActivity()).startPreferencePanel( 19604486738342fa5e11a78df836efe34b85bee125aDianne Hackborn ProcessStatsDetail.class.getName(), args, R.string.details_title, null, null, 0); 197c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 198c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn return super.onPreferenceTreeClick(preferenceScreen, preference); 199c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 200c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 201c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn @Override 202c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { 203c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn MenuItem refresh = menu.add(0, MENU_STATS_REFRESH, 0, R.string.menu_stats_refresh) 204c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn .setIcon(R.drawable.ic_menu_refresh_holo_dark) 205c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn .setAlphabeticShortcut('r'); 206c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn refresh.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM | 207c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn MenuItem.SHOW_AS_ACTION_WITH_TEXT); 20888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn SubMenu subMenu = menu.addSubMenu(R.string.menu_proc_stats_duration); 20988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn for (int i=0; i<NUM_DURATIONS; i++) { 21088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mDurationMenus[i] = subMenu.add(0, MENU_DURATION+i, 0, sDurationLabels[i]) 21188cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn .setCheckable(true); 21288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 21349759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mShowSystemMenu = menu.add(0, MENU_SHOW_SYSTEM, 0, R.string.menu_show_system) 21449759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn .setAlphabeticShortcut('s') 21588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn .setCheckable(true); 21649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mUseUssMenu = menu.add(0, MENU_USE_USS, 0, R.string.menu_use_uss) 21788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn .setAlphabeticShortcut('u') 21888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn .setCheckable(true); 21988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn subMenu = menu.addSubMenu(R.string.menu_proc_stats_type); 22049759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mTypeBackgroundMenu = subMenu.add(0, MENU_TYPE_BACKGROUND, 0, 22149759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn R.string.menu_proc_stats_type_background) 22249759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn .setAlphabeticShortcut('b') 22388cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn .setCheckable(true); 22449759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mTypeForegroundMenu = subMenu.add(0, MENU_TYPE_FOREGROUND, 0, 22549759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn R.string.menu_proc_stats_type_foreground) 22649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn .setAlphabeticShortcut('f') 22788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn .setCheckable(true); 22849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mTypeCachedMenu = subMenu.add(0, MENU_TYPE_CACHED, 0, 22949759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn R.string.menu_proc_stats_type_cached) 23088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn .setCheckable(true); 23188cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn 23288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn updateMenus(); 233c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 234c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn /* 235c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn String helpUrl; 236c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn if (!TextUtils.isEmpty(helpUrl = getResources().getString(R.string.help_url_battery))) { 237c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn final MenuItem help = menu.add(0, MENU_HELP, 0, R.string.help_label); 238c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn HelpUtils.prepareHelpMenuItem(getActivity(), help, helpUrl); 239c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 240c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn */ 241c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 242c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 24388cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn void updateMenus() { 24488cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn int closestIndex = 0; 24588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn long closestDelta = Math.abs(sDurations[0]-mDuration); 24688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn for (int i=1; i<NUM_DURATIONS; i++) { 24788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn long delta = Math.abs(sDurations[i]-mDuration); 24888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (delta < closestDelta) { 24988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn closestDelta = delta; 25088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn closestIndex = i; 25188cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 25288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 25388cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn for (int i=0; i<NUM_DURATIONS; i++) { 25488cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (mDurationMenus[i] != null) { 25588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mDurationMenus[i].setChecked(i == closestIndex); 25688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 25788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 25888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mDuration = sDurations[closestIndex]; 25988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (mShowSystemMenu != null) { 26088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mShowSystemMenu.setChecked(mShowSystem); 26188cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mShowSystemMenu.setEnabled(mStatsType == MENU_TYPE_BACKGROUND); 26288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 26388cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (mUseUssMenu != null) { 26488cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mUseUssMenu.setChecked(mUseUss); 26588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 26688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (mTypeBackgroundMenu != null) { 26788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mTypeBackgroundMenu.setChecked(mStatsType == MENU_TYPE_BACKGROUND); 26888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 26988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (mTypeForegroundMenu != null) { 27088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mTypeForegroundMenu.setChecked(mStatsType == MENU_TYPE_FOREGROUND); 27188cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 27288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (mTypeCachedMenu != null) { 27388cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mTypeCachedMenu.setChecked(mStatsType == MENU_TYPE_CACHED); 27488cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 27588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 27688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn 277c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn @Override 278c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn public boolean onOptionsItemSelected(MenuItem item) { 27988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn final int id = item.getItemId(); 28088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn switch (id) { 281c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn case MENU_STATS_REFRESH: 282c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mStats = null; 283c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn refreshStats(); 284c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn return true; 28549759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn case MENU_SHOW_SYSTEM: 28649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mShowSystem = !mShowSystem; 28749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn refreshStats(); 28849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn return true; 28949759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn case MENU_USE_USS: 29049759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mUseUss = !mUseUss; 29149759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn refreshStats(); 29249759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn return true; 29349759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn case MENU_TYPE_BACKGROUND: 29449759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn case MENU_TYPE_FOREGROUND: 29549759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn case MENU_TYPE_CACHED: 29649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mStatsType = item.getItemId(); 29749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn refreshStats(); 29849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn return true; 299c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn default: 30088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (id >= MENU_DURATION && id < (MENU_DURATION+NUM_DURATIONS)) { 30188cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mDuration = sDurations[id-MENU_DURATION]; 30288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn refreshStats(); 30388cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } 304c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn return false; 305c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 306c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 307c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 308b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn @Override 309b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn public void onRegionTapped(int region) { 310b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn if (mMemRegion != region) { 311b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn mMemRegion = region; 312b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn refreshStats(); 313b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn } 314b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn } 315b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn 316c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn private void addNotAvailableMessage() { 317c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn Preference notAvailable = new Preference(getActivity()); 318c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn notAvailable.setTitle(R.string.power_usage_not_available); 319c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mAppListGroup.addPreference(notAvailable); 320c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 321c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 32249759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn public static final int[] BACKGROUND_AND_SYSTEM_PROC_STATES = new int[] { 32349759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn ProcessStats.STATE_PERSISTENT, ProcessStats.STATE_IMPORTANT_FOREGROUND, 32449759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn ProcessStats.STATE_IMPORTANT_BACKGROUND, ProcessStats.STATE_BACKUP, 32549759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn ProcessStats.STATE_HEAVY_WEIGHT, ProcessStats.STATE_SERVICE, 32649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn ProcessStats.STATE_SERVICE_RESTARTING, ProcessStats.STATE_RECEIVER 32749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn }; 32849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn 32949759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn public static final int[] FOREGROUND_PROC_STATES = new int[] { 33049759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn ProcessStats.STATE_TOP 33149759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn }; 33249759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn 33349759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn public static final int[] CACHED_PROC_STATES = new int[] { 33449759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn ProcessStats.STATE_CACHED_ACTIVITY, ProcessStats.STATE_CACHED_ACTIVITY_CLIENT, 33549759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn ProcessStats.STATE_CACHED_EMPTY 33649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn }; 33749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn 338b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn public static final int[] RED_MEM_STATES = new int[] { 339b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn ProcessStats.ADJ_MEM_FACTOR_CRITICAL 340b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn }; 341b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn 342b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn public static final int[] YELLOW_MEM_STATES = new int[] { 343b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn ProcessStats.ADJ_MEM_FACTOR_CRITICAL, ProcessStats.ADJ_MEM_FACTOR_LOW, 344b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn ProcessStats.ADJ_MEM_FACTOR_MODERATE 345b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn }; 346b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn 3475635594c38fb319e050054e42109eb736f274accDianne Hackborn private String makeDuration(long time) { 3485635594c38fb319e050054e42109eb736f274accDianne Hackborn StringBuilder sb = new StringBuilder(32); 3495635594c38fb319e050054e42109eb736f274accDianne Hackborn TimeUtils.formatDuration(time, sb); 3505635594c38fb319e050054e42109eb736f274accDianne Hackborn return sb.toString(); 3515635594c38fb319e050054e42109eb736f274accDianne Hackborn } 3525635594c38fb319e050054e42109eb736f274accDianne Hackborn 353c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn private void refreshStats() { 35488cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn updateMenus(); 355c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 35688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (mStats == null || mLastDuration != mDuration) { 35788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn load(); 35849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn } 35949759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn 36049759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn int[] stats; 36149759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn int statsLabel; 36249759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn if (mStatsType == MENU_TYPE_FOREGROUND) { 36349759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn stats = FOREGROUND_PROC_STATES; 36449759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn statsLabel = R.string.process_stats_type_foreground; 36549759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn } else if (mStatsType == MENU_TYPE_CACHED) { 36649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn stats = CACHED_PROC_STATES; 36749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn statsLabel = R.string.process_stats_type_cached; 36849759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn } else { 36949759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn stats = mShowSystem ? BACKGROUND_AND_SYSTEM_PROC_STATES 37049759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn : ProcessStats.BACKGROUND_PROC_STATES; 37149759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn statsLabel = R.string.process_stats_type_background; 37249759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn } 37349759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn 374c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mAppListGroup.removeAll(); 375c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mAppListGroup.setOrderingAsAdded(false); 376c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 377c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mMemStatusPref.setOrder(-2); 378c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mAppListGroup.addPreference(mMemStatusPref); 379c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn String durationString = Utils.formatElapsedTime(getActivity(), 38049759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mStats.mTimePeriodEndRealtime-mStats.mTimePeriodStartRealtime, false); 381a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn CharSequence memString; 382b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn CharSequence[] memStatesStr = getResources().getTextArray(R.array.ram_states); 383b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn if (mMemState >= 0 && mMemState < memStatesStr.length) { 384b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn memString = memStatesStr[mMemState]; 385a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn } else { 386a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn memString = "?"; 387a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn } 388c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn mMemStatusPref.setTitle(getActivity().getString(R.string.process_stats_total_duration, 38949759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn getActivity().getString(statsLabel), durationString)); 390a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn mMemStatusPref.setSummary(getActivity().getString(R.string.process_stats_memory_status, 391a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn memString)); 392c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn /* 393c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn mMemStatusPref.setTitle(DateFormat.format(DateFormat.getBestDateTimePattern( 394c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn getActivity().getResources().getConfiguration().locale, 395c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn "MMMM dd, yyyy h:mm a"), mStats.mTimePeriodStartClock)); 396c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn */ 397c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn /* 398c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn BatteryHistoryPreference hist = new BatteryHistoryPreference(getActivity(), mStats); 399c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn hist.setOrder(-1); 400c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mAppListGroup.addPreference(hist); 401c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn */ 402c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 403c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn long now = SystemClock.uptimeMillis(); 404c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 405a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn final PackageManager pm = getActivity().getPackageManager(); 406a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn 407c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mTotalTime = ProcessStats.dumpSingleTime(null, null, mStats.mMemFactorDurations, 408c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mStats.mMemFactor, mStats.mStartTime, now); 4095635594c38fb319e050054e42109eb736f274accDianne Hackborn if (DEBUG) Log.d(TAG, "Total time of stats: " + makeDuration(mTotalTime)); 410c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 411a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn long[] memTimes = new long[ProcessStats.ADJ_MEM_FACTOR_COUNT]; 412a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn for (int iscreen=0; iscreen<ProcessStats.ADJ_COUNT; iscreen+=ProcessStats.ADJ_SCREEN_MOD) { 413a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn for (int imem=0; imem<ProcessStats.ADJ_MEM_FACTOR_COUNT; imem++) { 414a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn int state = imem+iscreen; 415a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn memTimes[imem] += mStats.mMemFactorDurations[state]; 416a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn } 417a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn } 418a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn 419b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn long memTotalTime; 420b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn int[] memStates; 421b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn 422b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn LinearColorPreference colors = new LinearColorPreference(getActivity()); 423b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn colors.setOrder(-1); 424b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn colors.setOnRegionTappedListener(this); 425b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn switch (mMemRegion) { 426b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn case LinearColorBar.REGION_RED: 427b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn colors.setColoredRegions(LinearColorBar.REGION_RED); 428b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn memTotalTime = memTimes[ProcessStats.ADJ_MEM_FACTOR_CRITICAL]; 429b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn memStates = RED_MEM_STATES; 430b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn break; 431b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn case LinearColorBar.REGION_YELLOW: 432b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn colors.setColoredRegions(LinearColorBar.REGION_RED 433b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn | LinearColorBar.REGION_YELLOW); 434b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn memTotalTime = memTimes[ProcessStats.ADJ_MEM_FACTOR_CRITICAL] 435b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn + memTimes[ProcessStats.ADJ_MEM_FACTOR_LOW] 436b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn + memTimes[ProcessStats.ADJ_MEM_FACTOR_MODERATE]; 437b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn memStates = YELLOW_MEM_STATES; 438b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn break; 439b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn default: 440b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn colors.setColoredRegions(LinearColorBar.REGION_ALL); 441b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn memTotalTime = mTotalTime; 442b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn memStates = ProcessStats.ALL_MEM_ADJ; 443b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn break; 444b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn } 445a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn colors.setRatios(memTimes[ProcessStats.ADJ_MEM_FACTOR_CRITICAL] / (float)mTotalTime, 446a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn (memTimes[ProcessStats.ADJ_MEM_FACTOR_LOW] 447a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn + memTimes[ProcessStats.ADJ_MEM_FACTOR_MODERATE]) / (float)mTotalTime, 448a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn memTimes[ProcessStats.ADJ_MEM_FACTOR_NORMAL] / (float)mTotalTime); 449b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn mAppListGroup.addPreference(colors); 450b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn 451b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn ProcessStats.ProcessDataCollection totals = new ProcessStats.ProcessDataCollection( 452b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn ProcessStats.ALL_SCREEN_ADJ, memStates, stats); 453c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 4545635594c38fb319e050054e42109eb736f274accDianne Hackborn ArrayList<ProcStatsEntry> entries = new ArrayList<ProcStatsEntry>(); 455a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn 456a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn /* 457a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn ArrayList<ProcessStats.ProcessState> rawProcs = mStats.collectProcessesLocked( 458a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn ProcessStats.ALL_SCREEN_ADJ, ProcessStats.ALL_MEM_ADJ, 459a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn ProcessStats.BACKGROUND_PROC_STATES, now, null); 460c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn for (int i=0, N=(rawProcs != null ? rawProcs.size() : 0); i<N; i++) { 461c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn procs.add(new ProcStatsEntry(rawProcs.get(i), totals)); 462c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn } 463a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn */ 464a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn 4655635594c38fb319e050054e42109eb736f274accDianne Hackborn if (DEBUG) Log.d(TAG, "-------------------- PULLING PROCESSES"); 4665635594c38fb319e050054e42109eb736f274accDianne Hackborn 4675635594c38fb319e050054e42109eb736f274accDianne Hackborn final ProcessMap<ProcStatsEntry> entriesMap = new ProcessMap<ProcStatsEntry>(); 4685635594c38fb319e050054e42109eb736f274accDianne Hackborn for (int ipkg=0, N=mStats.mPackages.getMap().size(); ipkg<N; ipkg++) { 4695635594c38fb319e050054e42109eb736f274accDianne Hackborn final SparseArray<ProcessStats.PackageState> pkgUids 4705635594c38fb319e050054e42109eb736f274accDianne Hackborn = mStats.mPackages.getMap().valueAt(ipkg); 4715635594c38fb319e050054e42109eb736f274accDianne Hackborn for (int iu=0; iu<pkgUids.size(); iu++) { 4725635594c38fb319e050054e42109eb736f274accDianne Hackborn final ProcessStats.PackageState st = pkgUids.valueAt(iu); 4735635594c38fb319e050054e42109eb736f274accDianne Hackborn for (int iproc=0; iproc<st.mProcesses.size(); iproc++) { 4745635594c38fb319e050054e42109eb736f274accDianne Hackborn final ProcessStats.ProcessState pkgProc = st.mProcesses.valueAt(iproc); 4755635594c38fb319e050054e42109eb736f274accDianne Hackborn final ProcessStats.ProcessState proc = mStats.mProcesses.get(pkgProc.mName, 4765635594c38fb319e050054e42109eb736f274accDianne Hackborn pkgProc.mUid); 4775635594c38fb319e050054e42109eb736f274accDianne Hackborn if (proc == null) { 4785635594c38fb319e050054e42109eb736f274accDianne Hackborn Log.w(TAG, "No process found for pkg " + st.mPackageName 4795635594c38fb319e050054e42109eb736f274accDianne Hackborn + "/" + st.mUid + " proc name " + pkgProc.mName); 4805635594c38fb319e050054e42109eb736f274accDianne Hackborn continue; 4815635594c38fb319e050054e42109eb736f274accDianne Hackborn } 4825635594c38fb319e050054e42109eb736f274accDianne Hackborn ProcStatsEntry ent = entriesMap.get(proc.mName, proc.mUid); 4835635594c38fb319e050054e42109eb736f274accDianne Hackborn if (ent == null) { 4845635594c38fb319e050054e42109eb736f274accDianne Hackborn ent = new ProcStatsEntry(proc, st.mPackageName, totals, mUseUss, 4855635594c38fb319e050054e42109eb736f274accDianne Hackborn mStatsType == MENU_TYPE_BACKGROUND); 4865635594c38fb319e050054e42109eb736f274accDianne Hackborn if (ent.mDuration > 0) { 4875635594c38fb319e050054e42109eb736f274accDianne Hackborn if (DEBUG) Log.d(TAG, "Adding proc " + proc.mName + "/" 4885635594c38fb319e050054e42109eb736f274accDianne Hackborn + proc.mUid + ": time=" + makeDuration(ent.mDuration) + " (" 489b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn + ((((double)ent.mDuration) / memTotalTime) * 100) + "%)" 4905635594c38fb319e050054e42109eb736f274accDianne Hackborn + " pss=" + ent.mAvgPss); 4915635594c38fb319e050054e42109eb736f274accDianne Hackborn entriesMap.put(proc.mName, proc.mUid, ent); 4925635594c38fb319e050054e42109eb736f274accDianne Hackborn entries.add(ent); 4935635594c38fb319e050054e42109eb736f274accDianne Hackborn } 4945635594c38fb319e050054e42109eb736f274accDianne Hackborn } else { 4955635594c38fb319e050054e42109eb736f274accDianne Hackborn ent.addPackage(st.mPackageName); 4965635594c38fb319e050054e42109eb736f274accDianne Hackborn } 4975635594c38fb319e050054e42109eb736f274accDianne Hackborn } 4985635594c38fb319e050054e42109eb736f274accDianne Hackborn } 4995635594c38fb319e050054e42109eb736f274accDianne Hackborn } 5005635594c38fb319e050054e42109eb736f274accDianne Hackborn 5015635594c38fb319e050054e42109eb736f274accDianne Hackborn if (DEBUG) Log.d(TAG, "-------------------- MAPPING SERVICES"); 5025635594c38fb319e050054e42109eb736f274accDianne Hackborn 5035635594c38fb319e050054e42109eb736f274accDianne Hackborn // Add in service info. 5045635594c38fb319e050054e42109eb736f274accDianne Hackborn if (mStatsType == MENU_TYPE_BACKGROUND) { 5055635594c38fb319e050054e42109eb736f274accDianne Hackborn for (int ip=0, N=mStats.mPackages.getMap().size(); ip<N; ip++) { 5065635594c38fb319e050054e42109eb736f274accDianne Hackborn SparseArray<ProcessStats.PackageState> uids = mStats.mPackages.getMap().valueAt(ip); 5075635594c38fb319e050054e42109eb736f274accDianne Hackborn for (int iu=0; iu<uids.size(); iu++) { 5085635594c38fb319e050054e42109eb736f274accDianne Hackborn ProcessStats.PackageState ps = uids.valueAt(iu); 5095635594c38fb319e050054e42109eb736f274accDianne Hackborn for (int is=0, NS=ps.mServices.size(); is<NS; is++) { 5105635594c38fb319e050054e42109eb736f274accDianne Hackborn ProcessStats.ServiceState ss = ps.mServices.valueAt(is); 5115635594c38fb319e050054e42109eb736f274accDianne Hackborn if (ss.mProcessName != null) { 5125635594c38fb319e050054e42109eb736f274accDianne Hackborn ProcStatsEntry ent = entriesMap.get(ss.mProcessName, uids.keyAt(iu)); 5135635594c38fb319e050054e42109eb736f274accDianne Hackborn if (ent != null) { 5145635594c38fb319e050054e42109eb736f274accDianne Hackborn if (DEBUG) Log.d(TAG, "Adding service " + ps.mPackageName 5155635594c38fb319e050054e42109eb736f274accDianne Hackborn + "/" + ss.mName + "/" + uids.keyAt(iu) + " to proc " 5165635594c38fb319e050054e42109eb736f274accDianne Hackborn + ss.mProcessName); 5175635594c38fb319e050054e42109eb736f274accDianne Hackborn ent.addService(ss); 5185635594c38fb319e050054e42109eb736f274accDianne Hackborn } else { 5195635594c38fb319e050054e42109eb736f274accDianne Hackborn Log.w(TAG, "No process " + ss.mProcessName + "/" + uids.keyAt(iu) 5205635594c38fb319e050054e42109eb736f274accDianne Hackborn + " for service " + ss.mName); 5215635594c38fb319e050054e42109eb736f274accDianne Hackborn } 5225635594c38fb319e050054e42109eb736f274accDianne Hackborn } 5235635594c38fb319e050054e42109eb736f274accDianne Hackborn } 5245635594c38fb319e050054e42109eb736f274accDianne Hackborn } 5255635594c38fb319e050054e42109eb736f274accDianne Hackborn } 5265635594c38fb319e050054e42109eb736f274accDianne Hackborn } 5275635594c38fb319e050054e42109eb736f274accDianne Hackborn 5285635594c38fb319e050054e42109eb736f274accDianne Hackborn /* 5295635594c38fb319e050054e42109eb736f274accDianne Hackborn SparseArray<ArrayMap<String, ProcStatsEntry>> processes 5305635594c38fb319e050054e42109eb736f274accDianne Hackborn = new SparseArray<ArrayMap<String, ProcStatsEntry>>(); 531a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn for (int ip=0, N=mStats.mProcesses.getMap().size(); ip<N; ip++) { 532a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn SparseArray<ProcessStats.ProcessState> uids = mStats.mProcesses.getMap().valueAt(ip); 533a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn for (int iu=0; iu<uids.size(); iu++) { 5345635594c38fb319e050054e42109eb736f274accDianne Hackborn ProcessStats.ProcessState st = uids.valueAt(iu); 5355635594c38fb319e050054e42109eb736f274accDianne Hackborn ProcStatsEntry ent = new ProcStatsEntry(st, totals, mUseUss, 53649759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mStatsType == MENU_TYPE_BACKGROUND); 5375635594c38fb319e050054e42109eb736f274accDianne Hackborn if (ent.mDuration > 0) { 5385635594c38fb319e050054e42109eb736f274accDianne Hackborn if (DEBUG) Log.d(TAG, "Adding proc " + st.mName + "/" + st.mUid + ": time=" 5395635594c38fb319e050054e42109eb736f274accDianne Hackborn + makeDuration(ent.mDuration) + " (" 540b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn + ((((double)ent.mDuration) / memTotalTime) * 100) + "%)"); 5415635594c38fb319e050054e42109eb736f274accDianne Hackborn procs.add(ent); 5425635594c38fb319e050054e42109eb736f274accDianne Hackborn ArrayMap<String, ProcStatsEntry> uidProcs = processes.get(ent.mUid); 5435635594c38fb319e050054e42109eb736f274accDianne Hackborn if (uidProcs == null) { 5445635594c38fb319e050054e42109eb736f274accDianne Hackborn uidProcs = new ArrayMap<String, ProcStatsEntry>(); 5455635594c38fb319e050054e42109eb736f274accDianne Hackborn processes.put(ent.mUid, uidProcs); 5465635594c38fb319e050054e42109eb736f274accDianne Hackborn } 5475635594c38fb319e050054e42109eb736f274accDianne Hackborn uidProcs.put(ent.mName, ent); 5485635594c38fb319e050054e42109eb736f274accDianne Hackborn } 549c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn } 550a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn } 5515635594c38fb319e050054e42109eb736f274accDianne Hackborn */ 552a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn 5535635594c38fb319e050054e42109eb736f274accDianne Hackborn Collections.sort(entries, sEntryCompare); 554c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn 5555635594c38fb319e050054e42109eb736f274accDianne Hackborn long maxWeight = 1; 5565635594c38fb319e050054e42109eb736f274accDianne Hackborn for (int i=0, N=(entries != null ? entries.size() : 0); i<N; i++) { 5575635594c38fb319e050054e42109eb736f274accDianne Hackborn ProcStatsEntry proc = entries.get(i); 558c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn if (maxWeight < proc.mWeight) { 559c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn maxWeight = proc.mWeight; 560c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn } 561c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn } 56204486738342fa5e11a78df836efe34b85bee125aDianne Hackborn mMaxWeight = maxWeight; 563c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn 5645635594c38fb319e050054e42109eb736f274accDianne Hackborn if (DEBUG) Log.d(TAG, "-------------------- BUILDING UI"); 5655635594c38fb319e050054e42109eb736f274accDianne Hackborn 5665635594c38fb319e050054e42109eb736f274accDianne Hackborn for (int i=0, N=(entries != null ? entries.size() : 0); i<N; i++) { 5675635594c38fb319e050054e42109eb736f274accDianne Hackborn ProcStatsEntry proc = entries.get(i); 568c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn final double percentOfWeight = (((double)proc.mWeight) / maxWeight) * 100; 569b1e33884190732a58bfbfe659898e02d41fe39f4Dianne Hackborn final double percentOfTime = (((double)proc.mDuration) / memTotalTime) * 100; 5705635594c38fb319e050054e42109eb736f274accDianne Hackborn if (percentOfWeight < 1 && percentOfTime < 33) { 5715635594c38fb319e050054e42109eb736f274accDianne Hackborn if (DEBUG) Log.d(TAG, "Skipping " + proc.mName + " weight=" + percentOfWeight 5725635594c38fb319e050054e42109eb736f274accDianne Hackborn + " time=" + percentOfTime); 5735635594c38fb319e050054e42109eb736f274accDianne Hackborn continue; 5745635594c38fb319e050054e42109eb736f274accDianne Hackborn } 57504486738342fa5e11a78df836efe34b85bee125aDianne Hackborn ProcessStatsPreference pref = new ProcessStatsPreference(getActivity(), null, proc); 5765635594c38fb319e050054e42109eb736f274accDianne Hackborn proc.evaluateTargetPackage(pm, mStats, totals, sEntryCompare, mUseUss, 57749759af6b06b884d3a1af9dbb120370893744b94Dianne Hackborn mStatsType == MENU_TYPE_BACKGROUND); 57804486738342fa5e11a78df836efe34b85bee125aDianne Hackborn proc.retrieveUiData(pm); 57904486738342fa5e11a78df836efe34b85bee125aDianne Hackborn pref.setTitle(proc.mUiLabel); 58004486738342fa5e11a78df836efe34b85bee125aDianne Hackborn if (proc.mUiTargetApp != null) { 58104486738342fa5e11a78df836efe34b85bee125aDianne Hackborn pref.setIcon(proc.mUiTargetApp.loadIcon(pm)); 582c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 583c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn pref.setOrder(i); 584c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn pref.setPercent(percentOfWeight, percentOfTime); 585c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn mAppListGroup.addPreference(pref); 5865635594c38fb319e050054e42109eb736f274accDianne Hackborn if (mAppListGroup.getPreferenceCount() > (MAX_ITEMS_TO_LIST+1)) { 5875635594c38fb319e050054e42109eb736f274accDianne Hackborn if (DEBUG) Log.d(TAG, "Done with UI, hit item limit!"); 5885635594c38fb319e050054e42109eb736f274accDianne Hackborn break; 58904436c51f63492944bbed276021a51cfe2081613Dianne Hackborn } 59004436c51f63492944bbed276021a51cfe2081613Dianne Hackborn } 591c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 592c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn 593c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn private void load() { 594c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn try { 59588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mLastDuration = mDuration; 596a582a051951be9b1afd57e05fd6a405bccd9a46fDianne Hackborn mMemState = mProcessStats.getCurrentMemoryState(); 59788cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn ParcelFileDescriptor pfd = mProcessStats.getStatsOverTime(mDuration); 59888cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mStats = new ProcessStats(false); 59988cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn InputStream is = new ParcelFileDescriptor.AutoCloseInputStream(pfd); 60088cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn mStats.read(is); 60188cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn try { 60288cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn is.close(); 60388cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn } catch (IOException e) { 604c9e4bd111664705959716629c2535c085e6c7cd6Dianne Hackborn } 60588cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn if (mStats.mReadError != null) { 60688cf7709cb7ed829980cb8ddac3d5c7ac945d772Dianne Hackborn Log.w(TAG, "Failure reading process stats: " + mStats.mReadError); 607c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 608c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } catch (RemoteException e) { 609c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn Log.e(TAG, "RemoteException:", e); 610c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 611c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn } 612c6d658e37d7c0ab2d264fff4850ea20823669558Dianne Hackborn} 613