Dear Troy Kisky,

> commit 5f6aa03fda2a0a79940765865c1e4266be8a75f8
>     USB: Fix complaints about strict aliasing in OHCI-HCD
> 
> tried to fix this, but gcc4.4 still complains. So, this
> patch basically reverts the above and does a simpler fix.
> 
> also, the above commit incorrectly changed
>       /* corresponds to data_buf[4-7] */
>       datab [1] = 0;
> to
> 
>       /* corresponds to databuf.u8[4-7] */
>       databuf.u8[1] = 0;
> 
> This patch also fixes that.
> 
> Signed-off-by: Troy Kisky <troy.ki...@boundarydevices.com>
> ---
>  drivers/usb/host/ohci-hcd.c |   70
> +++++++++++++++++++------------------------ 1 file changed, 31
> insertions(+), 39 deletions(-)
> 
> diff --git a/drivers/usb/host/ohci-hcd.c b/drivers/usb/host/ohci-hcd.c
> index d24f2f1..9f47351 100644
> --- a/drivers/usb/host/ohci-hcd.c
> +++ b/drivers/usb/host/ohci-hcd.c
> @@ -1261,19 +1261,11 @@ static int ohci_submit_rh_msg(struct usb_device
> *dev, unsigned long pipe, int leni = transfer_len;
>       int len = 0;
>       int stat = 0;
> -     __u32 datab[4];
> -     union {
> -             void *ptr;
> -             __u8 *u8;
> -             __u16 *u16;
> -             __u32 *u32;
> -     } databuf;
>       __u16 bmRType_bReq;
>       __u16 wValue;
>       __u16 wIndex;
>       __u16 wLength;
> -
> -     databuf.u32 = (__u32 *)datab;
> +     ALLOC_ALIGN_BUFFER(__u8, databuf, 16, sizeof(u32));

Ok, pardon my sloppiness in reviews ... but why not alloc this cache aligned? 
That way we'd also circumvent the issues with caches we'd eventually hit anyway.

[...]

The rest is OK.
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot

Reply via email to