10825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville/*
20825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Copyright (C) 2012 The Android Open Source Project
30825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville *
40825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Licensed under the Apache License, Version 2.0 (the "License");
50825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * you may not use this file except in compliance with the License.
60825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * You may obtain a copy of the License at
70825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville *
80825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville *      http://www.apache.org/licenses/LICENSE-2.0
90825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville *
100825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Unless required by applicable law or agreed to in writing, software
110825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * distributed under the License is distributed on an "AS IS" BASIS,
120825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
130825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * See the License for the specific language governing permissions and
140825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * limitations under the License.
150825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville */
160825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
170825495a331bb44df395a0cdb79fab85e68db5d5Wink Savillepackage com.android.internal.telephony;
180825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
19ded9c0af7fa49504c047275ed34c2d3b22bf0c3aWink Savilleimport android.telephony.Rlog;
200825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
2105ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenkaimport com.android.internal.telephony.uicc.UiccController;
2205ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenkaimport com.android.internal.telephony.uicc.IccCardProxy;
2305ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka
240825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport java.io.FileDescriptor;
250825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport java.io.PrintWriter;
260825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
270825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville/**
280825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * A debug service that will dump telephony's state
290825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville *
300825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * Currently this "Service" has a proxy in the phone app
310825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * com.android.phone.TelephonyDebugService which actually
320825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * invokes the dump method.
330825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville */
340825495a331bb44df395a0cdb79fab85e68db5d5Wink Savillepublic class DebugService {
350825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    private static String TAG = "DebugService";
360825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
370825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    /** Constructor */
380825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    public DebugService() {
390825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        log("DebugService:");
400825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    }
410825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
420825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    /**
430825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville     * Dump the state of various objects, add calls to other objects as desired.
440825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville     */
450825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    public void dump(FileDescriptor fd, PrintWriter pw, String[] args) {
460825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        log("dump: +");
470825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        PhoneProxy phoneProxy = null;
480825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        PhoneBase phoneBase = null;
490825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
500825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
510825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneProxy = (PhoneProxy) PhoneFactory.getDefaultPhone();
520825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
530825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            pw.println("Telephony DebugService: Could not getDefaultPhone e=" + e);
540825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            return;
550825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
560825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
570825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneBase = (PhoneBase)phoneProxy.getActivePhone();
580825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
590825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            pw.println("Telephony DebugService: Could not PhoneBase e=" + e);
600825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            return;
610825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
620825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
630825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        /**
640825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville         * Surround each of the sub dump's with try/catch so even
650825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville         * if one fails we'll be able to dump the next ones.
660825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville         */
670825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println();
680825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
690825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
700825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
710825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneBase.dump(fd, pw, args);
720825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
730825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
740825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
750825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
760825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
770825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
78454b1dfd508844b42eb775e4ab2359be74d3672bWink Saville            phoneBase.mDcTracker.dump(fd, pw, args);
790825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
800825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
810825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
820825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
830825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
840825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
850825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneBase.getServiceStateTracker().dump(fd, pw, args);
860825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
870825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
880825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
890825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
900825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
910825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
920825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            phoneBase.getCallTracker().dump(fd, pw, args);
930825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
940825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
950825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
960825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
970825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
980825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        try {
9922d85a8e3a575a6d01d2c788587971657dfe20c6Wink Saville            ((RIL)phoneBase.mCi).dump(fd, pw, args);
1000825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        } catch (Exception e) {
1010825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville            e.printStackTrace();
1020825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        }
1030825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.flush();
1040825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        pw.println("++++++++++++++++++++++++++++++++");
10505ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        try {
10605ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka            UiccController.getInstance().dump(fd, pw, args);
10705ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        } catch (Exception e) {
10805ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka            e.printStackTrace();
10905ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        }
11005ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        pw.flush();
11105ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        pw.println("++++++++++++++++++++++++++++++++");
11205ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        try {
11305ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka            ((IccCardProxy)phoneProxy.getIccCard()).dump(fd, pw, args);
11405ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        } catch (Exception e) {
11505ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka            e.printStackTrace();
11605ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        }
11705ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        pw.flush();
11805ef3b65972826780859b9acbd1fa9580d099832Alex Yakavenka        pw.println("++++++++++++++++++++++++++++++++");
1190825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville        log("dump: -");
1200825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    }
1210825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville
1220825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    private static void log(String s) {
123ded9c0af7fa49504c047275ed34c2d3b22bf0c3aWink Saville        Rlog.d(TAG, "DebugService " + s);
1240825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville    }
1250825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville}
126