Merge "Intialize Java Sensor object uuid in JNI" into nyc-dev

am: 7b0a3be

* commit '7b0a3be0012edae0d17e0a92c66b30c9025f5886':
  Intialize Java Sensor object uuid in JNI

Change-Id: I2fd63c82891e1b7290406190d076d08dab4917c5
This commit is contained in:
Peng Xu
2016-04-27 19:46:21 +00:00
committed by android-build-merger
2 changed files with 44 additions and 28 deletions

View File

@@ -912,9 +912,9 @@ public final class Sensor {
* its type and name. * its type and name.
*/ */
public int getId() { public int getId() {
if (mUuid == ALL_0_UUID) { if (mUuid.equals(ALL_0_UUID)) {
return 0; return 0;
} else if (mUuid == ALL_F_UUID) { } else if (mUuid.equals(ALL_F_UUID)) {
return -1; return -1;
} else { } else {
int id = Math.abs(mUuid.hashCode()) + 1; int id = Math.abs(mUuid.hashCode()) + 1;
@@ -1139,4 +1139,26 @@ public final class Sensor {
return false; return false;
} }
} }
/**
* Sets the UUID associated with the sensor.
*
* NOTE: to be used only by native bindings in SensorManager.
*
* @see #getUuid
* @see UUID
*/
private void setUuid(long msb, long lsb) {
// reuse static object if possible
if (msb == lsb) {
if (msb == 0L) {
mUuid = ALL_0_UUID;
return;
} else if (msb == ~0L) {
mUuid = ALL_F_UUID;
return;
}
}
mUuid = new UUID(msb, lsb);
}
} }

View File

@@ -50,6 +50,7 @@ struct {
struct SensorOffsets struct SensorOffsets
{ {
jclass clazz; jclass clazz;
//fields
jfieldID name; jfieldID name;
jfieldID vendor; jfieldID vendor;
jfieldID version; jfieldID version;
@@ -64,7 +65,9 @@ struct SensorOffsets
jfieldID requiredPermission; jfieldID requiredPermission;
jfieldID maxDelay; jfieldID maxDelay;
jfieldID flags; jfieldID flags;
//methods
jmethodID setType; jmethodID setType;
jmethodID setUuid;
jmethodID init; jmethodID init;
} gSensorOffsets; } gSensorOffsets;
@@ -102,6 +105,7 @@ nativeClassInit (JNIEnv *_env, jclass _this)
sensorOffsets.flags = _env->GetFieldID(sensorClass, "mFlags", "I"); sensorOffsets.flags = _env->GetFieldID(sensorClass, "mFlags", "I");
sensorOffsets.setType = _env->GetMethodID(sensorClass, "setType", "(I)Z"); sensorOffsets.setType = _env->GetMethodID(sensorClass, "setType", "(I)Z");
sensorOffsets.setUuid = _env->GetMethodID(sensorClass, "setUuid", "(JJ)V");
sensorOffsets.init = _env->GetMethodID(sensorClass, "<init>", "()V"); sensorOffsets.init = _env->GetMethodID(sensorClass, "<init>", "()V");
// java.util.List; // java.util.List;
@@ -192,11 +196,26 @@ translateNativeSensorToJavaSensor(JNIEnv *env, jobject sensor, const Sensor& nat
requiredPermission); requiredPermission);
env->SetIntField(sensor, sensorOffsets.maxDelay, nativeSensor.getMaxDelay()); env->SetIntField(sensor, sensorOffsets.maxDelay, nativeSensor.getMaxDelay());
env->SetIntField(sensor, sensorOffsets.flags, nativeSensor.getFlags()); env->SetIntField(sensor, sensorOffsets.flags, nativeSensor.getFlags());
if (env->CallBooleanMethod(sensor, sensorOffsets.setType, nativeSensor.getType()) if (env->CallBooleanMethod(sensor, sensorOffsets.setType, nativeSensor.getType())
== JNI_FALSE) { == JNI_FALSE) {
jstring stringType = getInternedString(env, &nativeSensor.getStringType()); jstring stringType = getInternedString(env, &nativeSensor.getStringType());
env->SetObjectField(sensor, sensorOffsets.stringType, stringType); env->SetObjectField(sensor, sensorOffsets.stringType, stringType);
} }
// java.util.UUID constructor UUID(long a, long b) assumes the two long inputs a and b
// correspond to first half and second half of the 16-byte stream in big-endian,
// respectively, if the byte stream is serialized according to RFC 4122 (Sec. 4.1.2).
//
// For Java UUID 12345678-90AB-CDEF-1122-334455667788, the byte stream will be
// (uint8_t) {0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF, ....} according RFC 4122.
//
// According to Java UUID constructor document, the long parameter a should be always
// 0x12345678980ABCDEF regardless of host machine endianess. Thus, htobe64 is used to
// convert int64_t read directly, which will be in host-endian, to the big-endian required
// by Java constructor.
const int64_t (&uuid)[2] = nativeSensor.getUuid().i64;
env->CallVoidMethod(sensor, sensorOffsets.setUuid, htobe64(uuid[0]), htobe64(uuid[1]));
} }
return sensor; return sensor;
} }
@@ -212,32 +231,7 @@ nativeGetSensorAtIndex(JNIEnv *env, jclass clazz, jlong sensorManager, jobject s
return false; return false;
} }
Sensor const* const list = sensorList[index]; return translateNativeSensorToJavaSensor(env, sensor, *sensorList[index]) != NULL;
const SensorOffsets& sensorOffsets(gSensorOffsets);
jstring name = getInternedString(env, &list->getName());
jstring vendor = getInternedString(env, &list->getVendor());
jstring requiredPermission = getInternedString(env, &list->getRequiredPermission());
env->SetObjectField(sensor, sensorOffsets.name, name);
env->SetObjectField(sensor, sensorOffsets.vendor, vendor);
env->SetIntField(sensor, sensorOffsets.version, list->getVersion());
env->SetIntField(sensor, sensorOffsets.handle, list->getHandle());
env->SetFloatField(sensor, sensorOffsets.range, list->getMaxValue());
env->SetFloatField(sensor, sensorOffsets.resolution, list->getResolution());
env->SetFloatField(sensor, sensorOffsets.power, list->getPowerUsage());
env->SetIntField(sensor, sensorOffsets.minDelay, list->getMinDelay());
env->SetIntField(sensor, sensorOffsets.fifoReservedEventCount,
list->getFifoReservedEventCount());
env->SetIntField(sensor, sensorOffsets.fifoMaxEventCount,
list->getFifoMaxEventCount());
env->SetObjectField(sensor, sensorOffsets.requiredPermission,
requiredPermission);
env->SetIntField(sensor, sensorOffsets.maxDelay, list->getMaxDelay());
env->SetIntField(sensor, sensorOffsets.flags, list->getFlags());
if (env->CallBooleanMethod(sensor, sensorOffsets.setType, list->getType()) == JNI_FALSE) {
jstring stringType = getInternedString(env, &list->getStringType());
env->SetObjectField(sensor, sensorOffsets.stringType, stringType);
}
return true;
} }
static void static void