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