greybus: introduce cport_id_valid()
authorAlex Elder <elder@linaro.org>
Sat, 13 Jun 2015 16:02:07 +0000 (11:02 -0500)
committerGreg Kroah-Hartman <gregkh@google.com>
Mon, 15 Jun 2015 23:49:00 +0000 (16:49 -0700)
Define a public predicate that defines whether a CPort ID is valid.

Use it in the message_send() routine, and make the message reported
more accurately reflect the error.  Also use it to check whether the
CPort ID in a received message is valid; if it is not, just drop the
message.

Get rid of local variable "buffer" in message_send(); it adds no
value.

Signed-off-by: Alex Elder <elder@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
drivers/staging/greybus/es1.c
drivers/staging/greybus/es2.c
drivers/staging/greybus/greybus.h

index 56c80c6ddb3ab64a0b7d9cc492f46dba3141da96..e68ee48e81897ff01191b9fd5e973d4defd791b6 100644 (file)
@@ -176,21 +176,17 @@ static void *message_send(struct greybus_host_device *hd, u16 cport_id,
 {
        struct es1_ap_dev *es1 = hd_to_es1(hd);
        struct usb_device *udev = es1->usb_dev;
-       void *buffer;
        size_t buffer_size;
        int retval;
        struct urb *urb;
 
-       buffer = message->buffer;
-       buffer_size = sizeof(*message->header) + message->payload_size;
-
        /*
         * The data actually transferred will include an indication
         * of where the data should be sent.  Do one last check of
         * the target CPort id before filling it in.
         */
-       if (cport_id == CPORT_ID_BAD) {
-               pr_err("request to send inbound data buffer\n");
+       if (!cport_id_valid(cport_id)) {
+               pr_err("invalid destination cport 0x%02x\n", cport_id);
                return ERR_PTR(-EINVAL);
        }
 
@@ -205,9 +201,11 @@ static void *message_send(struct greybus_host_device *hd, u16 cport_id,
         */
        put_unaligned_le16(cport_id, message->header->pad);
 
+       buffer_size = sizeof(*message->header) + message->payload_size;
+
        usb_fill_bulk_urb(urb, udev,
                          usb_sndbulkpipe(udev, es1->cport_out_endpoint),
-                         buffer, buffer_size,
+                         message->buffer, buffer_size,
                          cport_out_callback, message);
        retval = usb_submit_urb(urb, gfp_mask);
        if (retval) {
@@ -371,8 +369,12 @@ static void cport_in_callback(struct urb *urb)
        cport_id = get_unaligned_le16(header->pad);
        put_unaligned_le16(0, header->pad);
 
-       greybus_data_rcvd(hd, cport_id, urb->transfer_buffer,
+       if (cport_id_valid(cport_id))
+               greybus_data_rcvd(hd, cport_id, urb->transfer_buffer,
                                                        urb->actual_length);
+       else
+               dev_err(dev, "%s: invalid cport id 0x%02x received\n",
+                               __func__, cport_id);
 exit:
        /* put our urb back in the request pool */
        retval = usb_submit_urb(urb, GFP_ATOMIC);
index 5257779f7aed21140c7aa44d50a024bb7e3fd8dc..daa2e51760455dc0a618a70427cf13fe2460c512 100644 (file)
@@ -176,21 +176,17 @@ static void *message_send(struct greybus_host_device *hd, u16 cport_id,
 {
        struct es1_ap_dev *es1 = hd_to_es1(hd);
        struct usb_device *udev = es1->usb_dev;
-       void *buffer;
        size_t buffer_size;
        int retval;
        struct urb *urb;
 
-       buffer = message->buffer;
-       buffer_size = sizeof(*message->header) + message->payload_size;
-
        /*
         * The data actually transferred will include an indication
         * of where the data should be sent.  Do one last check of
         * the target CPort id before filling it in.
         */
-       if (cport_id == CPORT_ID_BAD) {
-               pr_err("request to send inbound data buffer\n");
+       if (!cport_id_valid(cport_id)) {
+               pr_err("invalid destination cport 0x%02x\n", cport_id);
                return ERR_PTR(-EINVAL);
        }
 
@@ -205,9 +201,11 @@ static void *message_send(struct greybus_host_device *hd, u16 cport_id,
         */
        put_unaligned_le16(cport_id, message->header->pad);
 
+       buffer_size = sizeof(*message->header) + message->payload_size;
+
        usb_fill_bulk_urb(urb, udev,
                          usb_sndbulkpipe(udev, es1->cport_out_endpoint),
-                         buffer, buffer_size,
+                         message->buffer, buffer_size,
                          cport_out_callback, message);
        retval = usb_submit_urb(urb, gfp_mask);
        if (retval) {
@@ -371,8 +369,12 @@ static void cport_in_callback(struct urb *urb)
        cport_id = get_unaligned_le16(header->pad);
        put_unaligned_le16(0, header->pad);
 
-       greybus_data_rcvd(hd, cport_id, urb->transfer_buffer,
+       if (cport_id_valid(cport_id))
+               greybus_data_rcvd(hd, cport_id, urb->transfer_buffer,
                                                        urb->actual_length);
+       else
+               dev_err(dev, "%s: invalid cport id 0x%02x received\n",
+                               __func__, cport_id);
 exit:
        /* put our urb back in the request pool */
        retval = usb_submit_urb(urb, GFP_ATOMIC);
index 05eab4c5f9a0ddc8c448608aaf7415c3b1f958d7..518f142b6b5f98747ba56762563d5c6a86638d3e 100644 (file)
@@ -196,5 +196,10 @@ static inline int is_gb_connection(const struct device *dev)
        return dev->type == &greybus_connection_type;
 }
 
+static inline bool cport_id_valid(u16 cport_id)
+{
+       return cport_id != CPORT_ID_BAD;
+}
+
 #endif /* __KERNEL__ */
 #endif /* __LINUX_GREYBUS_H */