On Thu, 2013-10-31 at 10:36 +0100, Cédric Le Goater wrote:
> The "screen" properties : depth, width, height, linebytes need
> to be converted to the host endian order when read from the device
> tree.
> 
> Signed-off-by: Cédric Le Goater <c...@fr.ibm.com>
> ---

Did you actually test that ? IE, using emulated VGA in qemu for
example ?

I'm asking because there are a few interesting nits here...

 - fbdev *generally* assume native endian framebuffer, but of course
under qemu today, the adapter will use a big endian frame buffer
aperture. You can compile in support for foreign endian but I don't know
how that actually works.

 - The setcolreg fix ... the "value" is used 2 lines above your endian
swap, is that correct ?

Cheers
Ben.


> Changes in v2:
> 
>  - replaced be32_to_cpu() by be32_to_cpup() 
>  - fixed setcolreg ops 
> 
>  drivers/video/offb.c |   12 ++++++------
>  1 file changed, 6 insertions(+), 6 deletions(-)
> 
> diff --git a/drivers/video/offb.c b/drivers/video/offb.c
> index 0c4f343..68e8415 100644
> --- a/drivers/video/offb.c
> +++ b/drivers/video/offb.c
> @@ -120,7 +120,7 @@ static int offb_setcolreg(u_int regno, u_int red, u_int 
> green, u_int blue,
>                       mask <<= info->var.transp.offset;
>                       value |= mask;
>               }
> -             pal[regno] = value;
> +             pal[regno] = cpu_to_be32(value);
>               return 0;
>       }
>  
> @@ -536,7 +536,7 @@ static void __init offb_init_nodriver(struct device_node 
> *dp, int no_real_node)
>       unsigned int flags, rsize, addr_prop = 0;
>       unsigned long max_size = 0;
>       u64 rstart, address = OF_BAD_ADDR;
> -     const u32 *pp, *addrp, *up;
> +     const __be32 *pp, *addrp, *up;
>       u64 asize;
>       int foreign_endian = 0;
>  
> @@ -552,25 +552,25 @@ static void __init offb_init_nodriver(struct 
> device_node *dp, int no_real_node)
>       if (pp == NULL)
>               pp = of_get_property(dp, "depth", &len);
>       if (pp && len == sizeof(u32))
> -             depth = *pp;
> +             depth = be32_to_cpup(pp);
>  
>       pp = of_get_property(dp, "linux,bootx-width", &len);
>       if (pp == NULL)
>               pp = of_get_property(dp, "width", &len);
>       if (pp && len == sizeof(u32))
> -             width = *pp;
> +             width = be32_to_cpup(pp);
>  
>       pp = of_get_property(dp, "linux,bootx-height", &len);
>       if (pp == NULL)
>               pp = of_get_property(dp, "height", &len);
>       if (pp && len == sizeof(u32))
> -             height = *pp;
> +             height = be32_to_cpup(pp);
>  
>       pp = of_get_property(dp, "linux,bootx-linebytes", &len);
>       if (pp == NULL)
>               pp = of_get_property(dp, "linebytes", &len);
>       if (pp && len == sizeof(u32) && (*pp != 0xffffffffu))
> -             pitch = *pp;
> +             pitch = be32_to_cpup(pp);
>       else
>               pitch = width * ((depth + 7) / 8);
>  


_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to