]> pilppa.org Git - familiar-h63xx-build.git/blob - org.handhelds.familiar/packages/linux/nslu2-kernel/2.6.13/10-ixp4xx-copy-from.patch
OE tree imported from monotone branch org.openembedded.oz354fam083 at revision 8b12e3...
[familiar-h63xx-build.git] / org.handhelds.familiar / packages / linux / nslu2-kernel / 2.6.13 / 10-ixp4xx-copy-from.patch
1 # This patch fixes ixp4xx_copy_from for cases where the 'from'
2 # pointer is odd - that would cause all the accesses to be
3 # misaligned in the old code.
4 --- linux-2.6.12.2/.pc/ixp4xx_copy_from.patch/drivers/mtd/maps/ixp4xx.c 2005-09-21 22:35:38.761014739 -0700
5 +++ linux-2.6.12.2/drivers/mtd/maps/ixp4xx.c    2005-09-23 01:27:54.696223365 -0700
6 @@ -54,19 +54,23 @@
7  static void ixp4xx_copy_from(struct map_info *map, void *to,
8                              unsigned long from, ssize_t len)
9  {
10 -       int i;
11 -       u8 *dest = (u8 *) to;
12 -       u16 *src = (u16 *) (map->map_priv_1 + from);
13 -       u16 data;
14 +       if (len <= 0)
15 +               return;
16  
17 -       for (i = 0; i < (len / 2); i++) {
18 -               data = src[i];
19 -               dest[i * 2] = BYTE0(data);
20 -               dest[i * 2 + 1] = BYTE1(data);
21 +       u8 *dest = (u8 *) to;
22 +       u8 *src  = (u8 *) (map->map_priv_1 + from);
23 +       if (from & 1)
24 +               *dest++ = BYTE1(*(u16 *)(src-1)), ++src, --len;
25 +
26 +       while (len >= 2) {
27 +               u16 data = *(u16 *)src; src += 2;
28 +               *dest++ = BYTE0(data);
29 +               *dest++ = BYTE1(data);
30 +               len -= 2;
31         }
32  
33 -       if (len & 1)
34 -               dest[len - 1] = BYTE0(src[i]);
35 +       if (len > 0)
36 +               *dest++ = BYTE0(*(u16 *)src);
37  }
38  
39  /*