Merge "Prevent use of a null sCallbackObj by Hardware FLP" into nyc-dev

This commit is contained in:
Wyatt Riley
2016-05-26 22:03:25 +00:00
committed by Android (Google) Code Review

View File

@@ -78,7 +78,7 @@ static inline void ThrowOnError(
env->ThrowNew(exceptionClass, methodName);
}
static bool IsValidCallbackThread() {
static bool IsValidCallbackThreadEnvOnly() {
JNIEnv* env = AndroidRuntime::getJNIEnv();
if(sCallbackEnv == NULL || sCallbackEnv != env) {
@@ -89,6 +89,20 @@ static bool IsValidCallbackThread() {
return true;
}
static bool IsValidCallbackThread() {
// sCallbacksObject is created when FlpHardwareProvider on Java side is
// initialized. Sometimes the hardware may call a function before the Java
// side is ready. In order to prevent a system crash, check whether
// sCallbacksObj has been created. If not, simply ignore this event from
// hardware.
if (sCallbacksObj == NULL) {
ALOGE("Attempt to use FlpHardwareProvider blocked, because it hasn't been initialized.");
return false;
}
return IsValidCallbackThreadEnvOnly();
}
static void BatchingCapabilitiesCallback(int32_t capabilities) {
if(!IsValidCallbackThread()) {
return;
@@ -154,7 +168,7 @@ static int SetThreadEvent(ThreadEvent event) {
}
case DISASSOCIATE_JVM:
{
if (!IsValidCallbackThread()) {
if (!IsValidCallbackThreadEnvOnly()) {
ALOGE(
"Attempted to dissasociate an unnownk callback thread : '%s'.",
__FUNCTION__
@@ -661,16 +675,6 @@ static void GeofenceMonitorStatusCallback(
TranslateToObject(lastLocation, locationObject);
}
// sCallbacksObject is created when FlpHardwareProvider on Java side is
// initialized. Sometimes the hardware may call this function before the Java
// side is ready. In order to prevent the system crash, check whether
// sCallbacksObj has been created. If not, simply ignore this event from
// hardware.
if (sCallbacksObj == NULL) {
ALOGE("FlpHardwareProvider hasn't been initialized.");
return;
}
sCallbackEnv->CallVoidMethod(
sCallbacksObj,
sOnGeofenceMonitorStatus,