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