Input: iforce - move command completion handling to serio code
authorDmitry Torokhov <dmitry.torokhov@gmail.com>
Fri, 3 Aug 2018 22:23:40 +0000 (15:23 -0700)
committerDmitry Torokhov <dmitry.torokhov@gmail.com>
Sun, 23 Jun 2019 06:54:39 +0000 (23:54 -0700)
Continue teasing apart protocol-specific bits from core into transport
modules. This time move RS232-specific command completion handling
from core to iforce-serio module.

Tested-by: Tim Schumacher <timschumi@gmx.de>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
drivers/input/joystick/iforce/iforce-packets.c
drivers/input/joystick/iforce/iforce-serio.c

index e677562..8a9a152 100644 (file)
@@ -134,13 +134,6 @@ void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data)
        struct input_dev *dev = iforce->dev;
        int i;
 
-#ifdef CONFIG_JOYSTICK_IFORCE_232
-       if (HI(iforce->expect_packet) == HI(cmd)) {
-               iforce->expect_packet = 0;
-               iforce->ecmd = cmd;
-               memcpy(iforce->edata, data, IFORCE_MAX_LENGTH);
-       }
-#endif
        wake_up(&iforce->wait);
 
        if (!iforce->type)
index fa45ce4..eca2f6e 100644 (file)
@@ -130,7 +130,17 @@ static irqreturn_t iforce_serio_irq(struct serio *serio,
        }
 
        if (iforce->idx == iforce->len) {
-               iforce_process_packet(iforce, (iforce->id << 8) | iforce->idx, iforce->data);
+               u16 cmd = (iforce->id << 8) | iforce->idx;
+
+               /* Handle command completion */
+               if (HI(iforce->expect_packet) == HI(cmd)) {
+                       iforce->expect_packet = 0;
+                       iforce->ecmd = cmd;
+                       memcpy(iforce->edata, iforce->data, IFORCE_MAX_LENGTH);
+               }
+
+               iforce_process_packet(iforce, cmd, iforce->data);
+
                iforce->pkt = 0;
                iforce->id  = 0;
                iforce->len = 0;