[U-Boot-Users] PATCH - Fix oob data copied into supplied buffer
ksi at koi8.net
ksi at koi8.net
Fri Sep 21 03:33:19 CEST 2007
On Thu, 20 Sep 2007, Troy Kisky wrote:
This doesn't look right to me.
First chunk fixes a minor spelling error. Then I can't understand why
introduce a new variable. Everything works fine with existing structures and
it's been like this for ages, both in Linux kernel and U-Boot.
> This patch correctly sets the oobavail variable
> and fixes a bug where the oob data was not valid when
> there where multiple groups in oobfree.
> It also defines a new variable so that you can tell which
> parts of a large page have ecc errors.
>
> Signed-off-by: Troy Kisky <troy.kisky at boundarydevices.com>
>
>
> diff --git a/drivers/nand/nand_base.c b/drivers/nand/nand_base.c
> index 151f535..45b8fb0 100644
> --- a/drivers/nand/nand_base.c
> +++ b/drivers/nand/nand_base.c
> @@ -931,7 +931,7 @@ static int nand_write_page (struct mtd_info *mtd,
> struct nand_chip *this, int pa
> for (i = 0; i < eccbytes; i++, eccidx++)
> oob_buf[oob_config[eccidx]] =
> ecc_code[i];
> /* If the hardware ecc provides syndromes then
> - * the ecc code must be written immidiately
> after
> + * the ecc code must be written immediately
> after
> * the data bytes (words) */
> if (this->options & NAND_HWECC_SYNDROME)
> this->write_buf(mtd, ecc_code,
> eccbytes);
> @@ -1092,7 +1092,7 @@ static int nand_read (struct mtd_info *mtd, loff_t
> from, size_t len, size_t * re
> return nand_read_ecc (mtd, from, len, retlen, buf, NULL, NULL);
> }
>
> -
> +ulong eccReadMask; /* bitmask off ecc err groups*/
> /**
> * nand_read_ecc - [MTD Interface] Read data with ECC
> * @mtd: MTD device structure
> @@ -1267,6 +1267,7 @@ static int nand_read_ecc (struct mtd_info *mtd,
> loff_t from, size_t len,
> ecc_code[j] = oob_data[oob_config[j]];
>
> /* correct data, if neccecary */
> + eccReadMask = 0;
> for (i = 0, j = 0, datidx = 0; i < this->eccsteps; i++,
> datidx += ecc) {
> ecc_status = this->correct_data(mtd,
> &data_poi[datidx], &ecc_code[j], &ecc_calc[j]);
>
> @@ -1283,6 +1284,7 @@ static int nand_read_ecc (struct mtd_info *mtd,
> loff_t from, size_t len,
> }
>
> if (ecc_status == -1) {
> + eccReadMask |= (1<<i);
> DEBUG (MTD_DEBUG_LEVEL0, "nand_read_ecc:
> " "Failed ECC read, page 0x%08x\n", page);
> ecc_failed++;
> }
> @@ -1299,7 +1301,7 @@ static int nand_read_ecc (struct mtd_info *mtd,
> loff_t from, size_t len,
> for (i = 0, j = 0; j < mtd->oobavail;
> i++) {
> int from =
> oobsel->oobfree[i][0];
> int num = oobsel->oobfree[i][1];
> - memcpy(&oob_buf[oob],
> &oob_data[from], num);
> + memcpy(&oob_buf[oob+j],
> &oob_data[from], num);
> j+= num;
> }
> oob += mtd->oobavail;
> @@ -1644,8 +1646,10 @@ static int nand_write_ecc (struct mtd_info *mtd,
> loff_t to, size_t len,
> this->select_chip(mtd, chipnr);
>
> /* Check, if it is write protected */
> - if (nand_check_wp(mtd))
> + if (nand_check_wp(mtd)) {
> + printk (KERN_NOTICE "nand_write_ecc: Device is write
> protected\n");
> goto out;
> + }
>
> /* if oobsel is NULL, use chip defaults */
> if (oobsel == NULL)
> @@ -2486,12 +2490,9 @@ int nand_scan (struct mtd_info *mtd, int
> maxchips)
>
> /* The number of bytes available for the filesystem to place fs
> dependend
> * oob data */
> - if (this->options & NAND_BUSWIDTH_16) {
> - mtd->oobavail = mtd->oobsize - (this->autooob->eccbytes
> + 2);
> - if (this->autooob->eccbytes & 0x01)
> - mtd->oobavail--;
> - } else
> - mtd->oobavail = mtd->oobsize - (this->autooob->eccbytes
> + 1);
> + mtd->oobavail = 0;
> + for (i=0; this->autooob->oobfree[i][1]; i++)
> + mtd->oobavail += this->autooob->oobfree[i][1];
>
> /*
> * check ECC mode, default to software
>
> ------------------------------------------------------------------------
> -
> This SF.net email is sponsored by: Microsoft
> Defy all challenges. Microsoft(R) Visual Studio 2005.
> http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
> _______________________________________________
> U-Boot-Users mailing list
> U-Boot-Users at lists.sourceforge.net
> https://lists.sourceforge.net/lists/listinfo/u-boot-users
>
---
******************************************************************
* KSI at home KOI8 Net < > The impossible we do immediately. *
* Las Vegas NV, USA < > Miracles require 24-hour notice. *
******************************************************************
More information about the U-Boot
mailing list