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

mtd: nand: introduce NAND_ROW_ADDR_3 flag

Several drivers check ->chipsize to see if the third row address cycle
is needed.  Instead of embedding magic sizes such as 32MB, 128MB in
drivers, introduce a new flag NAND_ROW_ADDR_3 for clean-up.  Since
nand_scan_ident() knows well about the device, it can handle this
properly.  The flag is set if the row address bit width is greater
than 16.

Delete comments such as "One more address cycle for ..." because
intention is now clear enough from the code.
Signed-off-by: NMasahiro Yamada <yamada.masahiro@socionext.com>
Acked-by: NWenyou Yang <wenyou.yang@microchip.com>
Signed-off-by: NBoris Brezillon <boris.brezillon@free-electrons.com>
上级 882fd157
...@@ -718,8 +718,7 @@ static void atmel_nfc_set_op_addr(struct nand_chip *chip, int page, int column) ...@@ -718,8 +718,7 @@ static void atmel_nfc_set_op_addr(struct nand_chip *chip, int page, int column)
nc->op.addrs[nc->op.naddrs++] = page; nc->op.addrs[nc->op.naddrs++] = page;
nc->op.addrs[nc->op.naddrs++] = page >> 8; nc->op.addrs[nc->op.naddrs++] = page >> 8;
if ((mtd->writesize > 512 && chip->chipsize > SZ_128M) || if (chip->options & NAND_ROW_ADDR_3)
(mtd->writesize <= 512 && chip->chipsize > SZ_32M))
nc->op.addrs[nc->op.naddrs++] = page >> 16; nc->op.addrs[nc->op.naddrs++] = page >> 16;
} }
} }
......
...@@ -331,8 +331,7 @@ static void au1550_command(struct mtd_info *mtd, unsigned command, int column, i ...@@ -331,8 +331,7 @@ static void au1550_command(struct mtd_info *mtd, unsigned command, int column, i
ctx->write_byte(mtd, (u8)(page_addr >> 8)); ctx->write_byte(mtd, (u8)(page_addr >> 8));
/* One more address cycle for devices > 32MiB */ if (this->options & NAND_ROW_ADDR_3)
if (this->chipsize > (32 << 20))
ctx->write_byte(mtd, ctx->write_byte(mtd,
((page_addr >> 16) & 0x0f)); ((page_addr >> 16) & 0x0f));
} }
......
...@@ -705,8 +705,7 @@ static void doc2001plus_command(struct mtd_info *mtd, unsigned command, int colu ...@@ -705,8 +705,7 @@ static void doc2001plus_command(struct mtd_info *mtd, unsigned command, int colu
if (page_addr != -1) { if (page_addr != -1) {
WriteDOC((unsigned char)(page_addr & 0xff), docptr, Mplus_FlashAddress); WriteDOC((unsigned char)(page_addr & 0xff), docptr, Mplus_FlashAddress);
WriteDOC((unsigned char)((page_addr >> 8) & 0xff), docptr, Mplus_FlashAddress); WriteDOC((unsigned char)((page_addr >> 8) & 0xff), docptr, Mplus_FlashAddress);
/* One more address cycle for higher density devices */ if (this->options & NAND_ROW_ADDR_3) {
if (this->chipsize & 0x0c000000) {
WriteDOC((unsigned char)((page_addr >> 16) & 0x0f), docptr, Mplus_FlashAddress); WriteDOC((unsigned char)((page_addr >> 16) & 0x0f), docptr, Mplus_FlashAddress);
printk("high density\n"); printk("high density\n");
} }
......
...@@ -432,8 +432,7 @@ static void set_addr(struct mtd_info *mtd, int column, int page_addr) ...@@ -432,8 +432,7 @@ static void set_addr(struct mtd_info *mtd, int column, int page_addr)
host->addr_value[0] |= (page_addr & 0xffff) host->addr_value[0] |= (page_addr & 0xffff)
<< (host->addr_cycle * 8); << (host->addr_cycle * 8);
host->addr_cycle += 2; host->addr_cycle += 2;
/* One more address cycle for devices > 128MiB */ if (chip->options & NAND_ROW_ADDR_3) {
if (chip->chipsize > (128 << 20)) {
host->addr_cycle += 1; host->addr_cycle += 1;
if (host->command == NAND_CMD_ERASE1) if (host->command == NAND_CMD_ERASE1)
host->addr_value[0] |= ((page_addr >> 16) & 0xff) << 16; host->addr_value[0] |= ((page_addr >> 16) & 0xff) << 16;
......
...@@ -859,8 +859,7 @@ static void mxc_do_addr_cycle(struct mtd_info *mtd, int column, int page_addr) ...@@ -859,8 +859,7 @@ static void mxc_do_addr_cycle(struct mtd_info *mtd, int column, int page_addr)
host->devtype_data->send_addr(host, host->devtype_data->send_addr(host,
(page_addr >> 8) & 0xff, true); (page_addr >> 8) & 0xff, true);
} else { } else {
/* One more address cycle for higher density devices */ if (nand_chip->options & NAND_ROW_ADDR_3) {
if (mtd->size >= 0x4000000) {
/* paddr_8 - paddr_15 */ /* paddr_8 - paddr_15 */
host->devtype_data->send_addr(host, host->devtype_data->send_addr(host,
(page_addr >> 8) & 0xff, (page_addr >> 8) & 0xff,
......
...@@ -727,8 +727,7 @@ static void nand_command(struct mtd_info *mtd, unsigned int command, ...@@ -727,8 +727,7 @@ static void nand_command(struct mtd_info *mtd, unsigned int command,
chip->cmd_ctrl(mtd, page_addr, ctrl); chip->cmd_ctrl(mtd, page_addr, ctrl);
ctrl &= ~NAND_CTRL_CHANGE; ctrl &= ~NAND_CTRL_CHANGE;
chip->cmd_ctrl(mtd, page_addr >> 8, ctrl); chip->cmd_ctrl(mtd, page_addr >> 8, ctrl);
/* One more address cycle for devices > 32MiB */ if (chip->options & NAND_ROW_ADDR_3)
if (chip->chipsize > (32 << 20))
chip->cmd_ctrl(mtd, page_addr >> 16, ctrl); chip->cmd_ctrl(mtd, page_addr >> 16, ctrl);
} }
chip->cmd_ctrl(mtd, NAND_CMD_NONE, NAND_NCE | NAND_CTRL_CHANGE); chip->cmd_ctrl(mtd, NAND_CMD_NONE, NAND_NCE | NAND_CTRL_CHANGE);
...@@ -854,8 +853,7 @@ static void nand_command_lp(struct mtd_info *mtd, unsigned int command, ...@@ -854,8 +853,7 @@ static void nand_command_lp(struct mtd_info *mtd, unsigned int command,
chip->cmd_ctrl(mtd, page_addr, ctrl); chip->cmd_ctrl(mtd, page_addr, ctrl);
chip->cmd_ctrl(mtd, page_addr >> 8, chip->cmd_ctrl(mtd, page_addr >> 8,
NAND_NCE | NAND_ALE); NAND_NCE | NAND_ALE);
/* One more address cycle for devices > 128MiB */ if (chip->options & NAND_ROW_ADDR_3)
if (chip->chipsize > (128 << 20))
chip->cmd_ctrl(mtd, page_addr >> 16, chip->cmd_ctrl(mtd, page_addr >> 16,
NAND_NCE | NAND_ALE); NAND_NCE | NAND_ALE);
} }
...@@ -4000,6 +3998,9 @@ static int nand_detect(struct nand_chip *chip, struct nand_flash_dev *type) ...@@ -4000,6 +3998,9 @@ static int nand_detect(struct nand_chip *chip, struct nand_flash_dev *type)
chip->chip_shift += 32 - 1; chip->chip_shift += 32 - 1;
} }
if (chip->chip_shift - chip->page_shift > 16)
chip->options |= NAND_ROW_ADDR_3;
chip->badblockbits = 8; chip->badblockbits = 8;
chip->erase = single_erase; chip->erase = single_erase;
......
...@@ -154,7 +154,7 @@ static void nuc900_nand_command_lp(struct mtd_info *mtd, unsigned int command, ...@@ -154,7 +154,7 @@ static void nuc900_nand_command_lp(struct mtd_info *mtd, unsigned int command,
if (page_addr != -1) { if (page_addr != -1) {
write_addr_reg(nand, page_addr); write_addr_reg(nand, page_addr);
if (chip->chipsize > (128 << 20)) { if (chip->options & NAND_ROW_ADDR_3) {
write_addr_reg(nand, page_addr >> 8); write_addr_reg(nand, page_addr >> 8);
write_addr_reg(nand, page_addr >> 16 | ENDADDR); write_addr_reg(nand, page_addr >> 16 | ENDADDR);
} else { } else {
......
...@@ -177,6 +177,9 @@ enum nand_ecc_algo { ...@@ -177,6 +177,9 @@ enum nand_ecc_algo {
*/ */
#define NAND_NEED_SCRAMBLING 0x00002000 #define NAND_NEED_SCRAMBLING 0x00002000
/* Device needs 3rd row address cycle */
#define NAND_ROW_ADDR_3 0x00004000
/* Options valid for Samsung large page devices */ /* Options valid for Samsung large page devices */
#define NAND_SAMSUNG_LP_OPTIONS NAND_CACHEPRG #define NAND_SAMSUNG_LP_OPTIONS NAND_CACHEPRG
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册