diff --git a/resource-overlay/eqs/Frameworks/res/values/config.xml b/resource-overlay/eqs/Frameworks/res/values/config.xml
index d251c63..b7fafeb 100644
--- a/resource-overlay/eqs/Frameworks/res/values/config.xml
+++ b/resource-overlay/eqs/Frameworks/res/values/config.xml
@@ -278,7 +278,4 @@
org.lineageos.sensor.dt2w
-
-
- org.lineageos.sensor.udfps
diff --git a/sensors/Sensor.cpp b/sensors/Sensor.cpp
index 7d4edfe..0df0108 100644
--- a/sensors/Sensor.cpp
+++ b/sensors/Sensor.cpp
@@ -22,6 +22,7 @@
#include
#include
+#include
static bool readEvent(int fd, struct input_event *event) {
int rc;
@@ -226,21 +227,24 @@ OneShotSensor::OneShotSensor(int32_t sensorHandle, ISensorsEventCallback* callba
mSensorInfo.flags |= SensorFlagBits::ONE_SHOT_MODE;
}
-InputEventOneShotSensor::InputEventOneShotSensor(
- int32_t sensorHandle, ISensorsEventCallback* callback, const std::string& pollPath,
- const std::string& enablePath, int enableValue, short keyValue, const std::string& name,
- const std::string& typeAsString, SensorType type)
+#define INPUT_DT2W_SENSOR_PATH "/dev/input/event10"
+#define INPUT_TOUCHSCREEN_PATH "/dev/input/event11"
+
+#define GESTURE_PATH "/sys/class/touchscreen/primary/gesture"
+
+InputEventDT2WSensor::InputEventDT2WSensor(
+ int32_t sensorHandle, ISensorsEventCallback* callback)
: OneShotSensor(sensorHandle, callback) {
- mSensorInfo.name = name;
- mSensorInfo.type = type;
- mSensorInfo.typeAsString = typeAsString;
+ mSensorInfo.name = "DT2W sensor";
+ mSensorInfo.type = static_cast(static_cast(SensorType::DEVICE_PRIVATE_BASE) + 1);
+ mSensorInfo.typeAsString = "org.lineageos.sensor.dt2w";
mSensorInfo.maxRange = 2048.0f;
mSensorInfo.resolution = 1.0f;
mSensorInfo.power = 0;
mSensorInfo.flags |= SensorFlagBits::WAKE_UP;
std::ofstream mGestureEnable;
- mGestureEnable.open(enablePath);
+ mGestureEnable.open(GESTURE_PATH);
if(!mGestureEnable) {
ALOGE("could not open gesture path");
@@ -248,7 +252,7 @@ InputEventOneShotSensor::InputEventOneShotSensor(
return;
}
- mGestureEnable << enableValue << std::flush;
+ mGestureEnable << "49" << std::flush;
int rc;
@@ -259,7 +263,7 @@ InputEventOneShotSensor::InputEventOneShotSensor(
ALOGE("failed to open wait pipe: %d", rc);
}
- mPollFds[0] = open(pollPath.c_str(), O_RDONLY | O_NONBLOCK);
+ mPollFds[0] = open(INPUT_DT2W_SENSOR_PATH, O_RDONLY | O_NONBLOCK);
if (mPollFds[0] < 0) {
ALOGE("failed to open poll fd: %d", mPollFds[0]);
}
@@ -278,17 +282,15 @@ InputEventOneShotSensor::InputEventOneShotSensor(
.fd = mPollFds[0],
.events = POLLIN,
};
-
- mKeyValue = keyValue;
}
-InputEventOneShotSensor::~InputEventOneShotSensor() {
+InputEventDT2WSensor::~InputEventDT2WSensor() {
interruptPoll();
}
-void InputEventOneShotSensor::activate(bool enable) {
+void InputEventDT2WSensor::activate(bool enable) {
std::lock_guard lock(mRunMutex);
- ALOGE("Activated for key %d", mKeyValue);
+
if (mIsEnabled != enable) {
mIsEnabled = enable;
interruptPoll();
@@ -296,12 +298,12 @@ void InputEventOneShotSensor::activate(bool enable) {
}
}
-void InputEventOneShotSensor::setOperationMode(OperationMode mode) {
+void InputEventDT2WSensor::setOperationMode(OperationMode mode) {
Sensor::setOperationMode(mode);
interruptPoll();
}
-void InputEventOneShotSensor::run() {
+void InputEventDT2WSensor::run() {
std::unique_lock runLock(mRunMutex);
while (!mStopThread) {
@@ -324,7 +326,7 @@ void InputEventOneShotSensor::run() {
}
if((mPolls[1].revents == mPolls[1].events) && readEvent(mPolls[1].fd, &event)) {
- if(event.type == EV_KEY && event.value == 1 && event.code == mKeyValue) {
+ if(event.type == EV_KEY && event.value == 1 && event.code == KEY_F4) {
mIsEnabled = false;
mCallback->postEvents(readEvents(), isWakeUpSensor());
}
@@ -335,25 +337,21 @@ void InputEventOneShotSensor::run() {
}
}
-void InputEventOneShotSensor::interruptPoll() {
+void InputEventDT2WSensor::interruptPoll() {
if (mWaitPipeFd[1] < 0) return;
char c = '1';
write(mWaitPipeFd[1], &c, sizeof(c));
}
-void InputEventOneShotSensor::fillEventData(Event& event) {
- event.u.data[0] = 0;
- event.u.data[1] = 0;
-}
-
-std::vector InputEventOneShotSensor::readEvents() {
+std::vector InputEventDT2WSensor::readEvents() {
std::vector events;
Event event;
event.sensorHandle = mSensorInfo.sensorHandle;
event.sensorType = mSensorInfo.type;
event.timestamp = ::android::elapsedRealtimeNano();
- fillEventData(event);
+ event.u.data[0] = 0;
+ event.u.data[1] = 0;
events.push_back(event);
return events;
}
diff --git a/sensors/Sensor.h b/sensors/Sensor.h
index 68d9456..436c419 100644
--- a/sensors/Sensor.h
+++ b/sensors/Sensor.h
@@ -27,7 +27,6 @@
#include
#include
#include
-#include
using ::android::hardware::sensors::V1_0::OperationMode;
using ::android::hardware::sensors::V1_0::Result;
@@ -93,18 +92,14 @@ class OneShotSensor : public Sensor {
virtual Result flush() override { return Result::BAD_VALUE; }
};
-class InputEventOneShotSensor : public OneShotSensor {
+class InputEventDT2WSensor : public OneShotSensor {
public:
- InputEventOneShotSensor(int32_t sensorHandle, ISensorsEventCallback* callback,
- const std::string& pollPath, const std::string& enablePath,
- int enableValue, short keyValue, const std::string& name,
- const std::string& typeAsString, SensorType type);
- virtual ~InputEventOneShotSensor() override;
+ InputEventDT2WSensor(int32_t sensorHandle, ISensorsEventCallback* callback);
+ virtual ~InputEventDT2WSensor() override;
virtual void activate(bool enable) override;
virtual void setOperationMode(OperationMode mode) override;
virtual std::vector readEvents() override;
- virtual void fillEventData(Event& event);
protected:
virtual void run() override;
@@ -117,31 +112,6 @@ class InputEventOneShotSensor : public OneShotSensor {
struct pollfd mPolls[2];
int mWaitPipeFd[2];
int mPollFds[1];
- short mKeyValue;
-};
-
-const std::string kDoubleTapInputEventPath = "/dev/input/event10";
-const std::string kGestureEnablePath = "/sys/class/touchscreen/primary/gesture";
-
-const int kEnableDt2w = 49;
-const int kEnableFodPressed = 17;
-
-class InputEventDT2WSensor : public InputEventOneShotSensor {
- public:
- InputEventDT2WSensor(int32_t sensorHandle, ISensorsEventCallback* callback)
- : InputEventOneShotSensor(
- sensorHandle, callback, kDoubleTapInputEventPath,
- kGestureEnablePath, kEnableDt2w, KEY_F4, "DT2W sensor",
- "org.lineageos.sensor.dt2w", static_cast(static_cast(SensorType::DEVICE_PRIVATE_BASE) + 1)) {}
-};
-
-class InputEventUdfpsSensor : public InputEventOneShotSensor {
- public:
- InputEventUdfpsSensor(int32_t sensorHandle, ISensorsEventCallback* callback)
- : InputEventOneShotSensor(
- sensorHandle, callback, kDoubleTapInputEventPath,
- kGestureEnablePath, kEnableFodPressed, KEY_F2, "UDFPS sensor",
- "org.lineageos.sensor.udfps", static_cast(static_cast(SensorType::DEVICE_PRIVATE_BASE) + 2)) {}
};
} // namespace implementation
diff --git a/sensors/SensorsSubHal.cpp b/sensors/SensorsSubHal.cpp
index 089e379..0e638a4 100644
--- a/sensors/SensorsSubHal.cpp
+++ b/sensors/SensorsSubHal.cpp
@@ -34,7 +34,6 @@ using ::android::hardware::sensors::V2_0::implementation::ScopedWakelock;
SensorsSubHal::SensorsSubHal() : mCallback(nullptr), mNextHandle(1) {
AddSensor();
- AddSensor();
}
Return SensorsSubHal::getSensorsList_2_1(ISensors::getSensorsList_2_1_cb _hidl_cb) {