diff options
author | Mike Lockwood <lockwood@android.com> | 2010-04-15 12:34:01 -0700 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2010-04-15 12:34:01 -0700 |
commit | f1307b2ac4958efad3cf678d6419472631b1f3b3 (patch) | |
tree | e8cad573294f0762edb8e5d89da78d208cd26b61 /services/jni | |
parent | 17d820d876652f927a04431aaf93b9c23c412ae3 (diff) | |
parent | 04598b67a58fad93e5060bb77756ba4863013aed (diff) | |
download | frameworks_base-f1307b2ac4958efad3cf678d6419472631b1f3b3.zip frameworks_base-f1307b2ac4958efad3cf678d6419472631b1f3b3.tar.gz frameworks_base-f1307b2ac4958efad3cf678d6419472631b1f3b3.tar.bz2 |
am 04598b67: GPS: Support for GPS HAL managing its own scheduling
Diffstat (limited to 'services/jni')
-rwxr-xr-x | services/jni/com_android_server_location_GpsLocationProvider.cpp | 38 |
1 files changed, 31 insertions, 7 deletions
diff --git a/services/jni/com_android_server_location_GpsLocationProvider.cpp b/services/jni/com_android_server_location_GpsLocationProvider.cpp index 31b7a9c..28cefd4 100755 --- a/services/jni/com_android_server_location_GpsLocationProvider.cpp +++ b/services/jni/com_android_server_location_GpsLocationProvider.cpp @@ -36,6 +36,7 @@ static jmethodID method_reportStatus; static jmethodID method_reportSvStatus; static jmethodID method_reportAGpsStatus; static jmethodID method_reportNmea; +static jmethodID method_setEngineCapabilities; static jmethodID method_xtraDownloadRequest; static jmethodID method_reportNiNotification; @@ -72,6 +73,8 @@ static GpsSvStatus sGpsSvStatusCopy; static AGpsStatus sAGpsStatusCopy; static NmeaSentence sNmeaBufferCopy[NMEA_SENTENCE_COUNT]; static GpsNiNotification sGpsNiNotificationCopy; +static uint32_t sEngineCapabilities; + enum CallbackType { kLocation = 1, @@ -82,6 +85,7 @@ enum CallbackType { kDisableRequest = 32, kNmeaAvailable = 64, kNiNotification = 128, + kSetCapabilities = 256, }; static int sPendingCallbacks; @@ -144,6 +148,19 @@ static void nmea_callback(GpsUtcTime timestamp, const char* nmea, int length) pthread_mutex_unlock(&sEventMutex); } +static void set_capabilities_callback(uint32_t capabilities) +{ + LOGD("set_capabilities_callback: %08X", capabilities); + + pthread_mutex_lock(&sEventMutex); + + sPendingCallbacks |= kSetCapabilities; + sEngineCapabilities = capabilities; + + pthread_cond_signal(&sEventCond); + pthread_mutex_unlock(&sEventMutex); +} + static void acquire_wakelock_callback() { acquire_wake_lock(PARTIAL_WAKE_LOCK, WAKE_LOCK_NAME); @@ -171,6 +188,7 @@ GpsCallbacks sGpsCallbacks = { status_callback, sv_status_callback, nmea_callback, + set_capabilities_callback, acquire_wakelock_callback, release_wakelock_callback, }; @@ -216,6 +234,7 @@ static void android_location_GpsLocationProvider_class_init_native(JNIEnv* env, method_reportSvStatus = env->GetMethodID(clazz, "reportSvStatus", "()V"); method_reportAGpsStatus = env->GetMethodID(clazz, "reportAGpsStatus", "(II)V"); method_reportNmea = env->GetMethodID(clazz, "reportNmea", "(IJ)V"); + method_setEngineCapabilities = env->GetMethodID(clazz, "setEngineCapabilities", "(I)V"); method_xtraDownloadRequest = env->GetMethodID(clazz, "xtraDownloadRequest", "()V"); method_reportNiNotification = env->GetMethodID(clazz, "reportNiNotification", "(IIIIILjava/lang/String;Ljava/lang/String;IILjava/lang/String;)V"); } @@ -280,14 +299,15 @@ static void android_location_GpsLocationProvider_cleanup(JNIEnv* env, jobject ob sGpsInterface->cleanup(); } -static jboolean android_location_GpsLocationProvider_start(JNIEnv* env, jobject obj, jint positionMode, - jboolean singleFix, jint fixFrequency) +static jboolean android_location_GpsLocationProvider_set_position_mode(JNIEnv* env, jobject obj, + jint mode, jint recurrence, jint min_interval, jint preferred_accuracy, jint preferred_time) { - int result = sGpsInterface->set_position_mode(positionMode, (singleFix ? 0 : fixFrequency)); - if (result) { - return false; - } + return (sGpsInterface->set_position_mode(mode, recurrence, min_interval, preferred_accuracy, + preferred_time) == 0); +} +static jboolean android_location_GpsLocationProvider_start(JNIEnv* env, jobject obj) +{ return (sGpsInterface->start() == 0); } @@ -375,6 +395,9 @@ static void android_location_GpsLocationProvider_wait_for_event(JNIEnv* env, job extras ); } + if (pendingCallbacks & kSetCapabilities) { + env->CallVoidMethod(obj, method_setEngineCapabilities, sEngineCapabilities); + } } static jint android_location_GpsLocationProvider_read_sv_status(JNIEnv* env, jobject obj, @@ -537,7 +560,8 @@ static JNINativeMethod sMethods[] = { {"native_init", "()Z", (void*)android_location_GpsLocationProvider_init}, {"native_disable", "()V", (void*)android_location_GpsLocationProvider_disable}, {"native_cleanup", "()V", (void*)android_location_GpsLocationProvider_cleanup}, - {"native_start", "(IZI)Z", (void*)android_location_GpsLocationProvider_start}, + {"native_set_position_mode", "(IIIII)Z", (void*)android_location_GpsLocationProvider_set_position_mode}, + {"native_start", "()Z", (void*)android_location_GpsLocationProvider_start}, {"native_stop", "()Z", (void*)android_location_GpsLocationProvider_stop}, {"native_delete_aiding_data", "(I)V", (void*)android_location_GpsLocationProvider_delete_aiding_data}, {"native_wait_for_event", "()V", (void*)android_location_GpsLocationProvider_wait_for_event}, |