|
@@ -232,7 +232,7 @@ static void set_addr(struct mtd_info *mtd, int column, int page_addr, int oob)
|
|
struct nand_chip *chip = mtd_to_nand(mtd);
|
|
struct nand_chip *chip = mtd_to_nand(mtd);
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
- struct fsl_ifc_regs __iomem *ifc = ctrl->regs;
|
|
|
|
|
|
+ struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
|
|
int buf_num;
|
|
int buf_num;
|
|
|
|
|
|
ifc_nand_ctrl->page = page_addr;
|
|
ifc_nand_ctrl->page = page_addr;
|
|
@@ -295,7 +295,7 @@ static void fsl_ifc_run_command(struct mtd_info *mtd)
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
struct fsl_ifc_nand_ctrl *nctrl = ifc_nand_ctrl;
|
|
struct fsl_ifc_nand_ctrl *nctrl = ifc_nand_ctrl;
|
|
- struct fsl_ifc_regs __iomem *ifc = ctrl->regs;
|
|
|
|
|
|
+ struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
|
|
u32 eccstat[4];
|
|
u32 eccstat[4];
|
|
int i;
|
|
int i;
|
|
|
|
|
|
@@ -371,7 +371,7 @@ static void fsl_ifc_do_read(struct nand_chip *chip,
|
|
{
|
|
{
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
- struct fsl_ifc_regs __iomem *ifc = ctrl->regs;
|
|
|
|
|
|
+ struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
|
|
|
|
|
|
/* Program FIR/IFC_NAND_FCR0 for Small/Large page */
|
|
/* Program FIR/IFC_NAND_FCR0 for Small/Large page */
|
|
if (mtd->writesize > 512) {
|
|
if (mtd->writesize > 512) {
|
|
@@ -411,7 +411,7 @@ static void fsl_ifc_cmdfunc(struct mtd_info *mtd, unsigned int command,
|
|
struct nand_chip *chip = mtd_to_nand(mtd);
|
|
struct nand_chip *chip = mtd_to_nand(mtd);
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
- struct fsl_ifc_regs __iomem *ifc = ctrl->regs;
|
|
|
|
|
|
+ struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
|
|
|
|
|
|
/* clear the read buffer */
|
|
/* clear the read buffer */
|
|
ifc_nand_ctrl->read_bytes = 0;
|
|
ifc_nand_ctrl->read_bytes = 0;
|
|
@@ -723,7 +723,7 @@ static int fsl_ifc_wait(struct mtd_info *mtd, struct nand_chip *chip)
|
|
{
|
|
{
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_mtd *priv = nand_get_controller_data(chip);
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
- struct fsl_ifc_regs __iomem *ifc = ctrl->regs;
|
|
|
|
|
|
+ struct fsl_ifc_runtime __iomem *ifc = ctrl->rregs;
|
|
u32 nand_fsr;
|
|
u32 nand_fsr;
|
|
|
|
|
|
/* Use READ_STATUS command, but wait for the device to be ready */
|
|
/* Use READ_STATUS command, but wait for the device to be ready */
|
|
@@ -825,39 +825,42 @@ static int fsl_ifc_chip_init_tail(struct mtd_info *mtd)
|
|
static void fsl_ifc_sram_init(struct fsl_ifc_mtd *priv)
|
|
static void fsl_ifc_sram_init(struct fsl_ifc_mtd *priv)
|
|
{
|
|
{
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
- struct fsl_ifc_regs __iomem *ifc = ctrl->regs;
|
|
|
|
|
|
+ struct fsl_ifc_runtime __iomem *ifc_runtime = ctrl->rregs;
|
|
|
|
+ struct fsl_ifc_global __iomem *ifc_global = ctrl->gregs;
|
|
uint32_t csor = 0, csor_8k = 0, csor_ext = 0;
|
|
uint32_t csor = 0, csor_8k = 0, csor_ext = 0;
|
|
uint32_t cs = priv->bank;
|
|
uint32_t cs = priv->bank;
|
|
|
|
|
|
/* Save CSOR and CSOR_ext */
|
|
/* Save CSOR and CSOR_ext */
|
|
- csor = ifc_in32(&ifc->csor_cs[cs].csor);
|
|
|
|
- csor_ext = ifc_in32(&ifc->csor_cs[cs].csor_ext);
|
|
|
|
|
|
+ csor = ifc_in32(&ifc_global->csor_cs[cs].csor);
|
|
|
|
+ csor_ext = ifc_in32(&ifc_global->csor_cs[cs].csor_ext);
|
|
|
|
|
|
/* chage PageSize 8K and SpareSize 1K*/
|
|
/* chage PageSize 8K and SpareSize 1K*/
|
|
csor_8k = (csor & ~(CSOR_NAND_PGS_MASK)) | 0x0018C000;
|
|
csor_8k = (csor & ~(CSOR_NAND_PGS_MASK)) | 0x0018C000;
|
|
- ifc_out32(csor_8k, &ifc->csor_cs[cs].csor);
|
|
|
|
- ifc_out32(0x0000400, &ifc->csor_cs[cs].csor_ext);
|
|
|
|
|
|
+ ifc_out32(csor_8k, &ifc_global->csor_cs[cs].csor);
|
|
|
|
+ ifc_out32(0x0000400, &ifc_global->csor_cs[cs].csor_ext);
|
|
|
|
|
|
/* READID */
|
|
/* READID */
|
|
ifc_out32((IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
|
|
ifc_out32((IFC_FIR_OP_CW0 << IFC_NAND_FIR0_OP0_SHIFT) |
|
|
- (IFC_FIR_OP_UA << IFC_NAND_FIR0_OP1_SHIFT) |
|
|
|
|
- (IFC_FIR_OP_RB << IFC_NAND_FIR0_OP2_SHIFT),
|
|
|
|
- &ifc->ifc_nand.nand_fir0);
|
|
|
|
|
|
+ (IFC_FIR_OP_UA << IFC_NAND_FIR0_OP1_SHIFT) |
|
|
|
|
+ (IFC_FIR_OP_RB << IFC_NAND_FIR0_OP2_SHIFT),
|
|
|
|
+ &ifc_runtime->ifc_nand.nand_fir0);
|
|
ifc_out32(NAND_CMD_READID << IFC_NAND_FCR0_CMD0_SHIFT,
|
|
ifc_out32(NAND_CMD_READID << IFC_NAND_FCR0_CMD0_SHIFT,
|
|
- &ifc->ifc_nand.nand_fcr0);
|
|
|
|
- ifc_out32(0x0, &ifc->ifc_nand.row3);
|
|
|
|
|
|
+ &ifc_runtime->ifc_nand.nand_fcr0);
|
|
|
|
+ ifc_out32(0x0, &ifc_runtime->ifc_nand.row3);
|
|
|
|
|
|
- ifc_out32(0x0, &ifc->ifc_nand.nand_fbcr);
|
|
|
|
|
|
+ ifc_out32(0x0, &ifc_runtime->ifc_nand.nand_fbcr);
|
|
|
|
|
|
/* Program ROW0/COL0 */
|
|
/* Program ROW0/COL0 */
|
|
- ifc_out32(0x0, &ifc->ifc_nand.row0);
|
|
|
|
- ifc_out32(0x0, &ifc->ifc_nand.col0);
|
|
|
|
|
|
+ ifc_out32(0x0, &ifc_runtime->ifc_nand.row0);
|
|
|
|
+ ifc_out32(0x0, &ifc_runtime->ifc_nand.col0);
|
|
|
|
|
|
/* set the chip select for NAND Transaction */
|
|
/* set the chip select for NAND Transaction */
|
|
- ifc_out32(cs << IFC_NAND_CSEL_SHIFT, &ifc->ifc_nand.nand_csel);
|
|
|
|
|
|
+ ifc_out32(cs << IFC_NAND_CSEL_SHIFT,
|
|
|
|
+ &ifc_runtime->ifc_nand.nand_csel);
|
|
|
|
|
|
/* start read seq */
|
|
/* start read seq */
|
|
- ifc_out32(IFC_NAND_SEQ_STRT_FIR_STRT, &ifc->ifc_nand.nandseq_strt);
|
|
|
|
|
|
+ ifc_out32(IFC_NAND_SEQ_STRT_FIR_STRT,
|
|
|
|
+ &ifc_runtime->ifc_nand.nandseq_strt);
|
|
|
|
|
|
/* wait for command complete flag or timeout */
|
|
/* wait for command complete flag or timeout */
|
|
wait_event_timeout(ctrl->nand_wait, ctrl->nand_stat,
|
|
wait_event_timeout(ctrl->nand_wait, ctrl->nand_stat,
|
|
@@ -867,14 +870,15 @@ static void fsl_ifc_sram_init(struct fsl_ifc_mtd *priv)
|
|
printk(KERN_ERR "fsl-ifc: Failed to Initialise SRAM\n");
|
|
printk(KERN_ERR "fsl-ifc: Failed to Initialise SRAM\n");
|
|
|
|
|
|
/* Restore CSOR and CSOR_ext */
|
|
/* Restore CSOR and CSOR_ext */
|
|
- ifc_out32(csor, &ifc->csor_cs[cs].csor);
|
|
|
|
- ifc_out32(csor_ext, &ifc->csor_cs[cs].csor_ext);
|
|
|
|
|
|
+ ifc_out32(csor, &ifc_global->csor_cs[cs].csor);
|
|
|
|
+ ifc_out32(csor_ext, &ifc_global->csor_cs[cs].csor_ext);
|
|
}
|
|
}
|
|
|
|
|
|
static int fsl_ifc_chip_init(struct fsl_ifc_mtd *priv)
|
|
static int fsl_ifc_chip_init(struct fsl_ifc_mtd *priv)
|
|
{
|
|
{
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
struct fsl_ifc_ctrl *ctrl = priv->ctrl;
|
|
- struct fsl_ifc_regs __iomem *ifc = ctrl->regs;
|
|
|
|
|
|
+ struct fsl_ifc_global __iomem *ifc_global = ctrl->gregs;
|
|
|
|
+ struct fsl_ifc_runtime __iomem *ifc_runtime = ctrl->rregs;
|
|
struct nand_chip *chip = &priv->chip;
|
|
struct nand_chip *chip = &priv->chip;
|
|
struct mtd_info *mtd = nand_to_mtd(&priv->chip);
|
|
struct mtd_info *mtd = nand_to_mtd(&priv->chip);
|
|
struct nand_ecclayout *layout;
|
|
struct nand_ecclayout *layout;
|
|
@@ -886,7 +890,8 @@ static int fsl_ifc_chip_init(struct fsl_ifc_mtd *priv)
|
|
|
|
|
|
/* fill in nand_chip structure */
|
|
/* fill in nand_chip structure */
|
|
/* set up function call table */
|
|
/* set up function call table */
|
|
- if ((ifc_in32(&ifc->cspr_cs[priv->bank].cspr)) & CSPR_PORT_SIZE_16)
|
|
|
|
|
|
+ if ((ifc_in32(&ifc_global->cspr_cs[priv->bank].cspr))
|
|
|
|
+ & CSPR_PORT_SIZE_16)
|
|
chip->read_byte = fsl_ifc_read_byte16;
|
|
chip->read_byte = fsl_ifc_read_byte16;
|
|
else
|
|
else
|
|
chip->read_byte = fsl_ifc_read_byte;
|
|
chip->read_byte = fsl_ifc_read_byte;
|
|
@@ -900,13 +905,14 @@ static int fsl_ifc_chip_init(struct fsl_ifc_mtd *priv)
|
|
chip->bbt_td = &bbt_main_descr;
|
|
chip->bbt_td = &bbt_main_descr;
|
|
chip->bbt_md = &bbt_mirror_descr;
|
|
chip->bbt_md = &bbt_mirror_descr;
|
|
|
|
|
|
- ifc_out32(0x0, &ifc->ifc_nand.ncfgr);
|
|
|
|
|
|
+ ifc_out32(0x0, &ifc_runtime->ifc_nand.ncfgr);
|
|
|
|
|
|
/* set up nand options */
|
|
/* set up nand options */
|
|
chip->bbt_options = NAND_BBT_USE_FLASH;
|
|
chip->bbt_options = NAND_BBT_USE_FLASH;
|
|
chip->options = NAND_NO_SUBPAGE_WRITE;
|
|
chip->options = NAND_NO_SUBPAGE_WRITE;
|
|
|
|
|
|
- if (ifc_in32(&ifc->cspr_cs[priv->bank].cspr) & CSPR_PORT_SIZE_16) {
|
|
|
|
|
|
+ if (ifc_in32(&ifc_global->cspr_cs[priv->bank].cspr)
|
|
|
|
+ & CSPR_PORT_SIZE_16) {
|
|
chip->read_byte = fsl_ifc_read_byte16;
|
|
chip->read_byte = fsl_ifc_read_byte16;
|
|
chip->options |= NAND_BUSWIDTH_16;
|
|
chip->options |= NAND_BUSWIDTH_16;
|
|
} else {
|
|
} else {
|
|
@@ -919,7 +925,7 @@ static int fsl_ifc_chip_init(struct fsl_ifc_mtd *priv)
|
|
chip->ecc.read_page = fsl_ifc_read_page;
|
|
chip->ecc.read_page = fsl_ifc_read_page;
|
|
chip->ecc.write_page = fsl_ifc_write_page;
|
|
chip->ecc.write_page = fsl_ifc_write_page;
|
|
|
|
|
|
- csor = ifc_in32(&ifc->csor_cs[priv->bank].csor);
|
|
|
|
|
|
+ csor = ifc_in32(&ifc_global->csor_cs[priv->bank].csor);
|
|
|
|
|
|
/* Hardware generates ECC per 512 Bytes */
|
|
/* Hardware generates ECC per 512 Bytes */
|
|
chip->ecc.size = 512;
|
|
chip->ecc.size = 512;
|
|
@@ -1007,10 +1013,10 @@ static int fsl_ifc_chip_remove(struct fsl_ifc_mtd *priv)
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
-static int match_bank(struct fsl_ifc_regs __iomem *ifc, int bank,
|
|
|
|
|
|
+static int match_bank(struct fsl_ifc_global __iomem *ifc_global, int bank,
|
|
phys_addr_t addr)
|
|
phys_addr_t addr)
|
|
{
|
|
{
|
|
- u32 cspr = ifc_in32(&ifc->cspr_cs[bank].cspr);
|
|
|
|
|
|
+ u32 cspr = ifc_in32(&ifc_global->cspr_cs[bank].cspr);
|
|
|
|
|
|
if (!(cspr & CSPR_V))
|
|
if (!(cspr & CSPR_V))
|
|
return 0;
|
|
return 0;
|
|
@@ -1024,7 +1030,7 @@ static DEFINE_MUTEX(fsl_ifc_nand_mutex);
|
|
|
|
|
|
static int fsl_ifc_nand_probe(struct platform_device *dev)
|
|
static int fsl_ifc_nand_probe(struct platform_device *dev)
|
|
{
|
|
{
|
|
- struct fsl_ifc_regs __iomem *ifc;
|
|
|
|
|
|
+ struct fsl_ifc_runtime __iomem *ifc;
|
|
struct fsl_ifc_mtd *priv;
|
|
struct fsl_ifc_mtd *priv;
|
|
struct resource res;
|
|
struct resource res;
|
|
static const char *part_probe_types[]
|
|
static const char *part_probe_types[]
|
|
@@ -1034,9 +1040,9 @@ static int fsl_ifc_nand_probe(struct platform_device *dev)
|
|
struct device_node *node = dev->dev.of_node;
|
|
struct device_node *node = dev->dev.of_node;
|
|
struct mtd_info *mtd;
|
|
struct mtd_info *mtd;
|
|
|
|
|
|
- if (!fsl_ifc_ctrl_dev || !fsl_ifc_ctrl_dev->regs)
|
|
|
|
|
|
+ if (!fsl_ifc_ctrl_dev || !fsl_ifc_ctrl_dev->rregs)
|
|
return -ENODEV;
|
|
return -ENODEV;
|
|
- ifc = fsl_ifc_ctrl_dev->regs;
|
|
|
|
|
|
+ ifc = fsl_ifc_ctrl_dev->rregs;
|
|
|
|
|
|
/* get, allocate and map the memory resource */
|
|
/* get, allocate and map the memory resource */
|
|
ret = of_address_to_resource(node, 0, &res);
|
|
ret = of_address_to_resource(node, 0, &res);
|
|
@@ -1047,7 +1053,7 @@ static int fsl_ifc_nand_probe(struct platform_device *dev)
|
|
|
|
|
|
/* find which chip select it is connected to */
|
|
/* find which chip select it is connected to */
|
|
for (bank = 0; bank < fsl_ifc_ctrl_dev->banks; bank++) {
|
|
for (bank = 0; bank < fsl_ifc_ctrl_dev->banks; bank++) {
|
|
- if (match_bank(ifc, bank, res.start))
|
|
|
|
|
|
+ if (match_bank(fsl_ifc_ctrl_dev->gregs, bank, res.start))
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|