Hi Artem, Can you please give a look on this patch? This patch fixes is required for anyone who wants to use this driver without using HW ECC. -- Vimal On Mon, May 2, 2011 at 4:40 PM, Kishore Kadiyala <kishore.kadiyala@xxxxxx> wrote: > For prefetch engine, read and write got broken in commit '2c01946c'. > We never hit a scenario of not getting 'gpmc_prefetch_enable' > call success. > When reading/writing a subpage with a non divisible by 4 ecc number > of bytes, the mis-aligned bytes gets handled first before enabling > the Prefetch engine, then it reads/writes rest of the bytes. > > Signed-off-by: Kishore Kadiyala <kishore.kadiyala@xxxxxx> > Signed-off-by: Vimal Singh <vimal.newwork@xxxxxxxxx> > Reported-by: Bryan DE FARIA <bdefaria@xxxxxxxxxxxxxxxxxxx> > --- > drivers/mtd/nand/omap2.c | 12 +++++------- > 1 files changed, 5 insertions(+), 7 deletions(-) > > diff --git a/drivers/mtd/nand/omap2.c b/drivers/mtd/nand/omap2.c > index da9a351..2c8040f 100644 > --- a/drivers/mtd/nand/omap2.c > +++ b/drivers/mtd/nand/omap2.c > @@ -263,11 +263,10 @@ static void omap_read_buf_pref(struct mtd_info *mtd, u_char *buf, int len) > if (ret) { > /* PFPW engine is busy, use cpu copy method */ > if (info->nand.options & NAND_BUSWIDTH_16) > - omap_read_buf16(mtd, buf, len); > + omap_read_buf16(mtd, (u_char *)p, len); > else > - omap_read_buf8(mtd, buf, len); > + omap_read_buf8(mtd, (u_char *)p, len); > } else { > - p = (u32 *) buf; > do { > r_count = gpmc_read_status(GPMC_PREFETCH_FIFO_CNT); > r_count = r_count >> 2; > @@ -293,7 +292,7 @@ static void omap_write_buf_pref(struct mtd_info *mtd, > struct omap_nand_info, mtd); > uint32_t w_count = 0; > int i = 0, ret = 0; > - u16 *p; > + u16 *p = (u16 *)buf; > unsigned long tim, limit; > > /* take care of subpage writes */ > @@ -309,11 +308,10 @@ static void omap_write_buf_pref(struct mtd_info *mtd, > if (ret) { > /* PFPW engine is busy, use cpu copy method */ > if (info->nand.options & NAND_BUSWIDTH_16) > - omap_write_buf16(mtd, buf, len); > + omap_write_buf16(mtd, (u_char *)p, len); > else > - omap_write_buf8(mtd, buf, len); > + omap_write_buf8(mtd, (u_char *)p, len); > } else { > - p = (u16 *) buf; > while (len) { > w_count = gpmc_read_status(GPMC_PREFETCH_FIFO_CNT); > w_count = w_count >> 1; > -- > 1.7.4.1 > > -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html