am 641a1868
: Merge "SensorService Flush API bug fix." into klp-dev
* commit '641a18688bc6b208bbeaffa6083d3cf5f6790e4b': SensorService Flush API bug fix.
This commit is contained in:
commit
487c7815d7
@ -686,21 +686,6 @@ status_t SensorService::flushSensor(const sp<SensorEventConnection>& connection,
|
|||||||
ALOGE("flush called on Significant Motion sensor");
|
ALOGE("flush called on Significant Motion sensor");
|
||||||
return INVALID_OPERATION;
|
return INVALID_OPERATION;
|
||||||
}
|
}
|
||||||
SensorDevice& dev(SensorDevice::getInstance());
|
|
||||||
|
|
||||||
if (dev.getHalDeviceVersion() < SENSORS_DEVICE_API_VERSION_1_1) {
|
|
||||||
// For older devices increment pending flush count, which will send a trivial flush complete
|
|
||||||
// event for all the connections which are registered for updates on this sensor.
|
|
||||||
const SortedVector< wp<SensorEventConnection> > activeConnections(
|
|
||||||
getActiveConnections());
|
|
||||||
for (size_t i=0 ; i<activeConnections.size() ; i++) {
|
|
||||||
sp<SensorEventConnection> connection(activeConnections[i].promote());
|
|
||||||
if (connection != 0) {
|
|
||||||
connection->incrementPendingFlushCount(handle);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return NO_ERROR;
|
|
||||||
}
|
|
||||||
return sensor->flush(connection.get(), handle);
|
return sensor->flush(connection.get(), handle);
|
||||||
}
|
}
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
@ -805,15 +790,6 @@ void SensorService::SensorEventConnection::setFirstFlushPending(int32_t handle,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SensorService::SensorEventConnection::incrementPendingFlushCount(int32_t handle) {
|
|
||||||
Mutex::Autolock _l(mConnectionLock);
|
|
||||||
ssize_t index = mSensorInfo.indexOfKey(handle);
|
|
||||||
if (index >= 0) {
|
|
||||||
FlushInfo& flushInfo = mSensorInfo.editValueAt(index);
|
|
||||||
flushInfo.mPendingFlushEventsToSend++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
status_t SensorService::SensorEventConnection::sendEvents(
|
status_t SensorService::SensorEventConnection::sendEvents(
|
||||||
sensors_event_t const* buffer, size_t numEvents,
|
sensors_event_t const* buffer, size_t numEvents,
|
||||||
sensors_event_t* scratch)
|
sensors_event_t* scratch)
|
||||||
@ -872,7 +848,7 @@ status_t SensorService::SensorEventConnection::sendEvents(
|
|||||||
ssize_t size = SensorEventQueue::write(mChannel, &flushCompleteEvent, 1);
|
ssize_t size = SensorEventQueue::write(mChannel, &flushCompleteEvent, 1);
|
||||||
if (size < 0) {
|
if (size < 0) {
|
||||||
// ALOGW("dropping %d events on the floor", count);
|
// ALOGW("dropping %d events on the floor", count);
|
||||||
countFlushCompleteEvents(scratch, count);
|
countFlushCompleteEventsLocked(scratch, count);
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
ALOGD_IF(DEBUG_CONNECTIONS, "sent dropped flush complete event==%d ",
|
ALOGD_IF(DEBUG_CONNECTIONS, "sent dropped flush complete event==%d ",
|
||||||
@ -889,17 +865,17 @@ status_t SensorService::SensorEventConnection::sendEvents(
|
|||||||
// the destination doesn't accept events anymore, it's probably
|
// the destination doesn't accept events anymore, it's probably
|
||||||
// full. For now, we just drop the events on the floor.
|
// full. For now, we just drop the events on the floor.
|
||||||
// ALOGW("dropping %d events on the floor", count);
|
// ALOGW("dropping %d events on the floor", count);
|
||||||
countFlushCompleteEvents(scratch, count);
|
Mutex::Autolock _l(mConnectionLock);
|
||||||
|
countFlushCompleteEventsLocked(scratch, count);
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
return size < 0 ? status_t(size) : status_t(NO_ERROR);
|
return size < 0 ? status_t(size) : status_t(NO_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SensorService::SensorEventConnection::countFlushCompleteEvents(
|
void SensorService::SensorEventConnection::countFlushCompleteEventsLocked(
|
||||||
sensors_event_t* scratch, const int numEventsDropped) {
|
sensors_event_t* scratch, const int numEventsDropped) {
|
||||||
ALOGD_IF(DEBUG_CONNECTIONS, "dropping %d events ", numEventsDropped);
|
ALOGD_IF(DEBUG_CONNECTIONS, "dropping %d events ", numEventsDropped);
|
||||||
Mutex::Autolock _l(mConnectionLock);
|
|
||||||
// Count flushComplete events in the events that are about to the dropped. These will be sent
|
// Count flushComplete events in the events that are about to the dropped. These will be sent
|
||||||
// separately before the next batch of events.
|
// separately before the next batch of events.
|
||||||
for (int j = 0; j < numEventsDropped; ++j) {
|
for (int j = 0; j < numEventsDropped; ++j) {
|
||||||
@ -939,15 +915,25 @@ status_t SensorService::SensorEventConnection::setEventRate(
|
|||||||
}
|
}
|
||||||
|
|
||||||
status_t SensorService::SensorEventConnection::flush() {
|
status_t SensorService::SensorEventConnection::flush() {
|
||||||
|
SensorDevice& dev(SensorDevice::getInstance());
|
||||||
|
const int halVersion = dev.getHalDeviceVersion();
|
||||||
Mutex::Autolock _l(mConnectionLock);
|
Mutex::Autolock _l(mConnectionLock);
|
||||||
status_t err(NO_ERROR);
|
status_t err(NO_ERROR);
|
||||||
|
// Loop through all sensors for this connection and call flush on each of them.
|
||||||
for (size_t i = 0; i < mSensorInfo.size(); ++i) {
|
for (size_t i = 0; i < mSensorInfo.size(); ++i) {
|
||||||
const int handle = mSensorInfo.keyAt(i);
|
const int handle = mSensorInfo.keyAt(i);
|
||||||
status_t err_flush = mService->flushSensor(this, handle);
|
if (halVersion < SENSORS_DEVICE_API_VERSION_1_1) {
|
||||||
if (err_flush != NO_ERROR) {
|
// For older devices just increment pending flush count which will send a trivial
|
||||||
ALOGE("Flush error handle=%d %s", handle, strerror(-err_flush));
|
// flush complete event.
|
||||||
|
FlushInfo& flushInfo = mSensorInfo.editValueFor(handle);
|
||||||
|
flushInfo.mPendingFlushEventsToSend++;
|
||||||
|
} else {
|
||||||
|
status_t err_flush = mService->flushSensor(this, handle);
|
||||||
|
if (err_flush != NO_ERROR) {
|
||||||
|
ALOGE("Flush error handle=%d %s", handle, strerror(-err_flush));
|
||||||
|
}
|
||||||
|
err = (err_flush != NO_ERROR) ? err_flush : err;
|
||||||
}
|
}
|
||||||
err = (err_flush != NO_ERROR) ? err_flush : err;
|
|
||||||
}
|
}
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
@ -83,7 +83,7 @@ class SensorService :
|
|||||||
// Count the number of flush complete events which are about to be dropped in the buffer.
|
// Count the number of flush complete events which are about to be dropped in the buffer.
|
||||||
// Increment mPendingFlushEventsToSend in mSensorInfo. These flush complete events will be
|
// Increment mPendingFlushEventsToSend in mSensorInfo. These flush complete events will be
|
||||||
// sent separately before the next batch of events.
|
// sent separately before the next batch of events.
|
||||||
void countFlushCompleteEvents(sensors_event_t* scratch, int numEventsDropped);
|
void countFlushCompleteEventsLocked(sensors_event_t* scratch, int numEventsDropped);
|
||||||
|
|
||||||
sp<SensorService> const mService;
|
sp<SensorService> const mService;
|
||||||
sp<BitTube> mChannel;
|
sp<BitTube> mChannel;
|
||||||
@ -112,7 +112,6 @@ class SensorService :
|
|||||||
bool addSensor(int32_t handle);
|
bool addSensor(int32_t handle);
|
||||||
bool removeSensor(int32_t handle);
|
bool removeSensor(int32_t handle);
|
||||||
void setFirstFlushPending(int32_t handle, bool value);
|
void setFirstFlushPending(int32_t handle, bool value);
|
||||||
void incrementPendingFlushCount(int32_t handle);
|
|
||||||
void dump(String8& result);
|
void dump(String8& result);
|
||||||
|
|
||||||
uid_t getUid() const { return mUid; }
|
uid_t getUid() const { return mUid; }
|
||||||
|
Loading…
Reference in New Issue
Block a user