greybus: greybus_protocols.h/es2: Ensure __le32 is used not u32
authorBryan O'Donoghue <bryan.odonoghue@linaro.org>
Mon, 18 Jul 2016 13:59:36 +0000 (14:59 +0100)
committerGreg Kroah-Hartman <gregkh@google.com>
Mon, 18 Jul 2016 16:22:45 +0000 (09:22 -0700)
There is a dangling u32 in es2/greybus_protocols.h that is only obvious
when you try to compile up gbsim. We need to do a cpu_to_le32 and declare
the 32-bit int in the header as __le32. This patch does that and splits out
the assignment of the req->flags parameter to a temporary variable to allow
for later printing.

Signed-off-by: Bryan O'Donoghue <bryan.odonoghue@linaro.org>
Suggested-by: Johan Hovold <johan@hovoldconsulting.com>
Reviewed-by: Johan Hovold <johan@hovoldconsulting.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
drivers/staging/greybus/es2.c
drivers/staging/greybus/greybus_protocols.h

index f64dbcb5e55432db2360967b72545073a1e58357..afc2d6c8ec5cd1001ef82c6aa6d05ec23ab7b464 100644 (file)
@@ -690,19 +690,23 @@ static int cport_enable(struct gb_host_device *hd, u16 cport_id,
        struct es2_ap_dev *es2 = hd_to_es2(hd);
        struct usb_device *udev = es2->usb_dev;
        struct gb_apb_request_cport_flags *req;
+       u32 connection_flags;
        int ret;
 
        req = kzalloc(sizeof(*req), GFP_KERNEL);
        if (!req)
                return -ENOMEM;
 
+       connection_flags = 0;
        if (flags & GB_CONNECTION_FLAG_CONTROL)
-               req->flags |= GB_APB_CPORT_FLAG_CONTROL;
+               connection_flags |= GB_APB_CPORT_FLAG_CONTROL;
        if (flags & GB_CONNECTION_FLAG_HIGH_PRIO)
-               req->flags |= GB_APB_CPORT_FLAG_HIGH_PRIO;
+               connection_flags |= GB_APB_CPORT_FLAG_HIGH_PRIO;
+
+       req->flags = cpu_to_le32(connection_flags);
 
        dev_dbg(&hd->dev, "%s - cport = %u, flags = %02x\n", __func__,
-                       cport_id, req->flags);
+                       cport_id, connection_flags);
 
        ret = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
                                GB_APB_REQUEST_CPORT_FLAGS,
index 178ec891e9addee187d77d509dcbd3d9bbeccdd0..d39a580a3a55a392e341929227046361fa40476b 100644 (file)
@@ -272,7 +272,7 @@ struct gb_control_intf_pm_response {
 #define APBA_REQUEST_ARPC_RUN                  0x12
 
 struct gb_apb_request_cport_flags {
-       u32     flags;
+       __le32  flags;
 #define GB_APB_CPORT_FLAG_CONTROL              0x01
 #define GB_APB_CPORT_FLAG_HIGH_PRIO            0x02
 } __packed;