RIL.java

E:\android-source\Android-2.3-Real6410-r1\Android-2.3-Real6410-r1\frameworks\base\telephony\java\com\android\internal\telephony\RIL.java

 

 

/*
	 * add for ptt
	 * @see com.tdtech.service.CommandsInterface#closeSocket()
	 */
	public void closeSocket(){
        try {
        	mSocket.shutdownInput();
        	mSocket.shutdownOutput();
        } catch (IOException ex) {
        }
        Log.w(LOG_TAG, "shutdown");
	}
	

	class RILSender extends Handler implements Runnable {
		public RILSender(Looper looper) {
			super(looper);
		}

		// Only allocated once
		byte[] dataLength = new byte[4];

		// ***** Runnable implementation
		public void run() {
			// setup if needed
		}

		// ***** Handler implemementation

		public void handleMessage(Message msg) {
			RILRequest rr = (RILRequest) (msg.obj);
			RILRequest req = null;

			switch (msg.what) {
			case EVENT_SEND:
				/**
				 * mRequestMessagePending++ already happened for every
				 * EVENT_SEND, thus we must make sure mRequestMessagePending--
				 * happens once and only once
				 */
				boolean alreadySubtracted = false;
				try {
					LocalSocket s;

					s = mSocket;

					if (s == null) {
						rr.onError(RADIO_NOT_AVAILABLE, null);
						rr.release();
						if (mRequestMessagesPending > 0)
							mRequestMessagesPending--;
						alreadySubtracted = true;
						return;
					}

					synchronized (mRequestsList) {
						mRequestsList.add(rr);
						mRequestMessagesWaiting++;
						Log.d(LOG_TAG, "mRequestsList size=" 
								+ mRequestsList.size()
								+ " mRequestMessagesWaiting="
								+ mRequestMessagesWaiting
								);
					}

					if (mRequestMessagesPending > 0)
						mRequestMessagesPending--;
					alreadySubtracted = true;

					byte[] data;

					data = rr.mp.marshall();
					rr.mp.recycle();
					rr.mp = null;

					if (data.length > RIL_MAX_COMMAND_BYTES) {
						throw new RuntimeException(
								"Parcel larger than max bytes allowed! "
										+ data.length);
					}

					// parcel length in big endian
					dataLength[0] = dataLength[1] = 0;
					dataLength[2] = (byte) ((data.length >> 8) & 0xff);
					dataLength[3] = (byte) ((data.length) & 0xff);

					// Log.v(LOG_TAG, "writing packet: " + data.length +
					// " bytes");

					s.getOutputStream().write(dataLength);
					s.getOutputStream().write(data);
				} catch (IOException ex) {
					Log.e(LOG_TAG, "IOException", ex);
					req = findAndRemoveRequestFromList(rr.mSerial);
					// make sure this request has not already been handled,
					// eg, if RILReceiver cleared the list.
					if (req != null || !alreadySubtracted) {
						rr.onError(RADIO_NOT_AVAILABLE, null);
						rr.release();
					}
				} catch (RuntimeException exc) {
					Log.e(LOG_TAG, "Uncaught exception ", exc);
					req = findAndRemoveRequestFromList(rr.mSerial);
					// make sure this request has not already been handled,
					// eg, if RILReceiver cleared the list.
					if (req != null || !alreadySubtracted) {
						rr.onError(GENERIC_FAILURE, null);
						rr.release();
					}
				}

				if (!alreadySubtracted && mRequestMessagesPending > 0) {
					mRequestMessagesPending--;
				}

				break;
 

你可能感兴趣的:(java)