10825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville/* 20825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville** Copyright 2007, 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.cdma; 180825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 190825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport java.util.concurrent.atomic.AtomicBoolean; 200825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 210825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport android.os.Message; 220825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport android.util.Log; 230825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 24e0e2ebb5a50e580cbe6957dcafb3495a2d0a27f2Alex Yakavenkaimport com.android.internal.telephony.IccFileHandler; 250825495a331bb44df395a0cdb79fab85e68db5d5Wink Savilleimport com.android.internal.telephony.IccPhoneBookInterfaceManager; 260825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 270825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville/** 280825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * RuimPhoneBookInterfaceManager to provide an inter-process communication to 290825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville * access ADN-like SIM records. 300825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville */ 310825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 320825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 330825495a331bb44df395a0cdb79fab85e68db5d5Wink Savillepublic class RuimPhoneBookInterfaceManager extends IccPhoneBookInterfaceManager { 340825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville static final String LOG_TAG = "CDMA"; 350825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 360825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville public RuimPhoneBookInterfaceManager(CDMAPhone phone) { 370825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville super(phone); 380825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville //NOTE service "simphonebook" added by IccSmsInterfaceManagerProxy 390825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 400825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 410825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville public void dispose() { 420825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville super.dispose(); 430825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 440825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 450825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville protected void finalize() { 460825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville try { 470825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville super.finalize(); 480825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } catch (Throwable throwable) { 490825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville Log.e(LOG_TAG, "Error while finalizing:", throwable); 500825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 510825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville if(DBG) Log.d(LOG_TAG, "RuimPhoneBookInterfaceManager finalized"); 520825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 530825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 540825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville public int[] getAdnRecordsSize(int efid) { 550825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville if (DBG) logd("getAdnRecordsSize: efid=" + efid); 560825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville synchronized(mLock) { 570825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville checkThread(); 580825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville recordSize = new int[3]; 590825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 600825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville //Using mBaseHandler, no difference in EVENT_GET_SIZE_DONE handling 610825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville AtomicBoolean status = new AtomicBoolean(false); 620825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville Message response = mBaseHandler.obtainMessage(EVENT_GET_SIZE_DONE, status); 630825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 64e0e2ebb5a50e580cbe6957dcafb3495a2d0a27f2Alex Yakavenka IccFileHandler fh = phone.getIccFileHandler(); 65e0e2ebb5a50e580cbe6957dcafb3495a2d0a27f2Alex Yakavenka //IccFileHandler can be null if there is no icc card present. 66e0e2ebb5a50e580cbe6957dcafb3495a2d0a27f2Alex Yakavenka if (fh != null) { 67e0e2ebb5a50e580cbe6957dcafb3495a2d0a27f2Alex Yakavenka fh.getEFLinearRecordSize(efid, response); 68e0e2ebb5a50e580cbe6957dcafb3495a2d0a27f2Alex Yakavenka waitForResult(status); 69e0e2ebb5a50e580cbe6957dcafb3495a2d0a27f2Alex Yakavenka } 700825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 710825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 720825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville return recordSize; 730825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 740825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 750825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville protected void logd(String msg) { 760825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville Log.d(LOG_TAG, "[RuimPbInterfaceManager] " + msg); 770825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 780825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 790825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville protected void loge(String msg) { 800825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville Log.e(LOG_TAG, "[RuimPbInterfaceManager] " + msg); 810825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville } 820825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville} 830825495a331bb44df395a0cdb79fab85e68db5d5Wink Saville 84