midp_slavemode_javacall.c
来自「This is a resource based on j2me embedde」· C语言 代码 · 共 729 行 · 第 1/2 页
C
729 行
/* * * * Copyright 1990-2008 Sun Microsystems, Inc. All Rights Reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License version * 2 only, as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License version 2 for more details (a copy is * included at /legal/license.txt). * * You should have received a copy of the GNU General Public License * version 2 along with this work; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa * Clara, CA 95054 or visit www.sun.com if you need additional * information or have any questions. */#include <jvmconfig.h>#include <kni.h>#include <jvm.h>#include <jvmspi.h>#include <sni.h>#include <midpEventUtil.h>#include <push_server_export.h>#include <midp_thread.h>#include <midp_run_vm.h>#include <midp_logging.h>#include <midp_slavemode_port.h>#include <javacall_lifecycle.h>#include <javautil_string.h>#include <midp_jc_event_defs.h>#include <midpServices.h>#include <midpEvents.h>#include <midpAMS.h> /* for midpFinalize() */#include <javacall_socket.h>#include <pcsl_network.h>#include <suspend_resume.h>#include <javacall_lifecycle.h>#include <jcapp_export.h>#ifdef ENABLE_JSR_120#include <wmaInterface.h>#endif#if ENABLE_JSR_135#include <javanotify_multimedia.h>#include <KNICommon.h>#endif /* ENABLE_JSR_135 */#ifdef ENABLE_JSR_234#include <javanotify_multimedia_advanced.h>#endif /*ENABLE_JSR_234*/#ifdef ENABLE_JSR_75#include <fcNotifyIsolates.h>#endif#ifdef ENABLE_JSR_177#include <carddevice.h>#endifextern void measureStack(int clearStack);extern jlong midp_slavemode_time_slice(void);static jlong midpTimeSlice(void);/** * Free the event result. Called when no waiting Java thread was found to * receive the result. This may be empty on some systems. * * @param waitingFor what signal the result is for * @param pResult the result set by checkForSystemSignal */void midpFreeEventResult(int waitingFor, void* pResult) { (void)waitingFor; (void)pResult;}/** * Unblock a Java thread. * * @param blocked_threads blocked threads * @param blocked_threads_count number of blocked threads * @param waitingFor signal type * @param descriptor platform specific handle * @param status error code produced by the operation that unblocked the thread * * @return <tt>1</tt> if a thread was unblocked, otherwise <tt>0</tt>. */static inteventUnblockJavaThread( JVMSPI_BlockedThreadInfo *blocked_threads, int blocked_threads_count, unsigned int waitingFor, int descriptor, int status){ /* * IMPL NOTE: this functionality is similar to midp_thread_signal_list. * It differs in that it reports to the caller whether a thread was * unblocked. This is a poor interface and should be removed. However, * the coupling with Push needs to be resolved first. In addition, * freeing of pResult here seems unsafe. Management of pResult needs * to be revisited. */ int i; MidpReentryData* pThreadReentryData; for (i = 0; i < blocked_threads_count; i++) { pThreadReentryData = (MidpReentryData*)(blocked_threads[i].reentry_data); if (pThreadReentryData == NULL) { continue; } if (pThreadReentryData != NULL && pThreadReentryData->descriptor == descriptor && pThreadReentryData->waitingFor == (midpSignalType)waitingFor) { pThreadReentryData->status = status; midp_thread_unblock(blocked_threads[i].thread_id); return 1; } if (waitingFor == NO_SIGNAL && pThreadReentryData->descriptor == descriptor) { pThreadReentryData->status = status; /** * mark this thread as unblocked so that it will not be unblocked * again without being blocked first. */ pThreadReentryData->waitingFor = -1; REPORT_INFO(LC_CORE, "eventUnblockJavaThread without signal!\n"); midp_thread_unblock(blocked_threads[i].thread_id); return 1; } } return 0;}/* * This function is called by the VM periodically. Checks if * the native platform has sent a signal to MIDP. * * @param pNewSignal (out) Structure that will store the signal info * @param pNewMidpEvent (out) Structure that will store the midp event info * @param blocked_threads (in) Blocked threads * @param blocked_threads_count (in) Number of blocked threads * @param timeout Wait timeout * * @return <tt>JAVACALL_OK</tt> if an event successfully received, * <tt>JAVACALL_FAIL</tt> or if failed or no messages are avaialable */javacall_result checkForSystemSignal(MidpReentryData* pNewSignal, MidpEvent* pNewMidpEvent, JVMSPI_BlockedThreadInfo* blocked_threads, int blocked_threads_count, jlong timeout) { midp_jc_event_union *event; static unsigned char binaryBuffer[BINARY_BUFFER_MAX_LEN]; javacall_bool res; int outEventLen; long timeTowaitInMillisec; /* convert jlong to long */ if (timeout > 0x7FFFFFFF) { timeTowaitInMillisec = -1; } else if (timeout < 0) { timeTowaitInMillisec = -1; } else { timeTowaitInMillisec = (long)(timeout&0x7FFFFFFF); } res = javacall_event_receive ((long)timeTowaitInMillisec, binaryBuffer, BINARY_BUFFER_MAX_LEN, &outEventLen); if (!JAVACALL_SUCCEEDED(res)) { return res; } event = (midp_jc_event_union *) binaryBuffer; switch (event->eventType) { case MIDP_JC_EVENT_KEY: pNewSignal->waitingFor = UI_SIGNAL; pNewMidpEvent->type = MIDP_KEY_EVENT; pNewMidpEvent->CHR = event->data.keyEvent.key; pNewMidpEvent->ACTION = event->data.keyEvent.keyEventType; break; case MIDP_JC_EVENT_PEN: pNewSignal->waitingFor = UI_SIGNAL; pNewMidpEvent->type = MIDP_PEN_EVENT; pNewMidpEvent->ACTION = event->data.penEvent.type; pNewMidpEvent->X_POS = event->data.penEvent.x; pNewMidpEvent->Y_POS = event->data.penEvent.y; break; case MIDP_JC_EVENT_SOCKET: pNewSignal->waitingFor = event->data.socketEvent.waitingFor; pNewSignal->descriptor = (int)event->data.socketEvent.handle; pNewSignal->status = event->data.socketEvent.status; pNewSignal->pResult = (void *) event->data.socketEvent.extraData; break; case MIDP_JC_EVENT_NETWORK: pNewSignal->waitingFor = NETWORK_STATUS_SIGNAL; pNewSignal->descriptor = 0; pNewSignal->status = (int)event->data.networkEvent.netType; break; case MIDP_JC_EVENT_END: pNewSignal->waitingFor = AMS_SIGNAL; pNewMidpEvent->type = SHUTDOWN_EVENT; break; case MIDP_JC_EVENT_PAUSE: /* * IMPL_NOTE: if VM is running, the following call will send * PAUSE_ALL_EVENT message to AMS; otherwise, the resources * will be suspended in the context of the caller. */ midp_suspend(); break; case MIDP_JC_EVENT_RESUME: midp_resume(); break; case MIDP_JC_EVENT_PUSH: pNewSignal->waitingFor = PUSH_ALARM_SIGNAL; pNewSignal->descriptor = event->data.pushEvent.alarmHandle; break; case MIDP_JC_EVENT_ROTATION: pNewSignal->waitingFor = UI_SIGNAL; pNewMidpEvent->type = ROTATION_EVENT; break; case MIDP_JC_EVENT_DISPLAY_DEVICE_STATE_CHANGED: pNewSignal->waitingFor = DISPLAY_DEVICE_SIGNAL; pNewMidpEvent->type = DISPLAY_DEVICE_STATE_CHANGED_EVENT; pNewMidpEvent->intParam1 = event->data.displayDeviceEvent.hardwareId; pNewMidpEvent->intParam2 = event->data.displayDeviceEvent.state; break; case MIDP_JC_EVENT_CLAMSHELL_STATE_CHANGED: pNewSignal->waitingFor = DISPLAY_DEVICE_SIGNAL; pNewMidpEvent->type = DISPLAY_CLAMSHELL_STATE_CHANGED_EVENT; pNewMidpEvent->intParam1 = event->data.clamshellEvent.state; break; case MIDP_JC_EVENT_CHANGE_LOCALE: pNewSignal->waitingFor = UI_SIGNAL; pNewMidpEvent->type = CHANGE_LOCALE_EVENT; break; case MIDP_JC_EVENT_VIRTUAL_KEYBOARD: pNewSignal->waitingFor = UI_SIGNAL; pNewMidpEvent->type = VIRTUAL_KEYBOARD_EVENT; break;#ifdef ENABLE_JSR_75 case JSR75_FC_JC_EVENT_ROOTCHANGED: notifyDisksChanged(); break;#endif#if ENABLE_JSR_120 case MIDP_JC_EVENT_SMS_INCOMING: pNewSignal->waitingFor = WMA_SMS_READ_SIGNAL; pNewSignal->descriptor = event->data.smsIncomingEvent.stub; break; case MIDP_JC_EVENT_CBS_INCOMING: pNewSignal->waitingFor = WMA_CBS_READ_SIGNAL; pNewSignal->descriptor = event->data.cbsIncomingEvent.stub; break; case MIDP_JC_EVENT_SMS_SENDING_RESULT: pNewSignal->waitingFor = WMA_SMS_WRITE_SIGNAL; pNewSignal->descriptor = (int)event->data.smsSendingResultEvent.handle; pNewSignal->status = event->data.smsSendingResultEvent.result; break;#endif#if ENABLE_JSR_205 case MIDP_JC_EVENT_MMS_INCOMING: pNewSignal->waitingFor = WMA_MMS_READ_SIGNAL; pNewSignal->descriptor = event->data.mmsIncomingEvent.stub; break; case MIDP_JC_EVENT_MMS_SENDING_RESULT: pNewSignal->waitingFor = WMA_MMS_WRITE_SIGNAL; pNewSignal->descriptor = (int)event->data.mmsSendingResultEvent.handle; pNewSignal->status = event->data.mmsSendingResultEvent.result; break;#endif case MIDP_JC_EVENT_MULTIMEDIA:#if ENABLE_JSR_135 pNewSignal->waitingFor = MEDIA_EVENT_SIGNAL; pNewSignal->status = event->data.multimediaEvent.status; pNewSignal->pResult = (void *)event->data.multimediaEvent.data.num32; /* Create Java driven event */ if (event->data.multimediaEvent.mediaType > 0 && event->data.multimediaEvent.mediaType < JAVACALL_EVENT_MEDIA_JAVA_EVENTS_MARKER) { pNewMidpEvent->type = MMAPI_EVENT; pNewMidpEvent->MM_PLAYER_ID = event->data.multimediaEvent.playerId; pNewMidpEvent->MM_DATA = event->data.multimediaEvent.data.num32; pNewMidpEvent->MM_ISOLATE = event->data.multimediaEvent.appId; pNewMidpEvent->MM_EVT_TYPE = event->data.multimediaEvent.mediaType; pNewMidpEvent->MM_EVT_STATUS= event->data.multimediaEvent.status; /* VOLUME_CHANGED event must be sent to all players. */ /* MM_ISOLATE = -1 causes broadcast by StoreMIDPEventInVmThread() */ if(JAVACALL_EVENT_MEDIA_VOLUME_CHANGED == event->data.multimediaEvent.mediaType) { pNewMidpEvent->MM_ISOLATE = -1; } } /* This event should simply unblock waiting thread. No Java event is needed */ if (event->data.multimediaEvent.mediaType > JAVACALL_EVENT_MEDIA_JAVA_EVENTS_MARKER) { pNewSignal->descriptor = MAKE_PLAYER_DESCRIPTOR(event->data.multimediaEvent.appId, event->data.multimediaEvent.playerId, event->data.multimediaEvent.mediaType); /* In case of error or end-of-media unblock all awaiting threads */ } else if (event->data.multimediaEvent.mediaType == JAVACALL_EVENT_MEDIA_END_OF_MEDIA || event->data.multimediaEvent.mediaType == JAVACALL_EVENT_MEDIA_RECORD_ERROR || event->data.multimediaEvent.mediaType == JAVACALL_EVENT_MEDIA_ERROR) { pNewSignal->descriptor = (MAKE_PLAYER_DESCRIPTOR(event->data.multimediaEvent.appId, event->data.multimediaEvent.playerId, 0) & PLAYER_DESCRIPTOR_EVENT_MASK); } else { pNewSignal->descriptor = 0; } REPORT_CALL_TRACE4(LC_NONE, "[media event] External event received " "%d %d %d %d\n", pNewMidpEvent->type, event->data.multimediaEvent.appId, event->data.multimediaEvent.playerId, event->data.multimediaEvent.data.num32);#endif break;#ifdef ENABLE_JSR_234 case MIDP_JC_EVENT_ADVANCED_MULTIMEDIA: pNewSignal->waitingFor = MEDIA_EVENT_SIGNAL; pNewSignal->status = JAVACALL_OK; pNewMidpEvent->type = AMMS_EVENT; pNewMidpEvent->MM_PLAYER_ID = event->data.multimediaEvent.playerId; pNewMidpEvent->MM_ISOLATE = event->data.multimediaEvent.appId; pNewMidpEvent->MM_EVT_TYPE = event->data.multimediaEvent.mediaType; switch( event->data.multimediaEvent.mediaType ) { case JAVACALL_EVENT_AMMS_SNAP_SHOOTING_STOPPED: case JAVACALL_EVENT_AMMS_SNAP_STORAGE_ERROR:
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?