diff options
| author | Tian Tao <[email protected]> | 2021-04-07 07:00:52 +0000 |
|---|---|---|
| committer | Hans de Goede <[email protected]> | 2021-04-08 14:20:09 +0000 |
| commit | 507cf5a2f1e2cd32feaee6e931e18dd74cfe60ce (patch) | |
| tree | 4c46e58316ed589e02b3d89551e4cf2178df7e5c /drivers/platform/surface/aggregator/controller.c | |
| parent | platform/mellanox: mlxreg-hotplug: move to use request_irq by IRQF_NO_AUTOEN ... (diff) | |
| download | kernel-507cf5a2f1e2cd32feaee6e931e18dd74cfe60ce.tar.gz kernel-507cf5a2f1e2cd32feaee6e931e18dd74cfe60ce.zip | |
platform/surface: aggregator: move to use request_irq by IRQF_NO_AUTOEN flag
disable_irq() after request_irq() still has a time gap in which
interrupts can come. request_irq() with IRQF_NO_AUTOEN flag will
disable IRQ auto-enable because of requesting.
this patch is made base on "add IRQF_NO_AUTOEN for request_irq" which
is being merged: https://lore.kernel.org/patchwork/patch/1388765/
Signed-off-by: Tian Tao <[email protected]>
Reviewed-by: Maximilian Luz <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Hans de Goede <[email protected]>
Diffstat (limited to 'drivers/platform/surface/aggregator/controller.c')
| -rw-r--r-- | drivers/platform/surface/aggregator/controller.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/platform/surface/aggregator/controller.c b/drivers/platform/surface/aggregator/controller.c index aa6f37b4f46e..00e38284885a 100644 --- a/drivers/platform/surface/aggregator/controller.c +++ b/drivers/platform/surface/aggregator/controller.c @@ -2483,7 +2483,8 @@ int ssam_irq_setup(struct ssam_controller *ctrl) * interrupt, and let the SAM resume callback during the controller * resume process clear it. */ - const int irqf = IRQF_SHARED | IRQF_ONESHOT | IRQF_TRIGGER_RISING; + const int irqf = IRQF_SHARED | IRQF_ONESHOT | + IRQF_TRIGGER_RISING | IRQF_NO_AUTOEN; gpiod = gpiod_get(dev, "ssam_wakeup-int", GPIOD_ASIS); if (IS_ERR(gpiod)) @@ -2501,7 +2502,6 @@ int ssam_irq_setup(struct ssam_controller *ctrl) return status; ctrl->irq.num = irq; - disable_irq(ctrl->irq.num); return 0; } |
