aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mtd
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/mtd')
-rw-r--r--drivers/mtd/nand/mxc_nand.c87
1 files changed, 47 insertions, 40 deletions
diff --git a/drivers/mtd/nand/mxc_nand.c b/drivers/mtd/nand/mxc_nand.c
index 8aa8a429e6b8..325645c60488 100644
--- a/drivers/mtd/nand/mxc_nand.c
+++ b/drivers/mtd/nand/mxc_nand.c
@@ -658,6 +658,52 @@ static void mxc_nand_select_chip(struct mtd_info *mtd, int chip)
658 } 658 }
659} 659}
660 660
661static void mxc_do_addr_cycle(struct mtd_info *mtd, int column, int page_addr)
662{
663 struct nand_chip *nand_chip = mtd->priv;
664 struct mxc_nand_host *host = nand_chip->priv;
665
666 /* Write out column address, if necessary */
667 if (column != -1) {
668 /*
669 * MXC NANDFC can only perform full page+spare or
670 * spare-only read/write. When the upper layers
671 * layers perform a read/write buf operation,
672 * we will used the saved column adress to index into
673 * the full page.
674 */
675 send_addr(host, 0, page_addr == -1);
676 if (host->pagesize_2k)
677 /* another col addr cycle for 2k page */
678 send_addr(host, 0, false);
679 }
680
681 /* Write out page address, if necessary */
682 if (page_addr != -1) {
683 /* paddr_0 - p_addr_7 */
684 send_addr(host, (page_addr & 0xff), false);
685
686 if (host->pagesize_2k) {
687 if (mtd->size >= 0x10000000) {
688 /* paddr_8 - paddr_15 */
689 send_addr(host, (page_addr >> 8) & 0xff, false);
690 send_addr(host, (page_addr >> 16) & 0xff, true);
691 } else
692 /* paddr_8 - paddr_15 */
693 send_addr(host, (page_addr >> 8) & 0xff, true);
694 } else {
695 /* One more address cycle for higher density devices */
696 if (mtd->size >= 0x4000000) {
697 /* paddr_8 - paddr_15 */
698 send_addr(host, (page_addr >> 8) & 0xff, false);
699 send_addr(host, (page_addr >> 16) & 0xff, true);
700 } else
701 /* paddr_8 - paddr_15 */
702 send_addr(host, (page_addr >> 8) & 0xff, true);
703 }
704 }
705}
706
661/* Used by the upper layer to write command to NAND Flash for 707/* Used by the upper layer to write command to NAND Flash for
662 * different operations to be carried out on NAND Flash */ 708 * different operations to be carried out on NAND Flash */
663static void mxc_nand_command(struct mtd_info *mtd, unsigned command, 709static void mxc_nand_command(struct mtd_info *mtd, unsigned command,
@@ -746,46 +792,7 @@ static void mxc_nand_command(struct mtd_info *mtd, unsigned command,
746 792
747 /* Write out the command to the device. */ 793 /* Write out the command to the device. */
748 send_cmd(host, command, useirq); 794 send_cmd(host, command, useirq);
749 795 mxc_do_addr_cycle(mtd, column, page_addr);
750 /* Write out column address, if necessary */
751 if (column != -1) {
752 /*
753 * MXC NANDFC can only perform full page+spare or
754 * spare-only read/write. When the upper layers
755 * layers perform a read/write buf operation,
756 * we will used the saved column adress to index into
757 * the full page.
758 */
759 send_addr(host, 0, page_addr == -1);
760 if (host->pagesize_2k)
761 /* another col addr cycle for 2k page */
762 send_addr(host, 0, false);
763 }
764
765 /* Write out page address, if necessary */
766 if (page_addr != -1) {
767 /* paddr_0 - p_addr_7 */
768 send_addr(host, (page_addr & 0xff), false);
769
770 if (host->pagesize_2k) {
771 if (mtd->size >= 0x10000000) {
772 /* paddr_8 - paddr_15 */
773 send_addr(host, (page_addr >> 8) & 0xff, false);
774 send_addr(host, (page_addr >> 16) & 0xff, true);
775 } else
776 /* paddr_8 - paddr_15 */
777 send_addr(host, (page_addr >> 8) & 0xff, true);
778 } else {
779 /* One more address cycle for higher density devices */
780 if (mtd->size >= 0x4000000) {
781 /* paddr_8 - paddr_15 */
782 send_addr(host, (page_addr >> 8) & 0xff, false);
783 send_addr(host, (page_addr >> 16) & 0xff, true);
784 } else
785 /* paddr_8 - paddr_15 */
786 send_addr(host, (page_addr >> 8) & 0xff, true);
787 }
788 }
789 796
790 /* Command post-processing step */ 797 /* Command post-processing step */
791 switch (command) { 798 switch (command) {