summaryrefslogtreecommitdiffstats
path: root/libs
diff options
context:
space:
mode:
authorEtienne Le Grand <etn@google.com>2014-04-05 09:06:00 +0000
committerAndroid Git Automerger <android-git-automerger@android.com>2014-04-05 09:06:00 +0000
commit75b332037f6197acb239bfbbf2ac09adb31e9971 (patch)
treeca355aad8603eab2e232c2aca4e2f83040cf60eb /libs
parent00f4dde1aa88576811bca79bc8242e1fc1edb333 (diff)
parent4369a4ebd5ae7567e7075bc82830b83178099ed5 (diff)
downloadframeworks_native-75b332037f6197acb239bfbbf2ac09adb31e9971.zip
frameworks_native-75b332037f6197acb239bfbbf2ac09adb31e9971.tar.gz
frameworks_native-75b332037f6197acb239bfbbf2ac09adb31e9971.tar.bz2
am 4369a4eb: Revert "Add stringType and requiredPermission to sensors, effectively adding permission checking for sensors"
* commit '4369a4ebd5ae7567e7075bc82830b83178099ed5': Revert "Add stringType and requiredPermission to sensors, effectively adding permission checking for sensors"
Diffstat (limited to 'libs')
-rw-r--r--libs/gui/Sensor.cpp158
1 files changed, 32 insertions, 126 deletions
diff --git a/libs/gui/Sensor.cpp b/libs/gui/Sensor.cpp
index 6f1a3f2..da6b0f9 100644
--- a/libs/gui/Sensor.cpp
+++ b/libs/gui/Sensor.cpp
@@ -48,90 +48,14 @@ Sensor::Sensor(struct sensor_t const* hwSensor, int halVersion)
mResolution = hwSensor->resolution;
mPower = hwSensor->power;
mMinDelay = hwSensor->minDelay;
-
// Set fifo event count zero for older devices which do not support batching. Fused
// sensors also have their fifo counts set to zero.
if (halVersion >= SENSORS_DEVICE_API_VERSION_1_1) {
mFifoReservedEventCount = hwSensor->fifoReservedEventCount;
mFifoMaxEventCount = hwSensor->fifoMaxEventCount;
- }
-
- // Ensure existing sensors have correct string type and required
- // permissions.
- switch (mType) {
- case SENSOR_TYPE_ACCELEROMETER:
- mStringType = SENSOR_STRING_TYPE_ACCELEROMETER;
- break;
- case SENSOR_TYPE_AMBIENT_TEMPERATURE:
- mStringType = SENSOR_STRING_TYPE_AMBIENT_TEMPERATURE;
- break;
- case SENSOR_TYPE_GAME_ROTATION_VECTOR:
- mStringType = SENSOR_STRING_TYPE_GAME_ROTATION_VECTOR;
- break;
- case SENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR:
- mStringType = SENSOR_STRING_TYPE_GEOMAGNETIC_ROTATION_VECTOR;
- break;
- case SENSOR_TYPE_GRAVITY:
- mStringType = SENSOR_STRING_TYPE_GRAVITY;
- break;
- case SENSOR_TYPE_GYROSCOPE:
- mStringType = SENSOR_STRING_TYPE_GYROSCOPE;
- break;
- case SENSOR_TYPE_GYROSCOPE_UNCALIBRATED:
- mStringType = SENSOR_STRING_TYPE_GYROSCOPE_UNCALIBRATED;
- break;
- case SENSOR_TYPE_HEART_RATE:
- mStringType = SENSOR_STRING_TYPE_HEART_RATE;
- mRequiredPermission = SENSOR_PERMISSION_BODY_SENSORS;
- break;
- case SENSOR_TYPE_LIGHT:
- mStringType = SENSOR_STRING_TYPE_LIGHT;
- break;
- case SENSOR_TYPE_LINEAR_ACCELERATION:
- mStringType = SENSOR_STRING_TYPE_LINEAR_ACCELERATION;
- break;
- case SENSOR_TYPE_MAGNETIC_FIELD:
- mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD;
- break;
- case SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED:
- mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD_UNCALIBRATED;
- break;
- case SENSOR_TYPE_ORIENTATION:
- mStringType = SENSOR_STRING_TYPE_ORIENTATION;
- break;
- case SENSOR_TYPE_PRESSURE:
- mStringType = SENSOR_STRING_TYPE_PRESSURE;
- break;
- case SENSOR_TYPE_PROXIMITY:
- mStringType = SENSOR_STRING_TYPE_PROXIMITY;
- break;
- case SENSOR_TYPE_RELATIVE_HUMIDITY:
- mStringType = SENSOR_STRING_TYPE_RELATIVE_HUMIDITY;
- break;
- case SENSOR_TYPE_ROTATION_VECTOR:
- mStringType = SENSOR_STRING_TYPE_ROTATION_VECTOR;
- break;
- case SENSOR_TYPE_SIGNIFICANT_MOTION:
- mStringType = SENSOR_STRING_TYPE_SIGNIFICANT_MOTION;
- break;
- case SENSOR_TYPE_STEP_COUNTER:
- mStringType = SENSOR_STRING_TYPE_STEP_COUNTER;
- break;
- case SENSOR_TYPE_STEP_DETECTOR:
- mStringType = SENSOR_STRING_TYPE_STEP_DETECTOR;
- break;
- case SENSOR_TYPE_TEMPERATURE:
- mStringType = SENSOR_STRING_TYPE_TEMPERATURE;
- break;
- default:
- // Only pipe the stringType and requiredPermission for custom sensors.
- if (halVersion >= SENSORS_DEVICE_API_VERSION_1_2 && hwSensor->stringType) {
- mStringType = hwSensor->stringType;
- }
- if (halVersion >= SENSORS_DEVICE_API_VERSION_1_2 && hwSensor->requiredPermission) {
- mRequiredPermission = hwSensor->requiredPermission;
- }
- break;
+ } else {
+ mFifoReservedEventCount = 0;
+ mFifoMaxEventCount = 0;
}
}
@@ -191,14 +115,6 @@ int32_t Sensor::getFifoMaxEventCount() const {
return mFifoMaxEventCount;
}
-const String8& Sensor::getStringType() const {
- return mStringType;
-}
-
-const String8& Sensor::getRequiredPermission() const {
- return mRequiredPermission;
-}
-
size_t Sensor::getFlattenedSize() const
{
size_t fixedSize =
@@ -207,10 +123,8 @@ size_t Sensor::getFlattenedSize() const
sizeof(int32_t) * 3;
size_t variableSize =
- sizeof(uint32_t) + FlattenableUtils::align<4>(mName.length()) +
- sizeof(uint32_t) + FlattenableUtils::align<4>(mVendor.length()) +
- sizeof(uint32_t) + FlattenableUtils::align<4>(mStringType.length()) +
- sizeof(uint32_t) + FlattenableUtils::align<4>(mRequiredPermission.length());
+ sizeof(int32_t) + FlattenableUtils::align<4>(mName.length()) +
+ sizeof(int32_t) + FlattenableUtils::align<4>(mVendor.length());
return fixedSize + variableSize;
}
@@ -220,8 +134,14 @@ status_t Sensor::flatten(void* buffer, size_t size) const {
return NO_MEMORY;
}
- flattenString8(buffer, size, mName);
- flattenString8(buffer, size, mVendor);
+ FlattenableUtils::write(buffer, size, mName.length());
+ memcpy(static_cast<char*>(buffer), mName.string(), mName.length());
+ FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(mName.length()));
+
+ FlattenableUtils::write(buffer, size, mVendor.length());
+ memcpy(static_cast<char*>(buffer), mVendor.string(), mVendor.length());
+ FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(mVendor.length()));
+
FlattenableUtils::write(buffer, size, mVersion);
FlattenableUtils::write(buffer, size, mHandle);
FlattenableUtils::write(buffer, size, mType);
@@ -232,23 +152,38 @@ status_t Sensor::flatten(void* buffer, size_t size) const {
FlattenableUtils::write(buffer, size, mMinDelay);
FlattenableUtils::write(buffer, size, mFifoReservedEventCount);
FlattenableUtils::write(buffer, size, mFifoMaxEventCount);
- flattenString8(buffer, size, mStringType);
- flattenString8(buffer, size, mRequiredPermission);
return NO_ERROR;
}
status_t Sensor::unflatten(void const* buffer, size_t size) {
- if (!unflattenString8(buffer, size, mName)) {
+ size_t len;
+
+ if (size < sizeof(size_t)) {
+ return NO_MEMORY;
+ }
+ FlattenableUtils::read(buffer, size, len);
+ if (size < len) {
+ return NO_MEMORY;
+ }
+ mName.setTo(static_cast<char const*>(buffer), len);
+ FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
+
+
+ if (size < sizeof(size_t)) {
return NO_MEMORY;
}
- if (!unflattenString8(buffer, size, mVendor)) {
+ FlattenableUtils::read(buffer, size, len);
+ if (size < len) {
return NO_MEMORY;
}
+ mVendor.setTo(static_cast<char const*>(buffer), len);
+ FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
size_t fixedSize =
sizeof(int32_t) * 3 +
sizeof(float) * 4 +
sizeof(int32_t) * 3;
+
if (size < fixedSize) {
return NO_MEMORY;
}
@@ -263,37 +198,8 @@ status_t Sensor::unflatten(void const* buffer, size_t size) {
FlattenableUtils::read(buffer, size, mMinDelay);
FlattenableUtils::read(buffer, size, mFifoReservedEventCount);
FlattenableUtils::read(buffer, size, mFifoMaxEventCount);
-
- if (!unflattenString8(buffer, size, mStringType)) {
- return NO_MEMORY;
- }
- if (!unflattenString8(buffer, size, mRequiredPermission)) {
- return NO_MEMORY;
- }
return NO_ERROR;
}
-void Sensor::flattenString8(void*& buffer, size_t& size,
- const String8& string8) {
- uint32_t len = string8.length();
- FlattenableUtils::write(buffer, size, len);
- memcpy(static_cast<char*>(buffer), string8.string(), len);
- FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
-}
-
-bool Sensor::unflattenString8(void const*& buffer, size_t& size, String8& outputString8) {
- uint32_t len;
- if (size < sizeof(len)) {
- return false;
- }
- FlattenableUtils::read(buffer, size, len);
- if (size < len) {
- return false;
- }
- outputString8.setTo(static_cast<char const*>(buffer), len);
- FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
- return true;
-}
-
// ----------------------------------------------------------------------------
}; // namespace android