summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTreehugger Robot <android-test-infra-autosubmit@system.gserviceaccount.com>2023-09-19 00:50:24 +0000
committerAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2023-09-19 00:50:24 +0000
commite8ed3f29dd8bc7dadd1f89ea3fd5408c5515916c (patch)
tree041e9e6dfdc6892044c81e6ead5f247cbb017e1e
parent6c255815ceef691ef776edfde588427b752dbb4a (diff)
parent7baa741ae21068d8345ee17313a6cb248ca08ddb (diff)
downloadlibhardware-e8ed3f29dd8bc7dadd1f89ea3fd5408c5515916c.tar.gz
Merge "Revert "Revert "Increase HidRawSensor thread priority to reduce latency""" into main am: 095c6960f8 am: 60b7e3a576 am: 5f6bfea312 am: 7baa741ae2
Original change: https://android-review.googlesource.com/c/platform/hardware/libhardware/+/2755006 Change-Id: I93bccffee5bc5bff56883e0c0fae7e1b1ba1c830 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
-rw-r--r--modules/sensors/dynamic_sensor/HidRawSensorDevice.cpp12
-rw-r--r--modules/sensors/dynamic_sensor/HidRawSensorDevice.h1
2 files changed, 12 insertions, 1 deletions
diff --git a/modules/sensors/dynamic_sensor/HidRawSensorDevice.cpp b/modules/sensors/dynamic_sensor/HidRawSensorDevice.cpp
index 8aa4cf92..5bc4abc2 100644
--- a/modules/sensors/dynamic_sensor/HidRawSensorDevice.cpp
+++ b/modules/sensors/dynamic_sensor/HidRawSensorDevice.cpp
@@ -35,6 +35,15 @@ using namespace Hid::Sensor::PropertyUsage;
const std::unordered_set<unsigned int> HidRawSensorDevice::sInterested{
ACCELEROMETER_3D, GYROMETER_3D, COMPASS_3D, CUSTOM};
+void HidRawSensorDevice::enableSchedFifoMode() {
+ constexpr int kHidRawSensorPriority = 10; // Matches with sensor service priority
+ struct sched_param param = {0};
+ param.sched_priority = kHidRawSensorPriority;
+ if (sched_setscheduler(getTid(), SCHED_FIFO | SCHED_RESET_ON_FORK, &param) != 0) {
+ ALOGE("Couldn't set SCHED_FIFO for HidRawSensor thread: %s", strerror(errno));
+ }
+}
+
sp<HidRawSensorDevice> HidRawSensorDevice::create(const std::string &devName) {
sp<HidRawSensorDevice> device(new HidRawSensorDevice(devName));
// offset +1 strong count added by constructor
@@ -74,7 +83,8 @@ HidRawSensorDevice::HidRawSensorDevice(const std::string &devName)
return;
}
- run("HidRawSensor");
+ run("HidRawSensor", PRIORITY_URGENT_DISPLAY);
+ enableSchedFifoMode();
mValid = true;
}
diff --git a/modules/sensors/dynamic_sensor/HidRawSensorDevice.h b/modules/sensors/dynamic_sensor/HidRawSensorDevice.h
index 06d435e7..7818bf16 100644
--- a/modules/sensors/dynamic_sensor/HidRawSensorDevice.h
+++ b/modules/sensors/dynamic_sensor/HidRawSensorDevice.h
@@ -41,6 +41,7 @@ private:
// constructor will result in +1 strong count
explicit HidRawSensorDevice(const std::string &devName);
+ void enableSchedFifoMode();
// implement function of Thread
virtual bool threadLoop() override;
std::unordered_map<unsigned int/*reportId*/, sp<HidRawSensor>> mSensors;