提交 c0313b96 编写于 作者: M Masahiro Yamada 提交者: Boris Brezillon

mtd: nand: squash struct nand_buffers into struct nand_chip

struct nand_buffers is malloc'ed in nand_scan_tail() just for
containing three pointers.  Squash this struct into nand_chip.

Move and rename as follows:

  chip->buffers->ecccalc   ->  chip->ecc.calc_buf
  chip->buffers->ecccode   ->  chip->ecc.code_buf
  chip->buffers->databuf   ->  chip->data_buf
Signed-off-by: NMasahiro Yamada <yamada.masahiro@socionext.com>
Signed-off-by: NBoris Brezillon <boris.brezillon@free-electrons.com>
上级 8b311ead
...@@ -1681,7 +1681,7 @@ static int brcmstb_nand_verify_erased_page(struct mtd_info *mtd, ...@@ -1681,7 +1681,7 @@ static int brcmstb_nand_verify_erased_page(struct mtd_info *mtd,
int ret; int ret;
if (!buf) { if (!buf) {
buf = chip->buffers->databuf; buf = chip->data_buf;
/* Invalidate page cache */ /* Invalidate page cache */
chip->pagebuf = -1; chip->pagebuf = -1;
} }
......
...@@ -330,7 +330,7 @@ static int denali_check_erased_page(struct mtd_info *mtd, ...@@ -330,7 +330,7 @@ static int denali_check_erased_page(struct mtd_info *mtd,
unsigned long uncor_ecc_flags, unsigned long uncor_ecc_flags,
unsigned int max_bitflips) unsigned int max_bitflips)
{ {
uint8_t *ecc_code = chip->buffers->ecccode; uint8_t *ecc_code = chip->ecc.code_buf;
int ecc_steps = chip->ecc.steps; int ecc_steps = chip->ecc.steps;
int ecc_size = chip->ecc.size; int ecc_size = chip->ecc.size;
int ecc_bytes = chip->ecc.bytes; int ecc_bytes = chip->ecc.bytes;
......
...@@ -684,8 +684,8 @@ static int fsmc_read_page_hwecc(struct mtd_info *mtd, struct nand_chip *chip, ...@@ -684,8 +684,8 @@ static int fsmc_read_page_hwecc(struct mtd_info *mtd, struct nand_chip *chip,
int eccbytes = chip->ecc.bytes; int eccbytes = chip->ecc.bytes;
int eccsteps = chip->ecc.steps; int eccsteps = chip->ecc.steps;
uint8_t *p = buf; uint8_t *p = buf;
uint8_t *ecc_calc = chip->buffers->ecccalc; uint8_t *ecc_calc = chip->ecc.calc_buf;
uint8_t *ecc_code = chip->buffers->ecccode; uint8_t *ecc_code = chip->ecc.code_buf;
int off, len, group = 0; int off, len, group = 0;
/* /*
* ecc_oob is intentionally taken as uint16_t. In 16bit devices, we * ecc_oob is intentionally taken as uint16_t. In 16bit devices, we
......
...@@ -1696,7 +1696,7 @@ static int mx23_check_transcription_stamp(struct gpmi_nand_data *this) ...@@ -1696,7 +1696,7 @@ static int mx23_check_transcription_stamp(struct gpmi_nand_data *this)
unsigned int search_area_size_in_strides; unsigned int search_area_size_in_strides;
unsigned int stride; unsigned int stride;
unsigned int page; unsigned int page;
uint8_t *buffer = chip->buffers->databuf; uint8_t *buffer = chip->data_buf;
int saved_chip_number; int saved_chip_number;
int found_an_ncb_fingerprint = false; int found_an_ncb_fingerprint = false;
...@@ -1755,7 +1755,7 @@ static int mx23_write_transcription_stamp(struct gpmi_nand_data *this) ...@@ -1755,7 +1755,7 @@ static int mx23_write_transcription_stamp(struct gpmi_nand_data *this)
unsigned int block; unsigned int block;
unsigned int stride; unsigned int stride;
unsigned int page; unsigned int page;
uint8_t *buffer = chip->buffers->databuf; uint8_t *buffer = chip->data_buf;
int saved_chip_number; int saved_chip_number;
int status; int status;
......
...@@ -2030,8 +2030,8 @@ static int nand_read_page_swecc(struct mtd_info *mtd, struct nand_chip *chip, ...@@ -2030,8 +2030,8 @@ static int nand_read_page_swecc(struct mtd_info *mtd, struct nand_chip *chip,
int eccbytes = chip->ecc.bytes; int eccbytes = chip->ecc.bytes;
int eccsteps = chip->ecc.steps; int eccsteps = chip->ecc.steps;
uint8_t *p = buf; uint8_t *p = buf;
uint8_t *ecc_calc = chip->buffers->ecccalc; uint8_t *ecc_calc = chip->ecc.calc_buf;
uint8_t *ecc_code = chip->buffers->ecccode; uint8_t *ecc_code = chip->ecc.code_buf;
unsigned int max_bitflips = 0; unsigned int max_bitflips = 0;
chip->ecc.read_page_raw(mtd, chip, buf, 1, page); chip->ecc.read_page_raw(mtd, chip, buf, 1, page);
...@@ -2102,7 +2102,7 @@ static int nand_read_subpage(struct mtd_info *mtd, struct nand_chip *chip, ...@@ -2102,7 +2102,7 @@ static int nand_read_subpage(struct mtd_info *mtd, struct nand_chip *chip,
/* Calculate ECC */ /* Calculate ECC */
for (i = 0; i < eccfrag_len ; i += chip->ecc.bytes, p += chip->ecc.size) for (i = 0; i < eccfrag_len ; i += chip->ecc.bytes, p += chip->ecc.size)
chip->ecc.calculate(mtd, p, &chip->buffers->ecccalc[i]); chip->ecc.calculate(mtd, p, &chip->ecc.calc_buf[i]);
/* /*
* The performance is faster if we position offsets according to * The performance is faster if we position offsets according to
...@@ -2142,7 +2142,7 @@ static int nand_read_subpage(struct mtd_info *mtd, struct nand_chip *chip, ...@@ -2142,7 +2142,7 @@ static int nand_read_subpage(struct mtd_info *mtd, struct nand_chip *chip,
return ret; return ret;
} }
ret = mtd_ooblayout_get_eccbytes(mtd, chip->buffers->ecccode, ret = mtd_ooblayout_get_eccbytes(mtd, chip->ecc.code_buf,
chip->oob_poi, index, eccfrag_len); chip->oob_poi, index, eccfrag_len);
if (ret) if (ret)
return ret; return ret;
...@@ -2151,13 +2151,13 @@ static int nand_read_subpage(struct mtd_info *mtd, struct nand_chip *chip, ...@@ -2151,13 +2151,13 @@ static int nand_read_subpage(struct mtd_info *mtd, struct nand_chip *chip,
for (i = 0; i < eccfrag_len ; i += chip->ecc.bytes, p += chip->ecc.size) { for (i = 0; i < eccfrag_len ; i += chip->ecc.bytes, p += chip->ecc.size) {
int stat; int stat;
stat = chip->ecc.correct(mtd, p, stat = chip->ecc.correct(mtd, p, &chip->ecc.code_buf[i],
&chip->buffers->ecccode[i], &chip->buffers->ecccalc[i]); &chip->ecc.calc_buf[i]);
if (stat == -EBADMSG && if (stat == -EBADMSG &&
(chip->ecc.options & NAND_ECC_GENERIC_ERASED_CHECK)) { (chip->ecc.options & NAND_ECC_GENERIC_ERASED_CHECK)) {
/* check for empty pages with bitflips */ /* check for empty pages with bitflips */
stat = nand_check_erased_ecc_chunk(p, chip->ecc.size, stat = nand_check_erased_ecc_chunk(p, chip->ecc.size,
&chip->buffers->ecccode[i], &chip->ecc.code_buf[i],
chip->ecc.bytes, chip->ecc.bytes,
NULL, 0, NULL, 0,
chip->ecc.strength); chip->ecc.strength);
...@@ -2190,8 +2190,8 @@ static int nand_read_page_hwecc(struct mtd_info *mtd, struct nand_chip *chip, ...@@ -2190,8 +2190,8 @@ static int nand_read_page_hwecc(struct mtd_info *mtd, struct nand_chip *chip,
int eccbytes = chip->ecc.bytes; int eccbytes = chip->ecc.bytes;
int eccsteps = chip->ecc.steps; int eccsteps = chip->ecc.steps;
uint8_t *p = buf; uint8_t *p = buf;
uint8_t *ecc_calc = chip->buffers->ecccalc; uint8_t *ecc_calc = chip->ecc.calc_buf;
uint8_t *ecc_code = chip->buffers->ecccode; uint8_t *ecc_code = chip->ecc.code_buf;
unsigned int max_bitflips = 0; unsigned int max_bitflips = 0;
ret = nand_read_page_op(chip, page, 0, NULL, 0); ret = nand_read_page_op(chip, page, 0, NULL, 0);
...@@ -2264,8 +2264,8 @@ static int nand_read_page_hwecc_oob_first(struct mtd_info *mtd, ...@@ -2264,8 +2264,8 @@ static int nand_read_page_hwecc_oob_first(struct mtd_info *mtd,
int eccbytes = chip->ecc.bytes; int eccbytes = chip->ecc.bytes;
int eccsteps = chip->ecc.steps; int eccsteps = chip->ecc.steps;
uint8_t *p = buf; uint8_t *p = buf;
uint8_t *ecc_code = chip->buffers->ecccode; uint8_t *ecc_code = chip->ecc.code_buf;
uint8_t *ecc_calc = chip->buffers->ecccalc; uint8_t *ecc_calc = chip->ecc.calc_buf;
unsigned int max_bitflips = 0; unsigned int max_bitflips = 0;
/* Read the OOB area first */ /* Read the OOB area first */
...@@ -2514,7 +2514,7 @@ static int nand_do_read_ops(struct mtd_info *mtd, loff_t from, ...@@ -2514,7 +2514,7 @@ static int nand_do_read_ops(struct mtd_info *mtd, loff_t from,
/* Is the current page in the buffer? */ /* Is the current page in the buffer? */
if (realpage != chip->pagebuf || oob) { if (realpage != chip->pagebuf || oob) {
bufpoi = use_bufpoi ? chip->buffers->databuf : buf; bufpoi = use_bufpoi ? chip->data_buf : buf;
if (use_bufpoi && aligned) if (use_bufpoi && aligned)
pr_debug("%s: using read bounce buffer for buf@%p\n", pr_debug("%s: using read bounce buffer for buf@%p\n",
...@@ -2555,7 +2555,7 @@ static int nand_do_read_ops(struct mtd_info *mtd, loff_t from, ...@@ -2555,7 +2555,7 @@ static int nand_do_read_ops(struct mtd_info *mtd, loff_t from,
/* Invalidate page cache */ /* Invalidate page cache */
chip->pagebuf = -1; chip->pagebuf = -1;
} }
memcpy(buf, chip->buffers->databuf + col, bytes); memcpy(buf, chip->data_buf + col, bytes);
} }
if (unlikely(oob)) { if (unlikely(oob)) {
...@@ -2596,7 +2596,7 @@ static int nand_do_read_ops(struct mtd_info *mtd, loff_t from, ...@@ -2596,7 +2596,7 @@ static int nand_do_read_ops(struct mtd_info *mtd, loff_t from,
buf += bytes; buf += bytes;
max_bitflips = max_t(unsigned int, max_bitflips, ret); max_bitflips = max_t(unsigned int, max_bitflips, ret);
} else { } else {
memcpy(buf, chip->buffers->databuf + col, bytes); memcpy(buf, chip->data_buf + col, bytes);
buf += bytes; buf += bytes;
max_bitflips = max_t(unsigned int, max_bitflips, max_bitflips = max_t(unsigned int, max_bitflips,
chip->pagebuf_bitflips); chip->pagebuf_bitflips);
...@@ -3071,7 +3071,7 @@ static int nand_write_page_swecc(struct mtd_info *mtd, struct nand_chip *chip, ...@@ -3071,7 +3071,7 @@ static int nand_write_page_swecc(struct mtd_info *mtd, struct nand_chip *chip,
int i, eccsize = chip->ecc.size, ret; int i, eccsize = chip->ecc.size, ret;
int eccbytes = chip->ecc.bytes; int eccbytes = chip->ecc.bytes;
int eccsteps = chip->ecc.steps; int eccsteps = chip->ecc.steps;
uint8_t *ecc_calc = chip->buffers->ecccalc; uint8_t *ecc_calc = chip->ecc.calc_buf;
const uint8_t *p = buf; const uint8_t *p = buf;
/* Software ECC calculation */ /* Software ECC calculation */
...@@ -3101,7 +3101,7 @@ static int nand_write_page_hwecc(struct mtd_info *mtd, struct nand_chip *chip, ...@@ -3101,7 +3101,7 @@ static int nand_write_page_hwecc(struct mtd_info *mtd, struct nand_chip *chip,
int i, eccsize = chip->ecc.size, ret; int i, eccsize = chip->ecc.size, ret;
int eccbytes = chip->ecc.bytes; int eccbytes = chip->ecc.bytes;
int eccsteps = chip->ecc.steps; int eccsteps = chip->ecc.steps;
uint8_t *ecc_calc = chip->buffers->ecccalc; uint8_t *ecc_calc = chip->ecc.calc_buf;
const uint8_t *p = buf; const uint8_t *p = buf;
ret = nand_prog_page_begin_op(chip, page, 0, NULL, 0); ret = nand_prog_page_begin_op(chip, page, 0, NULL, 0);
...@@ -3147,7 +3147,7 @@ static int nand_write_subpage_hwecc(struct mtd_info *mtd, ...@@ -3147,7 +3147,7 @@ static int nand_write_subpage_hwecc(struct mtd_info *mtd,
int oob_required, int page) int oob_required, int page)
{ {
uint8_t *oob_buf = chip->oob_poi; uint8_t *oob_buf = chip->oob_poi;
uint8_t *ecc_calc = chip->buffers->ecccalc; uint8_t *ecc_calc = chip->ecc.calc_buf;
int ecc_size = chip->ecc.size; int ecc_size = chip->ecc.size;
int ecc_bytes = chip->ecc.bytes; int ecc_bytes = chip->ecc.bytes;
int ecc_steps = chip->ecc.steps; int ecc_steps = chip->ecc.steps;
...@@ -3187,7 +3187,7 @@ static int nand_write_subpage_hwecc(struct mtd_info *mtd, ...@@ -3187,7 +3187,7 @@ static int nand_write_subpage_hwecc(struct mtd_info *mtd,
/* copy calculated ECC for whole page to chip->buffer->oob */ /* copy calculated ECC for whole page to chip->buffer->oob */
/* this include masked-value(0xFF) for unwritten subpages */ /* this include masked-value(0xFF) for unwritten subpages */
ecc_calc = chip->buffers->ecccalc; ecc_calc = chip->ecc.calc_buf;
ret = mtd_ooblayout_set_eccbytes(mtd, ecc_calc, chip->oob_poi, 0, ret = mtd_ooblayout_set_eccbytes(mtd, ecc_calc, chip->oob_poi, 0,
chip->ecc.total); chip->ecc.total);
if (ret) if (ret)
...@@ -3434,9 +3434,9 @@ static int nand_do_write_ops(struct mtd_info *mtd, loff_t to, ...@@ -3434,9 +3434,9 @@ static int nand_do_write_ops(struct mtd_info *mtd, loff_t to,
if (part_pagewr) if (part_pagewr)
bytes = min_t(int, bytes - column, writelen); bytes = min_t(int, bytes - column, writelen);
chip->pagebuf = -1; chip->pagebuf = -1;
memset(chip->buffers->databuf, 0xff, mtd->writesize); memset(chip->data_buf, 0xff, mtd->writesize);
memcpy(&chip->buffers->databuf[column], buf, bytes); memcpy(&chip->data_buf[column], buf, bytes);
wbuf = chip->buffers->databuf; wbuf = chip->data_buf;
} }
if (unlikely(oob)) { if (unlikely(oob)) {
...@@ -5310,7 +5310,6 @@ int nand_scan_tail(struct mtd_info *mtd) ...@@ -5310,7 +5310,6 @@ int nand_scan_tail(struct mtd_info *mtd)
{ {
struct nand_chip *chip = mtd_to_nand(mtd); struct nand_chip *chip = mtd_to_nand(mtd);
struct nand_ecc_ctrl *ecc = &chip->ecc; struct nand_ecc_ctrl *ecc = &chip->ecc;
struct nand_buffers *nbuf = NULL;
int ret, i; int ret, i;
/* New bad blocks should be marked in OOB, flash-based BBT, or both */ /* New bad blocks should be marked in OOB, flash-based BBT, or both */
...@@ -5319,30 +5318,22 @@ int nand_scan_tail(struct mtd_info *mtd) ...@@ -5319,30 +5318,22 @@ int nand_scan_tail(struct mtd_info *mtd)
return -EINVAL; return -EINVAL;
} }
nbuf = kzalloc(sizeof(*nbuf), GFP_KERNEL); ecc->calc_buf = kmalloc(mtd->oobsize, GFP_KERNEL);
if (!nbuf) if (!ecc->calc_buf)
return -ENOMEM; return -ENOMEM;
nbuf->ecccalc = kmalloc(mtd->oobsize, GFP_KERNEL); ecc->code_buf = kmalloc(mtd->oobsize, GFP_KERNEL);
if (!nbuf->ecccalc) { if (!ecc->code_buf) {
ret = -ENOMEM; ret = -ENOMEM;
goto err_free_nbuf; goto err_free_buf;
} }
nbuf->ecccode = kmalloc(mtd->oobsize, GFP_KERNEL); chip->data_buf = kmalloc(mtd->writesize + mtd->oobsize, GFP_KERNEL);
if (!nbuf->ecccode) { if (!chip->data_buf) {
ret = -ENOMEM; ret = -ENOMEM;
goto err_free_nbuf; goto err_free_buf;
} }
nbuf->databuf = kmalloc(mtd->writesize + mtd->oobsize, GFP_KERNEL);
if (!nbuf->databuf) {
ret = -ENOMEM;
goto err_free_nbuf;
}
chip->buffers = nbuf;
/* /*
* FIXME: some NAND manufacturer drivers expect the first die to be * FIXME: some NAND manufacturer drivers expect the first die to be
* selected when manufacturer->init() is called. They should be fixed * selected when manufacturer->init() is called. They should be fixed
...@@ -5353,10 +5344,10 @@ int nand_scan_tail(struct mtd_info *mtd) ...@@ -5353,10 +5344,10 @@ int nand_scan_tail(struct mtd_info *mtd)
ret = nand_manufacturer_init(chip); ret = nand_manufacturer_init(chip);
chip->select_chip(mtd, -1); chip->select_chip(mtd, -1);
if (ret) if (ret)
goto err_free_nbuf; goto err_free_buf;
/* Set the internal oob buffer location, just after the page data */ /* Set the internal oob buffer location, just after the page data */
chip->oob_poi = chip->buffers->databuf + mtd->writesize; chip->oob_poi = chip->data_buf + mtd->writesize;
/* /*
* If no default placement scheme is given, select an appropriate one. * If no default placement scheme is given, select an appropriate one.
...@@ -5640,13 +5631,10 @@ int nand_scan_tail(struct mtd_info *mtd) ...@@ -5640,13 +5631,10 @@ int nand_scan_tail(struct mtd_info *mtd)
err_nand_manuf_cleanup: err_nand_manuf_cleanup:
nand_manufacturer_cleanup(chip); nand_manufacturer_cleanup(chip);
err_free_nbuf: err_free_buf:
if (nbuf) { kfree(chip->data_buf);
kfree(nbuf->databuf); kfree(ecc->code_buf);
kfree(nbuf->ecccode); kfree(ecc->calc_buf);
kfree(nbuf->ecccalc);
kfree(nbuf);
}
return ret; return ret;
} }
...@@ -5696,12 +5684,9 @@ void nand_cleanup(struct nand_chip *chip) ...@@ -5696,12 +5684,9 @@ void nand_cleanup(struct nand_chip *chip)
/* Free bad block table memory */ /* Free bad block table memory */
kfree(chip->bbt); kfree(chip->bbt);
if (chip->buffers) { kfree(chip->data_buf);
kfree(chip->buffers->databuf); kfree(chip->ecc.code_buf);
kfree(chip->buffers->ecccode); kfree(chip->ecc.calc_buf);
kfree(chip->buffers->ecccalc);
kfree(chip->buffers);
}
/* Free bad block descriptor memory */ /* Free bad block descriptor memory */
if (chip->badblock_pattern && chip->badblock_pattern->options if (chip->badblock_pattern && chip->badblock_pattern->options
......
...@@ -898,7 +898,7 @@ static inline int nand_memory_bbt(struct mtd_info *mtd, struct nand_bbt_descr *b ...@@ -898,7 +898,7 @@ static inline int nand_memory_bbt(struct mtd_info *mtd, struct nand_bbt_descr *b
{ {
struct nand_chip *this = mtd_to_nand(mtd); struct nand_chip *this = mtd_to_nand(mtd);
return create_bbt(mtd, this->buffers->databuf, bd, -1); return create_bbt(mtd, this->data_buf, bd, -1);
} }
/** /**
......
...@@ -1530,7 +1530,7 @@ static int omap_write_page_bch(struct mtd_info *mtd, struct nand_chip *chip, ...@@ -1530,7 +1530,7 @@ static int omap_write_page_bch(struct mtd_info *mtd, struct nand_chip *chip,
const uint8_t *buf, int oob_required, int page) const uint8_t *buf, int oob_required, int page)
{ {
int ret; int ret;
uint8_t *ecc_calc = chip->buffers->ecccalc; uint8_t *ecc_calc = chip->ecc.calc_buf;
nand_prog_page_begin_op(chip, page, 0, NULL, 0); nand_prog_page_begin_op(chip, page, 0, NULL, 0);
...@@ -1571,7 +1571,7 @@ static int omap_write_subpage_bch(struct mtd_info *mtd, ...@@ -1571,7 +1571,7 @@ static int omap_write_subpage_bch(struct mtd_info *mtd,
u32 data_len, const u8 *buf, u32 data_len, const u8 *buf,
int oob_required, int page) int oob_required, int page)
{ {
u8 *ecc_calc = chip->buffers->ecccalc; u8 *ecc_calc = chip->ecc.calc_buf;
int ecc_size = chip->ecc.size; int ecc_size = chip->ecc.size;
int ecc_bytes = chip->ecc.bytes; int ecc_bytes = chip->ecc.bytes;
int ecc_steps = chip->ecc.steps; int ecc_steps = chip->ecc.steps;
...@@ -1609,7 +1609,7 @@ static int omap_write_subpage_bch(struct mtd_info *mtd, ...@@ -1609,7 +1609,7 @@ static int omap_write_subpage_bch(struct mtd_info *mtd,
/* copy calculated ECC for whole page to chip->buffer->oob */ /* copy calculated ECC for whole page to chip->buffer->oob */
/* this include masked-value(0xFF) for unwritten subpages */ /* this include masked-value(0xFF) for unwritten subpages */
ecc_calc = chip->buffers->ecccalc; ecc_calc = chip->ecc.calc_buf;
ret = mtd_ooblayout_set_eccbytes(mtd, ecc_calc, chip->oob_poi, 0, ret = mtd_ooblayout_set_eccbytes(mtd, ecc_calc, chip->oob_poi, 0,
chip->ecc.total); chip->ecc.total);
if (ret) if (ret)
...@@ -1639,8 +1639,8 @@ static int omap_write_subpage_bch(struct mtd_info *mtd, ...@@ -1639,8 +1639,8 @@ static int omap_write_subpage_bch(struct mtd_info *mtd,
static int omap_read_page_bch(struct mtd_info *mtd, struct nand_chip *chip, static int omap_read_page_bch(struct mtd_info *mtd, struct nand_chip *chip,
uint8_t *buf, int oob_required, int page) uint8_t *buf, int oob_required, int page)
{ {
uint8_t *ecc_calc = chip->buffers->ecccalc; uint8_t *ecc_calc = chip->ecc.calc_buf;
uint8_t *ecc_code = chip->buffers->ecccode; uint8_t *ecc_code = chip->ecc.code_buf;
int stat, ret; int stat, ret;
unsigned int max_bitflips = 0; unsigned int max_bitflips = 0;
......
...@@ -1555,7 +1555,7 @@ static int sunxi_nfc_hw_common_ecc_read_oob(struct mtd_info *mtd, ...@@ -1555,7 +1555,7 @@ static int sunxi_nfc_hw_common_ecc_read_oob(struct mtd_info *mtd,
{ {
chip->pagebuf = -1; chip->pagebuf = -1;
return chip->ecc.read_page(mtd, chip, chip->buffers->databuf, 1, page); return chip->ecc.read_page(mtd, chip, chip->data_buf, 1, page);
} }
static int sunxi_nfc_hw_common_ecc_write_oob(struct mtd_info *mtd, static int sunxi_nfc_hw_common_ecc_write_oob(struct mtd_info *mtd,
...@@ -1566,8 +1566,8 @@ static int sunxi_nfc_hw_common_ecc_write_oob(struct mtd_info *mtd, ...@@ -1566,8 +1566,8 @@ static int sunxi_nfc_hw_common_ecc_write_oob(struct mtd_info *mtd,
chip->pagebuf = -1; chip->pagebuf = -1;
memset(chip->buffers->databuf, 0xff, mtd->writesize); memset(chip->data_buf, 0xff, mtd->writesize);
ret = chip->ecc.write_page(mtd, chip, chip->buffers->databuf, 1, page); ret = chip->ecc.write_page(mtd, chip, chip->data_buf, 1, page);
if (ret) if (ret)
return ret; return ret;
......
...@@ -514,6 +514,8 @@ static const struct nand_ecc_caps __name = { \ ...@@ -514,6 +514,8 @@ static const struct nand_ecc_caps __name = { \
* @postpad: padding information for syndrome based ECC generators * @postpad: padding information for syndrome based ECC generators
* @options: ECC specific options (see NAND_ECC_XXX flags defined above) * @options: ECC specific options (see NAND_ECC_XXX flags defined above)
* @priv: pointer to private ECC control data * @priv: pointer to private ECC control data
* @calc_buf: buffer for calculated ECC, size is oobsize.
* @code_buf: buffer for ECC read from flash, size is oobsize.
* @hwctl: function to control hardware ECC generator. Must only * @hwctl: function to control hardware ECC generator. Must only
* be provided if an hardware ECC is available * be provided if an hardware ECC is available
* @calculate: function for ECC calculation or readback from ECC hardware * @calculate: function for ECC calculation or readback from ECC hardware
...@@ -564,6 +566,8 @@ struct nand_ecc_ctrl { ...@@ -564,6 +566,8 @@ struct nand_ecc_ctrl {
int postpad; int postpad;
unsigned int options; unsigned int options;
void *priv; void *priv;
u8 *calc_buf;
u8 *code_buf;
void (*hwctl)(struct mtd_info *mtd, int mode); void (*hwctl)(struct mtd_info *mtd, int mode);
int (*calculate)(struct mtd_info *mtd, const uint8_t *dat, int (*calculate)(struct mtd_info *mtd, const uint8_t *dat,
uint8_t *ecc_code); uint8_t *ecc_code);
...@@ -591,21 +595,6 @@ struct nand_ecc_ctrl { ...@@ -591,21 +595,6 @@ struct nand_ecc_ctrl {
int page); int page);
}; };
/**
* struct nand_buffers - buffer structure for read/write
* @ecccalc: buffer pointer for calculated ECC, size is oobsize.
* @ecccode: buffer pointer for ECC read from flash, size is oobsize.
* @databuf: buffer pointer for data, size is (page size + oobsize).
*
* Do not change the order of buffers. databuf and oobrbuf must be in
* consecutive order.
*/
struct nand_buffers {
uint8_t *ecccalc;
uint8_t *ecccode;
uint8_t *databuf;
};
/** /**
* struct nand_sdr_timings - SDR NAND chip timings * struct nand_sdr_timings - SDR NAND chip timings
* *
...@@ -774,7 +763,6 @@ struct nand_manufacturer_ops { ...@@ -774,7 +763,6 @@ struct nand_manufacturer_ops {
* @setup_read_retry: [FLASHSPECIFIC] flash (vendor) specific function for * @setup_read_retry: [FLASHSPECIFIC] flash (vendor) specific function for
* setting the read-retry mode. Mostly needed for MLC NAND. * setting the read-retry mode. Mostly needed for MLC NAND.
* @ecc: [BOARDSPECIFIC] ECC control structure * @ecc: [BOARDSPECIFIC] ECC control structure
* @buffers: buffer structure for read/write
* @buf_align: minimum buffer alignment required by a platform * @buf_align: minimum buffer alignment required by a platform
* @hwcontrol: platform-specific hardware control structure * @hwcontrol: platform-specific hardware control structure
* @erase: [REPLACEABLE] erase function * @erase: [REPLACEABLE] erase function
...@@ -814,6 +802,7 @@ struct nand_manufacturer_ops { ...@@ -814,6 +802,7 @@ struct nand_manufacturer_ops {
* @numchips: [INTERN] number of physical chips * @numchips: [INTERN] number of physical chips
* @chipsize: [INTERN] the size of one chip for multichip arrays * @chipsize: [INTERN] the size of one chip for multichip arrays
* @pagemask: [INTERN] page number mask = number of (pages / chip) - 1 * @pagemask: [INTERN] page number mask = number of (pages / chip) - 1
* @data_buf: [INTERN] buffer for data, size is (page size + oobsize).
* @pagebuf: [INTERN] holds the pagenumber which is currently in * @pagebuf: [INTERN] holds the pagenumber which is currently in
* data_buf. * data_buf.
* @pagebuf_bitflips: [INTERN] holds the bitflip count for the page which is * @pagebuf_bitflips: [INTERN] holds the bitflip count for the page which is
...@@ -892,6 +881,7 @@ struct nand_chip { ...@@ -892,6 +881,7 @@ struct nand_chip {
int numchips; int numchips;
uint64_t chipsize; uint64_t chipsize;
int pagemask; int pagemask;
u8 *data_buf;
int pagebuf; int pagebuf;
unsigned int pagebuf_bitflips; unsigned int pagebuf_bitflips;
int subpagesize; int subpagesize;
...@@ -922,7 +912,6 @@ struct nand_chip { ...@@ -922,7 +912,6 @@ struct nand_chip {
struct nand_hw_control *controller; struct nand_hw_control *controller;
struct nand_ecc_ctrl ecc; struct nand_ecc_ctrl ecc;
struct nand_buffers *buffers;
unsigned long buf_align; unsigned long buf_align;
struct nand_hw_control hwcontrol; struct nand_hw_control hwcontrol;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册