aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mtd
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/mtd')
-rw-r--r--drivers/mtd/nand/nand_base.c213
1 files changed, 104 insertions, 109 deletions
diff --git a/drivers/mtd/nand/nand_base.c b/drivers/mtd/nand/nand_base.c
index ec1db1e19c05..bd39f7b67906 100644
--- a/drivers/mtd/nand/nand_base.c
+++ b/drivers/mtd/nand/nand_base.c
@@ -3558,6 +3558,7 @@ int nand_scan_tail(struct mtd_info *mtd)
3558{ 3558{
3559 int i; 3559 int i;
3560 struct nand_chip *chip = mtd->priv; 3560 struct nand_chip *chip = mtd->priv;
3561 struct nand_ecc_ctrl *ecc = &chip->ecc;
3561 3562
3562 /* New bad blocks should be marked in OOB, flash-based BBT, or both */ 3563 /* New bad blocks should be marked in OOB, flash-based BBT, or both */
3563 BUG_ON((chip->bbt_options & NAND_BBT_NO_OOB_BBM) && 3564 BUG_ON((chip->bbt_options & NAND_BBT_NO_OOB_BBM) &&
@@ -3574,19 +3575,19 @@ int nand_scan_tail(struct mtd_info *mtd)
3574 /* 3575 /*
3575 * If no default placement scheme is given, select an appropriate one. 3576 * If no default placement scheme is given, select an appropriate one.
3576 */ 3577 */
3577 if (!chip->ecc.layout && (chip->ecc.mode != NAND_ECC_SOFT_BCH)) { 3578 if (!ecc->layout && (ecc->mode != NAND_ECC_SOFT_BCH)) {
3578 switch (mtd->oobsize) { 3579 switch (mtd->oobsize) {
3579 case 8: 3580 case 8:
3580 chip->ecc.layout = &nand_oob_8; 3581 ecc->layout = &nand_oob_8;
3581 break; 3582 break;
3582 case 16: 3583 case 16:
3583 chip->ecc.layout = &nand_oob_16; 3584 ecc->layout = &nand_oob_16;
3584 break; 3585 break;
3585 case 64: 3586 case 64:
3586 chip->ecc.layout = &nand_oob_64; 3587 ecc->layout = &nand_oob_64;
3587 break; 3588 break;
3588 case 128: 3589 case 128:
3589 chip->ecc.layout = &nand_oob_128; 3590 ecc->layout = &nand_oob_128;
3590 break; 3591 break;
3591 default: 3592 default:
3592 pr_warn("No oob scheme defined for oobsize %d\n", 3593 pr_warn("No oob scheme defined for oobsize %d\n",
@@ -3603,64 +3604,62 @@ int nand_scan_tail(struct mtd_info *mtd)
3603 * selected and we have 256 byte pagesize fallback to software ECC 3604 * selected and we have 256 byte pagesize fallback to software ECC
3604 */ 3605 */
3605 3606
3606 switch (chip->ecc.mode) { 3607 switch (ecc->mode) {
3607 case NAND_ECC_HW_OOB_FIRST: 3608 case NAND_ECC_HW_OOB_FIRST:
3608 /* Similar to NAND_ECC_HW, but a separate read_page handle */ 3609 /* Similar to NAND_ECC_HW, but a separate read_page handle */
3609 if (!chip->ecc.calculate || !chip->ecc.correct || 3610 if (!ecc->calculate || !ecc->correct || !ecc->hwctl) {
3610 !chip->ecc.hwctl) {
3611 pr_warn("No ECC functions supplied; " 3611 pr_warn("No ECC functions supplied; "
3612 "hardware ECC not possible\n"); 3612 "hardware ECC not possible\n");
3613 BUG(); 3613 BUG();
3614 } 3614 }
3615 if (!chip->ecc.read_page) 3615 if (!ecc->read_page)
3616 chip->ecc.read_page = nand_read_page_hwecc_oob_first; 3616 ecc->read_page = nand_read_page_hwecc_oob_first;
3617 3617
3618 case NAND_ECC_HW: 3618 case NAND_ECC_HW:
3619 /* Use standard hwecc read page function? */ 3619 /* Use standard hwecc read page function? */
3620 if (!chip->ecc.read_page) 3620 if (!ecc->read_page)
3621 chip->ecc.read_page = nand_read_page_hwecc; 3621 ecc->read_page = nand_read_page_hwecc;
3622 if (!chip->ecc.write_page) 3622 if (!ecc->write_page)
3623 chip->ecc.write_page = nand_write_page_hwecc; 3623 ecc->write_page = nand_write_page_hwecc;
3624 if (!chip->ecc.read_page_raw) 3624 if (!ecc->read_page_raw)
3625 chip->ecc.read_page_raw = nand_read_page_raw; 3625 ecc->read_page_raw = nand_read_page_raw;
3626 if (!chip->ecc.write_page_raw) 3626 if (!ecc->write_page_raw)
3627 chip->ecc.write_page_raw = nand_write_page_raw; 3627 ecc->write_page_raw = nand_write_page_raw;
3628 if (!chip->ecc.read_oob) 3628 if (!ecc->read_oob)
3629 chip->ecc.read_oob = nand_read_oob_std; 3629 ecc->read_oob = nand_read_oob_std;
3630 if (!chip->ecc.write_oob) 3630 if (!ecc->write_oob)
3631 chip->ecc.write_oob = nand_write_oob_std; 3631 ecc->write_oob = nand_write_oob_std;
3632 if (!chip->ecc.read_subpage) 3632 if (!ecc->read_subpage)
3633 chip->ecc.read_subpage = nand_read_subpage; 3633 ecc->read_subpage = nand_read_subpage;
3634 if (!chip->ecc.write_subpage) 3634 if (!ecc->write_subpage)
3635 chip->ecc.write_subpage = nand_write_subpage_hwecc; 3635 ecc->write_subpage = nand_write_subpage_hwecc;
3636 3636
3637 case NAND_ECC_HW_SYNDROME: 3637 case NAND_ECC_HW_SYNDROME:
3638 if ((!chip->ecc.calculate || !chip->ecc.correct || 3638 if ((!ecc->calculate || !ecc->correct || !ecc->hwctl) &&
3639 !chip->ecc.hwctl) && 3639 (!ecc->read_page ||
3640 (!chip->ecc.read_page || 3640 ecc->read_page == nand_read_page_hwecc ||
3641 chip->ecc.read_page == nand_read_page_hwecc || 3641 !ecc->write_page ||
3642 !chip->ecc.write_page || 3642 ecc->write_page == nand_write_page_hwecc)) {
3643 chip->ecc.write_page == nand_write_page_hwecc)) {
3644 pr_warn("No ECC functions supplied; " 3643 pr_warn("No ECC functions supplied; "
3645 "hardware ECC not possible\n"); 3644 "hardware ECC not possible\n");
3646 BUG(); 3645 BUG();
3647 } 3646 }
3648 /* Use standard syndrome read/write page function? */ 3647 /* Use standard syndrome read/write page function? */
3649 if (!chip->ecc.read_page) 3648 if (!ecc->read_page)
3650 chip->ecc.read_page = nand_read_page_syndrome; 3649 ecc->read_page = nand_read_page_syndrome;
3651 if (!chip->ecc.write_page) 3650 if (!ecc->write_page)
3652 chip->ecc.write_page = nand_write_page_syndrome; 3651 ecc->write_page = nand_write_page_syndrome;
3653 if (!chip->ecc.read_page_raw) 3652 if (!ecc->read_page_raw)
3654 chip->ecc.read_page_raw = nand_read_page_raw_syndrome; 3653 ecc->read_page_raw = nand_read_page_raw_syndrome;
3655 if (!chip->ecc.write_page_raw) 3654 if (!ecc->write_page_raw)
3656 chip->ecc.write_page_raw = nand_write_page_raw_syndrome; 3655 ecc->write_page_raw = nand_write_page_raw_syndrome;
3657 if (!chip->ecc.read_oob) 3656 if (!ecc->read_oob)
3658 chip->ecc.read_oob = nand_read_oob_syndrome; 3657 ecc->read_oob = nand_read_oob_syndrome;
3659 if (!chip->ecc.write_oob) 3658 if (!ecc->write_oob)
3660 chip->ecc.write_oob = nand_write_oob_syndrome; 3659 ecc->write_oob = nand_write_oob_syndrome;
3661 3660
3662 if (mtd->writesize >= chip->ecc.size) { 3661 if (mtd->writesize >= ecc->size) {
3663 if (!chip->ecc.strength) { 3662 if (!ecc->strength) {
3664 pr_warn("Driver must set ecc.strength when using hardware ECC\n"); 3663 pr_warn("Driver must set ecc.strength when using hardware ECC\n");
3665 BUG(); 3664 BUG();
3666 } 3665 }
@@ -3668,23 +3667,23 @@ int nand_scan_tail(struct mtd_info *mtd)
3668 } 3667 }
3669 pr_warn("%d byte HW ECC not possible on " 3668 pr_warn("%d byte HW ECC not possible on "
3670 "%d byte page size, fallback to SW ECC\n", 3669 "%d byte page size, fallback to SW ECC\n",
3671 chip->ecc.size, mtd->writesize); 3670 ecc->size, mtd->writesize);
3672 chip->ecc.mode = NAND_ECC_SOFT; 3671 ecc->mode = NAND_ECC_SOFT;
3673 3672
3674 case NAND_ECC_SOFT: 3673 case NAND_ECC_SOFT:
3675 chip->ecc.calculate = nand_calculate_ecc; 3674 ecc->calculate = nand_calculate_ecc;
3676 chip->ecc.correct = nand_correct_data; 3675 ecc->correct = nand_correct_data;
3677 chip->ecc.read_page = nand_read_page_swecc; 3676 ecc->read_page = nand_read_page_swecc;
3678 chip->ecc.read_subpage = nand_read_subpage; 3677 ecc->read_subpage = nand_read_subpage;
3679 chip->ecc.write_page = nand_write_page_swecc; 3678 ecc->write_page = nand_write_page_swecc;
3680 chip->ecc.read_page_raw = nand_read_page_raw; 3679 ecc->read_page_raw = nand_read_page_raw;
3681 chip->ecc.write_page_raw = nand_write_page_raw; 3680 ecc->write_page_raw = nand_write_page_raw;
3682 chip->ecc.read_oob = nand_read_oob_std; 3681 ecc->read_oob = nand_read_oob_std;
3683 chip->ecc.write_oob = nand_write_oob_std; 3682 ecc->write_oob = nand_write_oob_std;
3684 if (!chip->ecc.size) 3683 if (!ecc->size)
3685 chip->ecc.size = 256; 3684 ecc->size = 256;
3686 chip->ecc.bytes = 3; 3685 ecc->bytes = 3;
3687 chip->ecc.strength = 1; 3686 ecc->strength = 1;
3688 break; 3687 break;
3689 3688
3690 case NAND_ECC_SOFT_BCH: 3689 case NAND_ECC_SOFT_BCH:
@@ -3692,87 +3691,83 @@ int nand_scan_tail(struct mtd_info *mtd)
3692 pr_warn("CONFIG_MTD_ECC_BCH not enabled\n"); 3691 pr_warn("CONFIG_MTD_ECC_BCH not enabled\n");
3693 BUG(); 3692 BUG();
3694 } 3693 }
3695 chip->ecc.calculate = nand_bch_calculate_ecc; 3694 ecc->calculate = nand_bch_calculate_ecc;
3696 chip->ecc.correct = nand_bch_correct_data; 3695 ecc->correct = nand_bch_correct_data;
3697 chip->ecc.read_page = nand_read_page_swecc; 3696 ecc->read_page = nand_read_page_swecc;
3698 chip->ecc.read_subpage = nand_read_subpage; 3697 ecc->read_subpage = nand_read_subpage;
3699 chip->ecc.write_page = nand_write_page_swecc; 3698 ecc->write_page = nand_write_page_swecc;
3700 chip->ecc.read_page_raw = nand_read_page_raw; 3699 ecc->read_page_raw = nand_read_page_raw;
3701 chip->ecc.write_page_raw = nand_write_page_raw; 3700 ecc->write_page_raw = nand_write_page_raw;
3702 chip->ecc.read_oob = nand_read_oob_std; 3701 ecc->read_oob = nand_read_oob_std;
3703 chip->ecc.write_oob = nand_write_oob_std; 3702 ecc->write_oob = nand_write_oob_std;
3704 /* 3703 /*
3705 * Board driver should supply ecc.size and ecc.bytes values to 3704 * Board driver should supply ecc.size and ecc.bytes values to
3706 * select how many bits are correctable; see nand_bch_init() 3705 * select how many bits are correctable; see nand_bch_init()
3707 * for details. Otherwise, default to 4 bits for large page 3706 * for details. Otherwise, default to 4 bits for large page
3708 * devices. 3707 * devices.
3709 */ 3708 */
3710 if (!chip->ecc.size && (mtd->oobsize >= 64)) { 3709 if (!ecc->size && (mtd->oobsize >= 64)) {
3711 chip->ecc.size = 512; 3710 ecc->size = 512;
3712 chip->ecc.bytes = 7; 3711 ecc->bytes = 7;
3713 } 3712 }
3714 chip->ecc.priv = nand_bch_init(mtd, 3713 ecc->priv = nand_bch_init(mtd, ecc->size, ecc->bytes,
3715 chip->ecc.size, 3714 &ecc->layout);
3716 chip->ecc.bytes, 3715 if (!ecc->priv) {
3717 &chip->ecc.layout);
3718 if (!chip->ecc.priv) {
3719 pr_warn("BCH ECC initialization failed!\n"); 3716 pr_warn("BCH ECC initialization failed!\n");
3720 BUG(); 3717 BUG();
3721 } 3718 }
3722 chip->ecc.strength = 3719 ecc->strength = ecc->bytes * 8 / fls(8 * ecc->size);
3723 chip->ecc.bytes * 8 / fls(8 * chip->ecc.size);
3724 break; 3720 break;
3725 3721
3726 case NAND_ECC_NONE: 3722 case NAND_ECC_NONE:
3727 pr_warn("NAND_ECC_NONE selected by board driver. " 3723 pr_warn("NAND_ECC_NONE selected by board driver. "
3728 "This is not recommended!\n"); 3724 "This is not recommended!\n");
3729 chip->ecc.read_page = nand_read_page_raw; 3725 ecc->read_page = nand_read_page_raw;
3730 chip->ecc.write_page = nand_write_page_raw; 3726 ecc->write_page = nand_write_page_raw;
3731 chip->ecc.read_oob = nand_read_oob_std; 3727 ecc->read_oob = nand_read_oob_std;
3732 chip->ecc.read_page_raw = nand_read_page_raw; 3728 ecc->read_page_raw = nand_read_page_raw;
3733 chip->ecc.write_page_raw = nand_write_page_raw; 3729 ecc->write_page_raw = nand_write_page_raw;
3734 chip->ecc.write_oob = nand_write_oob_std; 3730 ecc->write_oob = nand_write_oob_std;
3735 chip->ecc.size = mtd->writesize; 3731 ecc->size = mtd->writesize;
3736 chip->ecc.bytes = 0; 3732 ecc->bytes = 0;
3737 chip->ecc.strength = 0; 3733 ecc->strength = 0;
3738 break; 3734 break;
3739 3735
3740 default: 3736 default:
3741 pr_warn("Invalid NAND_ECC_MODE %d\n", chip->ecc.mode); 3737 pr_warn("Invalid NAND_ECC_MODE %d\n", ecc->mode);
3742 BUG(); 3738 BUG();
3743 } 3739 }
3744 3740
3745 /* For many systems, the standard OOB write also works for raw */ 3741 /* For many systems, the standard OOB write also works for raw */
3746 if (!chip->ecc.read_oob_raw) 3742 if (!ecc->read_oob_raw)
3747 chip->ecc.read_oob_raw = chip->ecc.read_oob; 3743 ecc->read_oob_raw = ecc->read_oob;
3748 if (!chip->ecc.write_oob_raw) 3744 if (!ecc->write_oob_raw)
3749 chip->ecc.write_oob_raw = chip->ecc.write_oob; 3745 ecc->write_oob_raw = ecc->write_oob;
3750 3746
3751 /* 3747 /*
3752 * The number of bytes available for a client to place data into 3748 * The number of bytes available for a client to place data into
3753 * the out of band area. 3749 * the out of band area.
3754 */ 3750 */
3755 chip->ecc.layout->oobavail = 0; 3751 ecc->layout->oobavail = 0;
3756 for (i = 0; chip->ecc.layout->oobfree[i].length 3752 for (i = 0; ecc->layout->oobfree[i].length
3757 && i < ARRAY_SIZE(chip->ecc.layout->oobfree); i++) 3753 && i < ARRAY_SIZE(ecc->layout->oobfree); i++)
3758 chip->ecc.layout->oobavail += 3754 ecc->layout->oobavail += ecc->layout->oobfree[i].length;
3759 chip->ecc.layout->oobfree[i].length; 3755 mtd->oobavail = ecc->layout->oobavail;
3760 mtd->oobavail = chip->ecc.layout->oobavail;
3761 3756
3762 /* 3757 /*
3763 * Set the number of read / write steps for one page depending on ECC 3758 * Set the number of read / write steps for one page depending on ECC
3764 * mode. 3759 * mode.
3765 */ 3760 */
3766 chip->ecc.steps = mtd->writesize / chip->ecc.size; 3761 ecc->steps = mtd->writesize / ecc->size;
3767 if (chip->ecc.steps * chip->ecc.size != mtd->writesize) { 3762 if (ecc->steps * ecc->size != mtd->writesize) {
3768 pr_warn("Invalid ECC parameters\n"); 3763 pr_warn("Invalid ECC parameters\n");
3769 BUG(); 3764 BUG();
3770 } 3765 }
3771 chip->ecc.total = chip->ecc.steps * chip->ecc.bytes; 3766 ecc->total = ecc->steps * ecc->bytes;
3772 3767
3773 /* Allow subpage writes up to ecc.steps. Not possible for MLC flash */ 3768 /* Allow subpage writes up to ecc.steps. Not possible for MLC flash */
3774 if (!(chip->options & NAND_NO_SUBPAGE_WRITE) && nand_is_slc(chip)) { 3769 if (!(chip->options & NAND_NO_SUBPAGE_WRITE) && nand_is_slc(chip)) {
3775 switch (chip->ecc.steps) { 3770 switch (ecc->steps) {
3776 case 2: 3771 case 2:
3777 mtd->subpage_sft = 1; 3772 mtd->subpage_sft = 1;
3778 break; 3773 break;
@@ -3792,7 +3787,7 @@ int nand_scan_tail(struct mtd_info *mtd)
3792 chip->pagebuf = -1; 3787 chip->pagebuf = -1;
3793 3788
3794 /* Large page NAND with SOFT_ECC should support subpage reads */ 3789 /* Large page NAND with SOFT_ECC should support subpage reads */
3795 if ((chip->ecc.mode == NAND_ECC_SOFT) && (chip->page_shift > 9)) 3790 if ((ecc->mode == NAND_ECC_SOFT) && (chip->page_shift > 9))
3796 chip->options |= NAND_SUBPAGE_READ; 3791 chip->options |= NAND_SUBPAGE_READ;
3797 3792
3798 /* Fill in remaining MTD driver data */ 3793 /* Fill in remaining MTD driver data */
@@ -3817,9 +3812,9 @@ int nand_scan_tail(struct mtd_info *mtd)
3817 mtd->writebufsize = mtd->writesize; 3812 mtd->writebufsize = mtd->writesize;
3818 3813
3819 /* propagate ecc info to mtd_info */ 3814 /* propagate ecc info to mtd_info */
3820 mtd->ecclayout = chip->ecc.layout; 3815 mtd->ecclayout = ecc->layout;
3821 mtd->ecc_strength = chip->ecc.strength; 3816 mtd->ecc_strength = ecc->strength;
3822 mtd->ecc_step_size = chip->ecc.size; 3817 mtd->ecc_step_size = ecc->size;
3823 /* 3818 /*
3824 * Initialize bitflip_threshold to its default prior scan_bbt() call. 3819 * Initialize bitflip_threshold to its default prior scan_bbt() call.
3825 * scan_bbt() might invoke mtd_read(), thus bitflip_threshold must be 3820 * scan_bbt() might invoke mtd_read(), thus bitflip_threshold must be