ServiceRecord.java revision 91268cf21eace600792d04db1ac62e9268f48002
19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2006 The Android Open Source Project
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License.
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License.
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage com.android.server.am;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport com.android.internal.os.BatteryStatsImpl;
20d0a2f86f357f346639a6648b4004266865c979b4Daniel Sandlerimport com.android.server.NotificationManagerService;
219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
22d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackbornimport android.app.INotificationManager;
23d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackbornimport android.app.Notification;
24d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackbornimport android.app.NotificationManager;
25390517be2d60dd6e6264150c190c372d89bb331aDianne Hackbornimport android.app.PendingIntent;
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.ComponentName;
270c3804950236fe170ebf6cc7a5f1e3e305b8f315Dianne Hackbornimport android.content.Context;
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.Intent;
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ApplicationInfo;
30742a67127366c376fdf188ff99ba30b27d3bf90cAmith Yamasaniimport android.content.pm.PackageManager;
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.content.pm.ServiceInfo;
32390517be2d60dd6e6264150c190c372d89bb331aDianne Hackbornimport android.net.Uri;
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.Binder;
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.IBinder;
35d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackbornimport android.os.RemoteException;
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.os.SystemClock;
37f02b60aa4f367516f40cf3d60fffae0c6fe3e1b8Dianne Hackbornimport android.os.UserHandle;
38390517be2d60dd6e6264150c190c372d89bb331aDianne Hackbornimport android.provider.Settings;
39390517be2d60dd6e6264150c190c372d89bb331aDianne Hackbornimport android.util.ArrayMap;
408a9b22056b13477f59df934928c00c58b5871c95Joe Onoratoimport android.util.Slog;
411ebccf531d1049853b3b0630035434619682c016Dianne Hackbornimport android.util.TimeUtils;
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.io.PrintWriter;
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.util.ArrayList;
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport java.util.List;
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * A running application service.
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
50be4e6aaa0252dd7da28b7aa85beba982538efa46Dianne Hackbornfinal class ServiceRecord extends Binder {
5139792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn    // Maximum number of delivery attempts before giving up.
5239792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn    static final int MAX_DELIVERY_COUNT = 3;
5339792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
5439792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn    // Maximum number of times it can fail during execution before giving up.
5539792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn    static final int MAX_DONE_EXECUTING_COUNT = 6;
5639792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
57b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn    final ActivityManagerService ams;
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final BatteryStatsImpl.Uid.Pkg.Serv stats;
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final ComponentName name; // service component.
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final String shortName; // name.flattenToShortString().
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final Intent.FilterComparison intent;
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                            // original intent used to find service.
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final ServiceInfo serviceInfo;
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                            // all information about the service.
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final ApplicationInfo appInfo;
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                            // information about service's app.
67742a67127366c376fdf188ff99ba30b27d3bf90cAmith Yamasani    final int userId;       // user that this service is running as
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final String packageName; // the package implementing intent's component
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final String processName; // process where this component wants to run
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final String permission;// permission needed to access service
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final String baseDir;   // where activity source (resources etc) located
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final String resDir;   // where public activity source (public resources etc) located
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final String dataDir;   // where activity data should go
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final boolean exported; // from ServiceInfo.exported
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final Runnable restarter; // used to schedule retries of starting the service
7691268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn    final ProcessTracker.ServiceState tracker; // tracking service execution, may be null
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    final long createTime;  // when this service was created
78390517be2d60dd6e6264150c190c372d89bb331aDianne Hackborn    final ArrayMap<Intent.FilterComparison, IntentBindRecord> bindings
79390517be2d60dd6e6264150c190c372d89bb331aDianne Hackborn            = new ArrayMap<Intent.FilterComparison, IntentBindRecord>();
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                            // All active bindings to the service.
81390517be2d60dd6e6264150c190c372d89bb331aDianne Hackborn    final ArrayMap<IBinder, ArrayList<ConnectionRecord>> connections
82390517be2d60dd6e6264150c190c372d89bb331aDianne Hackborn            = new ArrayMap<IBinder, ArrayList<ConnectionRecord>>();
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project                            // IBinder -> ConnectionRecord of all bound clients
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
85d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn    ProcessRecord app;      // where this service is running or null.
86a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn    ProcessRecord isolatedProc; // keep track of isolated process, if requested
87d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn    boolean isForeground;   // is service currently in foreground mode?
88d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn    int foregroundId;       // Notification ID of last foreground req.
89d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn    Notification foregroundNoti; // Notification record of foreground state.
909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    long lastActivity;      // last time there was some activity on the service.
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    boolean startRequested; // someone explicitly called start?
92f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn    boolean stopIfKilled;   // last onStart() said to stop if service killed?
93f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn    boolean callStart;      // last onStart() has asked to alway be called on restart.
949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int executeNesting;     // number of outstanding operations keeping foreground.
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    long executingStart;    // start time of last execute request.
969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int crashCount;         // number of times proc has crashed with service running
979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int totalRestartCount;  // number of times we have had to restart.
989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    int restartCount;       // number of restarts performed in a row.
999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    long restartDelay;      // delay until next restart attempt.
1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    long restartTime;       // time of last restart.
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    long nextRestartTime;   // time when restartDelay will expire.
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
103f210d6b75e2c0fe60b90c074ff9f615c1137f23eDianne Hackborn    String stringName;      // caching of toString
104f210d6b75e2c0fe60b90c074ff9f615c1137f23eDianne Hackborn
1050c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn    private int lastStartId;    // identifier of most recent start request.
1060c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn
1077e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn    static class StartItem {
10839792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        final ServiceRecord sr;
1090c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn        final boolean taskRemoved;
11039792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        final int id;
11139792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        final Intent intent;
11221c241e061de29a538008ca42df9c878184bcfb8Dianne Hackborn        final ActivityManagerService.NeededUriGrants neededGrants;
11339792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        long deliveredTime;
11439792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        int deliveryCount;
11539792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        int doneExecutingCount;
1167e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn        UriPermissionOwner uriPermissions;
11739792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
11839792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        String stringName;      // caching of toString
11939792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
1200c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn        StartItem(ServiceRecord _sr, boolean _taskRemoved, int _id, Intent _intent,
12121c241e061de29a538008ca42df9c878184bcfb8Dianne Hackborn                ActivityManagerService.NeededUriGrants _neededGrants) {
12239792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            sr = _sr;
1230c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn            taskRemoved = _taskRemoved;
12439792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            id = _id;
12539792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            intent = _intent;
12621c241e061de29a538008ca42df9c878184bcfb8Dianne Hackborn            neededGrants = _neededGrants;
12739792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        }
12839792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
1297e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn        UriPermissionOwner getUriPermissionsLocked() {
1307e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn            if (uriPermissions == null) {
1317e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                uriPermissions = new UriPermissionOwner(sr.ams, this);
13239792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            }
1337e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn            return uriPermissions;
13439792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        }
13539792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
1367e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn        void removeUriPermissionsLocked() {
1377e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn            if (uriPermissions != null) {
1387e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                uriPermissions.removeUriPermissionsLocked();
1397e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                uriPermissions = null;
14039792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            }
14139792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        }
14239792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
14339792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        public String toString() {
14439792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            if (stringName != null) {
14539792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn                return stringName;
14639792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            }
14739792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            StringBuilder sb = new StringBuilder(128);
14839792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            sb.append("ServiceRecord{")
14939792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn                .append(Integer.toHexString(System.identityHashCode(sr)))
15039792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn                .append(' ').append(sr.shortName)
15139792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn                .append(" StartItem ")
15239792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn                .append(Integer.toHexString(System.identityHashCode(this)))
15339792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn                .append(" id=").append(id).append('}');
15439792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            return stringName = sb.toString();
15539792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        }
15639792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn    }
15739792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
15839792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn    final ArrayList<StartItem> deliveredStarts = new ArrayList<StartItem>();
15939792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn                            // start() arguments which been delivered.
16039792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn    final ArrayList<StartItem> pendingStarts = new ArrayList<StartItem>();
16139792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn                            // start() arguments that haven't yet been delivered.
16239792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
163f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn    void dumpStartList(PrintWriter pw, String prefix, List<StartItem> list, long now) {
164f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        final int N = list.size();
165f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        for (int i=0; i<N; i++) {
166f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn            StartItem si = list.get(i);
167f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn            pw.print(prefix); pw.print("#"); pw.print(i);
168f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                    pw.print(" id="); pw.print(si.id);
1691ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                    if (now != 0) {
1701ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                        pw.print(" dur=");
1711ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                        TimeUtils.formatDuration(si.deliveredTime, now, pw);
1721ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                    }
173f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                    if (si.deliveryCount != 0) {
174f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                        pw.print(" dc="); pw.print(si.deliveryCount);
175f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                    }
176f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                    if (si.doneExecutingCount != 0) {
177f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                        pw.print(" dxc="); pw.print(si.doneExecutingCount);
178f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                    }
17939792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn                    pw.println("");
18039792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            pw.print(prefix); pw.print("  intent=");
181f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                    if (si.intent != null) pw.println(si.intent.toString());
182f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                    else pw.println("null");
18321c241e061de29a538008ca42df9c878184bcfb8Dianne Hackborn            if (si.neededGrants != null) {
18421c241e061de29a538008ca42df9c878184bcfb8Dianne Hackborn                pw.print(prefix); pw.print("  neededGrants=");
18521c241e061de29a538008ca42df9c878184bcfb8Dianne Hackborn                        pw.println(si.neededGrants);
18639792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            }
1877e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn            if (si.uriPermissions != null) {
1887e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                if (si.uriPermissions.readUriPermissions != null) {
1897e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                    pw.print(prefix); pw.print("  readUriPermissions=");
1907e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                            pw.println(si.uriPermissions.readUriPermissions);
1917e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                }
1927e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                if (si.uriPermissions.writeUriPermissions != null) {
1937e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                    pw.print(prefix); pw.print("  writeUriPermissions=");
1947e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                            pw.println(si.uriPermissions.writeUriPermissions);
1957e269644fcc319835f1e7f762f3cbd8087e3e22fDianne Hackborn                }
19639792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            }
197f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        }
198f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn    }
199f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn
2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    void dump(PrintWriter pw, String prefix) {
2011d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        pw.print(prefix); pw.print("intent={");
20221c241e061de29a538008ca42df9c878184bcfb8Dianne Hackborn                pw.print(intent.getIntent().toShortString(false, true, false, true));
2031d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                pw.println('}');
2041d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        pw.print(prefix); pw.print("packageName="); pw.println(packageName);
2051d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        pw.print(prefix); pw.print("processName="); pw.println(processName);
2061d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        if (permission != null) {
2071d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn            pw.print(prefix); pw.print("permission="); pw.println(permission);
2081d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        }
209fd12af4e768fec852c4c5dfee3b9bd7403b4b347Dianne Hackborn        long now = SystemClock.uptimeMillis();
2101ebccf531d1049853b3b0630035434619682c016Dianne Hackborn        long nowReal = SystemClock.elapsedRealtime();
2111ebccf531d1049853b3b0630035434619682c016Dianne Hackborn        pw.print(prefix); pw.print("baseDir="); pw.println(baseDir);
212a301fe61c8573c06be754d5788a84d19188ee2d3Marco Nelissen        if (!resDir.equals(baseDir)) {
213a301fe61c8573c06be754d5788a84d19188ee2d3Marco Nelissen            pw.print(prefix); pw.print("resDir="); pw.println(resDir);
214a301fe61c8573c06be754d5788a84d19188ee2d3Marco Nelissen        }
2151ebccf531d1049853b3b0630035434619682c016Dianne Hackborn        pw.print(prefix); pw.print("dataDir="); pw.println(dataDir);
2161d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        pw.print(prefix); pw.print("app="); pw.println(app);
217a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn        if (isolatedProc != null) {
218a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn            pw.print(prefix); pw.print("isolatedProc="); pw.println(isolatedProc);
219a0c283eac33dd2da72235751bbfa4f2d9898d5eaDianne Hackborn        }
220d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        if (isForeground || foregroundId != 0) {
221d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn            pw.print(prefix); pw.print("isForeground="); pw.print(isForeground);
222d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn                    pw.print(" foregroundId="); pw.print(foregroundId);
223d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn                    pw.print(" foregroundNoti="); pw.println(foregroundNoti);
224d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        }
2259adb9c3b10991ef315c270993f4155709c8a232dDianne Hackborn        pw.print(prefix); pw.print("createTime=");
2261ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                TimeUtils.formatDuration(createTime, nowReal, pw);
2271ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                pw.print(" lastActivity=");
2281ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                TimeUtils.formatDuration(lastActivity, now, pw);
2291ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                pw.println("");
230e17aeb31030cfeed339a39a107912ad5e9178390Dianne Hackborn        pw.print(prefix); pw.print("executingStart=");
2311ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                TimeUtils.formatDuration(executingStart, now, pw);
2321ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                pw.print(" restartTime=");
2331ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                TimeUtils.formatDuration(restartTime, now, pw);
2341ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                pw.println("");
235d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        if (startRequested || lastStartId != 0) {
236d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn            pw.print(prefix); pw.print("startRequested="); pw.print(startRequested);
237f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                    pw.print(" stopIfKilled="); pw.print(stopIfKilled);
238f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                    pw.print(" callStart="); pw.print(callStart);
239d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn                    pw.print(" lastStartId="); pw.println(lastStartId);
240d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        }
241d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        if (executeNesting != 0 || crashCount != 0 || restartCount != 0
242d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn                || restartDelay != 0 || nextRestartTime != 0) {
243d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn            pw.print(prefix); pw.print("executeNesting="); pw.print(executeNesting);
244d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn                    pw.print(" restartCount="); pw.print(restartCount);
2451ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                    pw.print(" restartDelay=");
2461ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                    TimeUtils.formatDuration(restartDelay, now, pw);
2471ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                    pw.print(" nextRestartTime=");
2481ebccf531d1049853b3b0630035434619682c016Dianne Hackborn                    TimeUtils.formatDuration(nextRestartTime, now, pw);
249d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn                    pw.print(" crashCount="); pw.println(crashCount);
250d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        }
251f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        if (deliveredStarts.size() > 0) {
252f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn            pw.print(prefix); pw.println("Delivered Starts:");
2531ebccf531d1049853b3b0630035434619682c016Dianne Hackborn            dumpStartList(pw, prefix, deliveredStarts, now);
254f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        }
255f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        if (pendingStarts.size() > 0) {
256f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn            pw.print(prefix); pw.println("Pending Starts:");
257f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn            dumpStartList(pw, prefix, pendingStarts, 0);
258f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        }
2599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (bindings.size() > 0) {
260f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn            pw.print(prefix); pw.println("Bindings:");
261390517be2d60dd6e6264150c190c372d89bb331aDianne Hackborn            for (int i=0; i<bindings.size(); i++) {
262390517be2d60dd6e6264150c190c372d89bb331aDianne Hackborn                IntentBindRecord b = bindings.valueAt(i);
2631d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                pw.print(prefix); pw.print("* IntentBindRecord{");
2641d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                        pw.print(Integer.toHexString(System.identityHashCode(b)));
2650c3804950236fe170ebf6cc7a5f1e3e305b8f315Dianne Hackborn                        if ((b.collectFlags()&Context.BIND_AUTO_CREATE) != 0) {
2660c3804950236fe170ebf6cc7a5f1e3e305b8f315Dianne Hackborn                            pw.append(" CREATE");
2670c3804950236fe170ebf6cc7a5f1e3e305b8f315Dianne Hackborn                        }
2681d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                        pw.println("}:");
2691d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                b.dumpInService(pw, prefix + "  ");
2709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (connections.size() > 0) {
2731d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn            pw.print(prefix); pw.println("All Connections:");
274390517be2d60dd6e6264150c190c372d89bb331aDianne Hackborn            for (int conni=0; conni<connections.size(); conni++) {
275390517be2d60dd6e6264150c190c372d89bb331aDianne Hackborn                ArrayList<ConnectionRecord> c = connections.valueAt(conni);
27643d9ac81f7722bb539ee67023f10b9f43abbf202Dianne Hackborn                for (int i=0; i<c.size(); i++) {
27743d9ac81f7722bb539ee67023f10b9f43abbf202Dianne Hackborn                    pw.print(prefix); pw.print("  "); pw.println(c.get(i));
27843d9ac81f7722bb539ee67023f10b9f43abbf202Dianne Hackborn                }
2799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            }
2809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
2819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
2829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
283b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn    ServiceRecord(ActivityManagerService ams,
284b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            BatteryStatsImpl.Uid.Pkg.Serv servStats, ComponentName name,
28591268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn            Intent.FilterComparison intent, ServiceInfo sInfo, Runnable restarter,
28691268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn            ProcessTracker.ServiceState tracker) {
287b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn        this.ams = ams;
2889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        this.stats = servStats;
2899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        this.name = name;
2909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        shortName = name.flattenToShortString();
2919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        this.intent = intent;
2929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        serviceInfo = sInfo;
2939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        appInfo = sInfo.applicationInfo;
2949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        packageName = sInfo.applicationInfo.packageName;
2959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        processName = sInfo.processName;
2969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        permission = sInfo.permission;
2979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        baseDir = sInfo.applicationInfo.sourceDir;
2989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        resDir = sInfo.applicationInfo.publicSourceDir;
2999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        dataDir = sInfo.applicationInfo.dataDir;
3009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        exported = sInfo.exported;
3019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        this.restarter = restarter;
30291268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn        this.tracker = tracker;
3039adb9c3b10991ef315c270993f4155709c8a232dDianne Hackborn        createTime = SystemClock.elapsedRealtime();
3049adb9c3b10991ef315c270993f4155709c8a232dDianne Hackborn        lastActivity = SystemClock.uptimeMillis();
305f02b60aa4f367516f40cf3d60fffae0c6fe3e1b8Dianne Hackborn        userId = UserHandle.getUserId(appInfo.uid);
3069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
3089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public AppBindRecord retrieveAppBindingLocked(Intent intent,
3099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            ProcessRecord app) {
3109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        Intent.FilterComparison filter = new Intent.FilterComparison(intent);
3119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        IntentBindRecord i = bindings.get(filter);
3129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (i == null) {
3139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            i = new IntentBindRecord(this, filter);
3149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            bindings.put(filter, i);
3159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        AppBindRecord a = i.apps.get(app);
3179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (a != null) {
3189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return a;
3199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
3209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        a = new AppBindRecord(this, i, app);
3219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        i.apps.put(app, a);
3229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return a;
3239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
32591268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn    public boolean hasAutoCreateConnections() {
32691268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn        // XXX should probably keep a count of the number of auto-create
32791268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn        // connections directly in the service.
32891268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn        for (int conni=connections.size()-1; conni>=0; conni--) {
32991268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn            ArrayList<ConnectionRecord> cr = connections.valueAt(conni);
33091268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn            for (int i=0; i<cr.size(); i++) {
33191268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn                if ((cr.get(i).flags&Context.BIND_AUTO_CREATE) != 0) {
33291268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn                    return true;
33391268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn                }
33491268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn            }
33591268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn        }
33691268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn        return false;
33791268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn    }
33891268cf21eace600792d04db1ac62e9268f48002Dianne Hackborn
3399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void resetRestartCounter() {
3409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        restartCount = 0;
3419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        restartDelay = 0;
3429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        restartTime = 0;
3439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
3449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
345f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn    public StartItem findDeliveredStart(int id, boolean remove) {
346f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        final int N = deliveredStarts.size();
347f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        for (int i=0; i<N; i++) {
348f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn            StartItem si = deliveredStarts.get(i);
349f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn            if (si.id == id) {
350f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                if (remove) deliveredStarts.remove(i);
351f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn                return si;
352f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn            }
353f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        }
354f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn
355f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn        return null;
356f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn    }
357f6f9f2d0256930ce0bb4913b2260b8480914edc2Dianne Hackborn
3580c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn    public int getLastStartId() {
3590c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn        return lastStartId;
3600c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn    }
3610c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn
3620c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn    public int makeNextStartId() {
3630c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn        lastStartId++;
3640c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn        if (lastStartId < 1) {
3650c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn            lastStartId = 1;
3660c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn        }
3670c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn        return lastStartId;
3680c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn    }
3690c5001d776d56bae02a5cc2663286a125d99bc5eDianne Hackborn
370d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn    public void postNotification() {
371d0a2f86f357f346639a6648b4004266865c979b4Daniel Sandler        final int appUid = appInfo.uid;
372d0a2f86f357f346639a6648b4004266865c979b4Daniel Sandler        final int appPid = app.pid;
373d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        if (foregroundId != 0 && foregroundNoti != null) {
374b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            // Do asynchronous communication with notification manager to
375b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            // avoid deadlocks.
376b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            final String localPackageName = packageName;
377b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            final int localForegroundId = foregroundId;
378b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            final Notification localForegroundNoti = foregroundNoti;
379b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            ams.mHandler.post(new Runnable() {
380b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                public void run() {
381d0a2f86f357f346639a6648b4004266865c979b4Daniel Sandler                    NotificationManagerService nm =
382d0a2f86f357f346639a6648b4004266865c979b4Daniel Sandler                            (NotificationManagerService) NotificationManager.getService();
383d0a2f86f357f346639a6648b4004266865c979b4Daniel Sandler                    if (nm == null) {
384b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                        return;
385b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                    }
386b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                    try {
387ca92a4c38f8b4763cd72690091b3a5bbbd7c973aDianne Hackborn                        if (localForegroundNoti.icon == 0) {
3882ced96c54445efca6522afd1878f79c9ee2780baDianne Hackborn                            // It is not correct for the caller to supply a notification
3892ced96c54445efca6522afd1878f79c9ee2780baDianne Hackborn                            // icon, but this used to be able to slip through, so for
3902ced96c54445efca6522afd1878f79c9ee2780baDianne Hackborn                            // those dirty apps give it the app's icon.
391ca92a4c38f8b4763cd72690091b3a5bbbd7c973aDianne Hackborn                            localForegroundNoti.icon = appInfo.icon;
39291fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler
39391fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                            // Do not allow apps to present a sneaky invisible content view either.
394ca92a4c38f8b4763cd72690091b3a5bbbd7c973aDianne Hackborn                            localForegroundNoti.contentView = null;
395ca92a4c38f8b4763cd72690091b3a5bbbd7c973aDianne Hackborn                            localForegroundNoti.bigContentView = null;
39691fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                            CharSequence appName = appInfo.loadLabel(
39791fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                    ams.mContext.getPackageManager());
39891fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                            if (appName == null) {
39991fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                appName = appInfo.packageName;
40091fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                            }
40191fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                            Context ctx = null;
40291fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                            try {
40391fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                ctx = ams.mContext.createPackageContext(
40491fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                        appInfo.packageName, 0);
40591fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                Intent runningIntent = new Intent(
40691fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                        Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
40791fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                runningIntent.setData(Uri.fromParts("package",
40891fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                        appInfo.packageName, null));
40991fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                PendingIntent pi = PendingIntent.getActivity(ams.mContext, 0,
41091fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                        runningIntent, PendingIntent.FLAG_UPDATE_CURRENT);
411ca92a4c38f8b4763cd72690091b3a5bbbd7c973aDianne Hackborn                                localForegroundNoti.setLatestEventInfo(ctx,
41291fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                        ams.mContext.getString(
41391fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                                com.android.internal.R.string
41491fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                                        .app_running_notification_title,
41591fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                                appName),
41691fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                        ams.mContext.getString(
41791fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                                com.android.internal.R.string
41891fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                                        .app_running_notification_text,
41991fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                                appName),
42091fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                                        pi);
42191fe8455d66ef4ac000ba3ba0fb043dd1fbaee49Daniel Sandler                            } catch (PackageManager.NameNotFoundException e) {
422ca92a4c38f8b4763cd72690091b3a5bbbd7c973aDianne Hackborn                                localForegroundNoti.icon = 0;
4232ced96c54445efca6522afd1878f79c9ee2780baDianne Hackborn                            }
4242ced96c54445efca6522afd1878f79c9ee2780baDianne Hackborn                        }
425ca92a4c38f8b4763cd72690091b3a5bbbd7c973aDianne Hackborn                        if (localForegroundNoti.icon == 0) {
426282add7bc3e80825c73244f527857aefa74093a9Dianne Hackborn                            // Notifications whose icon is 0 are defined to not show
427282add7bc3e80825c73244f527857aefa74093a9Dianne Hackborn                            // a notification, silently ignoring it.  We don't want to
428282add7bc3e80825c73244f527857aefa74093a9Dianne Hackborn                            // just ignore it, we want to prevent the service from
429282add7bc3e80825c73244f527857aefa74093a9Dianne Hackborn                            // being foreground.
430282add7bc3e80825c73244f527857aefa74093a9Dianne Hackborn                            throw new RuntimeException("icon must be non-zero");
431282add7bc3e80825c73244f527857aefa74093a9Dianne Hackborn                        }
432b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                        int[] outId = new int[1];
433f265ea9d8307282ff1da3915978625a94fc2859eDianne Hackborn                        nm.enqueueNotificationInternal(localPackageName, localPackageName,
434f265ea9d8307282ff1da3915978625a94fc2859eDianne Hackborn                                appUid, appPid, null, localForegroundId, localForegroundNoti,
435f265ea9d8307282ff1da3915978625a94fc2859eDianne Hackborn                                outId, userId);
43634fcf971037f33605e8009946d3acc686819dd6dJoe Onorato                    } catch (RuntimeException e) {
4378a9b22056b13477f59df934928c00c58b5871c95Joe Onorato                        Slog.w(ActivityManagerService.TAG,
4389e0f5d9a63ba88c2bf69df0557f8c9696db370c4Dianne Hackborn                                "Error showing notification for service", e);
4399e0f5d9a63ba88c2bf69df0557f8c9696db370c4Dianne Hackborn                        // If it gave us a garbage notification, it doesn't
4409e0f5d9a63ba88c2bf69df0557f8c9696db370c4Dianne Hackborn                        // get to be foreground.
4419e0f5d9a63ba88c2bf69df0557f8c9696db370c4Dianne Hackborn                        ams.setServiceForeground(name, ServiceRecord.this,
442eaa0718780a29df8fbe42c59beecee5557fdf785Joe Onorato                                0, null, true);
443eaa0718780a29df8fbe42c59beecee5557fdf785Joe Onorato                        ams.crashApplication(appUid, appPid, localPackageName,
444eaa0718780a29df8fbe42c59beecee5557fdf785Joe Onorato                                "Bad notification for startForeground: " + e);
445b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                    }
446d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn                }
447b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            });
448d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        }
449d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn    }
450d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn
451d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn    public void cancelNotification() {
452d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        if (foregroundId != 0) {
453b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            // Do asynchronous communication with notification manager to
454b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            // avoid deadlocks.
455b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            final String localPackageName = packageName;
456b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            final int localForegroundId = foregroundId;
457b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            ams.mHandler.post(new Runnable() {
458b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                public void run() {
459b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                    INotificationManager inm = NotificationManager.getService();
460b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                    if (inm == null) {
461b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                        return;
462b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                    }
463b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                    try {
4644120375d46091df8527bb701882e056fbb0e6b06Dianne Hackborn                        inm.cancelNotificationWithTag(localPackageName, null,
4654120375d46091df8527bb701882e056fbb0e6b06Dianne Hackborn                                localForegroundId, userId);
46634fcf971037f33605e8009946d3acc686819dd6dJoe Onorato                    } catch (RuntimeException e) {
4678a9b22056b13477f59df934928c00c58b5871c95Joe Onorato                        Slog.w(ActivityManagerService.TAG,
4689e0f5d9a63ba88c2bf69df0557f8c9696db370c4Dianne Hackborn                                "Error canceling notification for service", e);
469b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                    } catch (RemoteException e) {
470b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn                    }
471d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn                }
472b1c4a2a3b37fccf68e6a9563cccf1685df2bf3e7Dianne Hackborn            });
473d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn        }
474d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn    }
475d8a43f61680bacf0d4b52a03ff3c7a07307377fcDianne Hackborn
47639792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn    public void clearDeliveredStartsLocked() {
47739792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        for (int i=deliveredStarts.size()-1; i>=0; i--) {
47839792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn            deliveredStarts.get(i).removeUriPermissionsLocked();
47939792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        }
48039792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn        deliveredStarts.clear();
48139792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn    }
48239792d2262352ae775091876d5488d2412a2ff92Dianne Hackborn
4839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public String toString() {
484f210d6b75e2c0fe60b90c074ff9f615c1137f23eDianne Hackborn        if (stringName != null) {
485f210d6b75e2c0fe60b90c074ff9f615c1137f23eDianne Hackborn            return stringName;
486f210d6b75e2c0fe60b90c074ff9f615c1137f23eDianne Hackborn        }
487f210d6b75e2c0fe60b90c074ff9f615c1137f23eDianne Hackborn        StringBuilder sb = new StringBuilder(128);
4881d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        sb.append("ServiceRecord{")
4891d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn            .append(Integer.toHexString(System.identityHashCode(this)))
490b12e1354f25f04e9c9a71da76c6fca858b7d39d0Dianne Hackborn            .append(" u").append(userId)
4911d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn            .append(' ').append(shortName).append('}');
492f210d6b75e2c0fe60b90c074ff9f615c1137f23eDianne Hackborn        return stringName = sb.toString();
4939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
4949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
495