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) {