greybus: gpio: fix missing response on request errors
authorJohan Hovold <johan@hovoldconsulting.com>
Fri, 27 Mar 2015 11:45:43 +0000 (12:45 +0100)
committerGreg Kroah-Hartman <greg@kroah.com>
Mon, 30 Mar 2015 13:17:37 +0000 (15:17 +0200)
Send response also to incoming requests that cannot be fulfilled.

Signed-off-by: Johan Hovold <johan@hovoldconsulting.com>
Reviewed-by: Alex Elder <elder@linaro.org>
Signed-off-by: Greg Kroah-Hartman <greg@kroah.com>
drivers/staging/greybus/gpio.c

index 0500a6f585268cb7b00c7345d7aa2c9395fa4e58..9a34fc5a52b87d7af0017741bde30722c7c3d41b 100644 (file)
@@ -396,43 +396,47 @@ static int gb_gpio_irq_set_type(struct irq_data *d, unsigned int type)
 
 static void gb_gpio_request_recv(u8 type, struct gb_operation *op)
 {
-       struct gb_gpio_controller *ggc;
        struct gb_connection *connection = op->connection;
+       struct gb_gpio_controller *ggc = connection->private;
        struct gb_message *request;
        struct gb_gpio_irq_event_request *event;
        int irq;
        struct irq_desc *desc;
        int ret;
+       int status;
 
        if (type != GB_GPIO_TYPE_IRQ_EVENT) {
                dev_err(&connection->dev,
                        "unsupported unsolicited request: %u\n", type);
-               return;
+               status = -EINVAL;
+               goto send_response;
        }
 
-       ggc = connection->private;
-
        request = op->request;
 
        if (request->payload_size < sizeof(*event)) {
                dev_err(ggc->chip.dev, "short event received\n");
-               return;
+               status = -EINVAL;
+               goto send_response;
        }
 
        event = request->payload;
        if (event->which > ggc->line_max) {
                dev_err(ggc->chip.dev, "invalid hw irq: %d\n", event->which);
-               return;
+               status = -EINVAL;
+               goto send_response;
        }
        irq = gpio_to_irq(ggc->chip.base + event->which);
        if (irq < 0) {
                dev_err(ggc->chip.dev, "failed to map irq\n");
-               return;
+               status = -EINVAL;
+               goto send_response;
        }
        desc = irq_to_desc(irq);
        if (!desc) {
                dev_err(ggc->chip.dev, "failed to look up irq\n");
-               return;
+               status = -EINVAL;
+               goto send_response;
        }
 
        /* Dispatch interrupt */
@@ -440,10 +444,13 @@ static void gb_gpio_request_recv(u8 type, struct gb_operation *op)
        handle_simple_irq(irq, desc);
        local_irq_enable();
 
-       ret = gb_operation_response_send(op, 0);
+       status = 0;
+send_response:
+       ret = gb_operation_response_send(op, status);
        if (ret) {
                dev_err(ggc->chip.dev,
-                       "failed to send response status %d: %d\n", 0, ret);
+                       "failed to send response status %d: %d\n",
+                       status, ret);
        }
 }