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