diff options
Diffstat (limited to 'drivers/mtd/nand/raw/omap2.c')
| -rw-r--r-- | drivers/mtd/nand/raw/omap2.c | 200 | 
1 files changed, 103 insertions, 97 deletions
| diff --git a/drivers/mtd/nand/raw/omap2.c b/drivers/mtd/nand/raw/omap2.c index 4546ac0bed4a..886d05c391ef 100644 --- a/drivers/mtd/nand/raw/omap2.c +++ b/drivers/mtd/nand/raw/omap2.c @@ -240,7 +240,7 @@ static int omap_prefetch_reset(int cs, struct omap_nand_info *info)  /**   * omap_hwcontrol - hardware specific access to control-lines - * @mtd: MTD device structure + * @chip: NAND chip object   * @cmd: command to device   * @ctrl:   * NAND_NCE: bit 0 -> don't care @@ -249,9 +249,9 @@ static int omap_prefetch_reset(int cs, struct omap_nand_info *info)   *   * NOTE: boards may use different bits for these!!   */ -static void omap_hwcontrol(struct mtd_info *mtd, int cmd, unsigned int ctrl) +static void omap_hwcontrol(struct nand_chip *chip, int cmd, unsigned int ctrl)  { -	struct omap_nand_info *info = mtd_to_omap(mtd); +	struct omap_nand_info *info = mtd_to_omap(nand_to_mtd(chip));  	if (cmd != NAND_CMD_NONE) {  		if (ctrl & NAND_CLE) @@ -275,7 +275,7 @@ static void omap_read_buf8(struct mtd_info *mtd, u_char *buf, int len)  {  	struct nand_chip *nand = mtd_to_nand(mtd); -	ioread8_rep(nand->IO_ADDR_R, buf, len); +	ioread8_rep(nand->legacy.IO_ADDR_R, buf, len);  }  /** @@ -291,7 +291,7 @@ static void omap_write_buf8(struct mtd_info *mtd, const u_char *buf, int len)  	bool status;  	while (len--) { -		iowrite8(*p++, info->nand.IO_ADDR_W); +		iowrite8(*p++, info->nand.legacy.IO_ADDR_W);  		/* wait until buffer is available for write */  		do {  			status = info->ops->nand_writebuffer_empty(); @@ -309,7 +309,7 @@ static void omap_read_buf16(struct mtd_info *mtd, u_char *buf, int len)  {  	struct nand_chip *nand = mtd_to_nand(mtd); -	ioread16_rep(nand->IO_ADDR_R, buf, len / 2); +	ioread16_rep(nand->legacy.IO_ADDR_R, buf, len / 2);  }  /** @@ -327,7 +327,7 @@ static void omap_write_buf16(struct mtd_info *mtd, const u_char * buf, int len)  	len >>= 1;  	while (len--) { -		iowrite16(*p++, info->nand.IO_ADDR_W); +		iowrite16(*p++, info->nand.legacy.IO_ADDR_W);  		/* wait until buffer is available for write */  		do {  			status = info->ops->nand_writebuffer_empty(); @@ -337,12 +337,13 @@ static void omap_write_buf16(struct mtd_info *mtd, const u_char * buf, int len)  /**   * omap_read_buf_pref - read data from NAND controller into buffer - * @mtd: MTD device structure + * @chip: NAND chip object   * @buf: buffer to store date   * @len: number of bytes to read   */ -static void omap_read_buf_pref(struct mtd_info *mtd, u_char *buf, int len) +static void omap_read_buf_pref(struct nand_chip *chip, u_char *buf, int len)  { +	struct mtd_info *mtd = nand_to_mtd(chip);  	struct omap_nand_info *info = mtd_to_omap(mtd);  	uint32_t r_count = 0;  	int ret = 0; @@ -372,7 +373,7 @@ static void omap_read_buf_pref(struct mtd_info *mtd, u_char *buf, int len)  			r_count = readl(info->reg.gpmc_prefetch_status);  			r_count = PREFETCH_STATUS_FIFO_CNT(r_count);  			r_count = r_count >> 2; -			ioread32_rep(info->nand.IO_ADDR_R, p, r_count); +			ioread32_rep(info->nand.legacy.IO_ADDR_R, p, r_count);  			p += r_count;  			len -= r_count << 2;  		} while (len); @@ -383,13 +384,14 @@ static void omap_read_buf_pref(struct mtd_info *mtd, u_char *buf, int len)  /**   * omap_write_buf_pref - write buffer to NAND controller - * @mtd: MTD device structure + * @chip: NAND chip object   * @buf: data buffer   * @len: number of bytes to write   */ -static void omap_write_buf_pref(struct mtd_info *mtd, -					const u_char *buf, int len) +static void omap_write_buf_pref(struct nand_chip *chip, const u_char *buf, +				int len)  { +	struct mtd_info *mtd = nand_to_mtd(chip);  	struct omap_nand_info *info = mtd_to_omap(mtd);  	uint32_t w_count = 0;  	int i = 0, ret = 0; @@ -399,7 +401,7 @@ static void omap_write_buf_pref(struct mtd_info *mtd,  	/* take care of subpage writes */  	if (len % 2 != 0) { -		writeb(*buf, info->nand.IO_ADDR_W); +		writeb(*buf, info->nand.legacy.IO_ADDR_W);  		p = (u16 *)(buf + 1);  		len--;  	} @@ -419,7 +421,7 @@ static void omap_write_buf_pref(struct mtd_info *mtd,  			w_count = PREFETCH_STATUS_FIFO_CNT(w_count);  			w_count = w_count >> 1;  			for (i = 0; (i < w_count) && len; i++, len -= 2) -				iowrite16(*p++, info->nand.IO_ADDR_W); +				iowrite16(*p++, info->nand.legacy.IO_ADDR_W);  		}  		/* wait for data to flushed-out before reset the prefetch */  		tim = 0; @@ -528,14 +530,17 @@ out_copy:  /**   * omap_read_buf_dma_pref - read data from NAND controller into buffer - * @mtd: MTD device structure + * @chip: NAND chip object   * @buf: buffer to store date   * @len: number of bytes to read   */ -static void omap_read_buf_dma_pref(struct mtd_info *mtd, u_char *buf, int len) +static void omap_read_buf_dma_pref(struct nand_chip *chip, u_char *buf, +				   int len)  { +	struct mtd_info *mtd = nand_to_mtd(chip); +  	if (len <= mtd->oobsize) -		omap_read_buf_pref(mtd, buf, len); +		omap_read_buf_pref(chip, buf, len);  	else  		/* start transfer in DMA mode */  		omap_nand_dma_transfer(mtd, buf, len, 0x0); @@ -543,18 +548,20 @@ static void omap_read_buf_dma_pref(struct mtd_info *mtd, u_char *buf, int len)  /**   * omap_write_buf_dma_pref - write buffer to NAND controller - * @mtd: MTD device structure + * @chip: NAND chip object   * @buf: data buffer   * @len: number of bytes to write   */ -static void omap_write_buf_dma_pref(struct mtd_info *mtd, -					const u_char *buf, int len) +static void omap_write_buf_dma_pref(struct nand_chip *chip, const u_char *buf, +				    int len)  { +	struct mtd_info *mtd = nand_to_mtd(chip); +  	if (len <= mtd->oobsize) -		omap_write_buf_pref(mtd, buf, len); +		omap_write_buf_pref(chip, buf, len);  	else  		/* start transfer in DMA mode */ -		omap_nand_dma_transfer(mtd, (u_char *) buf, len, 0x1); +		omap_nand_dma_transfer(mtd, (u_char *)buf, len, 0x1);  }  /* @@ -578,14 +585,14 @@ static irqreturn_t omap_nand_irq(int this_irq, void *dev)  			bytes = info->buf_len;  		else if (!info->buf_len)  			bytes = 0; -		iowrite32_rep(info->nand.IO_ADDR_W, -						(u32 *)info->buf, bytes >> 2); +		iowrite32_rep(info->nand.legacy.IO_ADDR_W, (u32 *)info->buf, +			      bytes >> 2);  		info->buf = info->buf + bytes;  		info->buf_len -= bytes;  	} else { -		ioread32_rep(info->nand.IO_ADDR_R, -						(u32 *)info->buf, bytes >> 2); +		ioread32_rep(info->nand.legacy.IO_ADDR_R, (u32 *)info->buf, +			     bytes >> 2);  		info->buf = info->buf + bytes;  		if (this_irq == info->gpmc_irq_count) @@ -605,17 +612,19 @@ done:  /*   * omap_read_buf_irq_pref - read data from NAND controller into buffer - * @mtd: MTD device structure + * @chip: NAND chip object   * @buf: buffer to store date   * @len: number of bytes to read   */ -static void omap_read_buf_irq_pref(struct mtd_info *mtd, u_char *buf, int len) +static void omap_read_buf_irq_pref(struct nand_chip *chip, u_char *buf, +				   int len)  { +	struct mtd_info *mtd = nand_to_mtd(chip);  	struct omap_nand_info *info = mtd_to_omap(mtd);  	int ret = 0;  	if (len <= mtd->oobsize) { -		omap_read_buf_pref(mtd, buf, len); +		omap_read_buf_pref(chip, buf, len);  		return;  	} @@ -651,20 +660,21 @@ out_copy:  /*   * omap_write_buf_irq_pref - write buffer to NAND controller - * @mtd: MTD device structure + * @chip: NAND chip object   * @buf: data buffer   * @len: number of bytes to write   */ -static void omap_write_buf_irq_pref(struct mtd_info *mtd, -					const u_char *buf, int len) +static void omap_write_buf_irq_pref(struct nand_chip *chip, const u_char *buf, +				    int len)  { +	struct mtd_info *mtd = nand_to_mtd(chip);  	struct omap_nand_info *info = mtd_to_omap(mtd);  	int ret = 0;  	unsigned long tim, limit;  	u32 val;  	if (len <= mtd->oobsize) { -		omap_write_buf_pref(mtd, buf, len); +		omap_write_buf_pref(chip, buf, len);  		return;  	} @@ -857,7 +867,7 @@ static int omap_compare_ecc(u8 *ecc_data1,	/* read from NAND memory */  /**   * omap_correct_data - Compares the ECC read with HW generated ECC - * @mtd: MTD device structure + * @chip: NAND chip object   * @dat: page data   * @read_ecc: ecc read from nand flash   * @calc_ecc: ecc read from HW ECC registers @@ -869,10 +879,10 @@ static int omap_compare_ecc(u8 *ecc_data1,	/* read from NAND memory */   * corrected errors is returned. If uncorrectable errors exist, %-1 is   * returned.   */ -static int omap_correct_data(struct mtd_info *mtd, u_char *dat, -				u_char *read_ecc, u_char *calc_ecc) +static int omap_correct_data(struct nand_chip *chip, u_char *dat, +			     u_char *read_ecc, u_char *calc_ecc)  { -	struct omap_nand_info *info = mtd_to_omap(mtd); +	struct omap_nand_info *info = mtd_to_omap(nand_to_mtd(chip));  	int blockCnt = 0, i = 0, ret = 0;  	int stat = 0; @@ -900,7 +910,7 @@ static int omap_correct_data(struct mtd_info *mtd, u_char *dat,  /**   * omap_calcuate_ecc - Generate non-inverted ECC bytes. - * @mtd: MTD device structure + * @chip: NAND chip object   * @dat: The pointer to data on which ecc is computed   * @ecc_code: The ecc_code buffer   * @@ -910,10 +920,10 @@ static int omap_correct_data(struct mtd_info *mtd, u_char *dat,   * an erased page will produce an ECC mismatch between generated and read   * ECC bytes that has to be dealt with separately.   */ -static int omap_calculate_ecc(struct mtd_info *mtd, const u_char *dat, -				u_char *ecc_code) +static int omap_calculate_ecc(struct nand_chip *chip, const u_char *dat, +			      u_char *ecc_code)  { -	struct omap_nand_info *info = mtd_to_omap(mtd); +	struct omap_nand_info *info = mtd_to_omap(nand_to_mtd(chip));  	u32 val;  	val = readl(info->reg.gpmc_ecc_config); @@ -935,10 +945,9 @@ static int omap_calculate_ecc(struct mtd_info *mtd, const u_char *dat,   * @mtd: MTD device structure   * @mode: Read/Write mode   */ -static void omap_enable_hwecc(struct mtd_info *mtd, int mode) +static void omap_enable_hwecc(struct nand_chip *chip, int mode)  { -	struct omap_nand_info *info = mtd_to_omap(mtd); -	struct nand_chip *chip = mtd_to_nand(mtd); +	struct omap_nand_info *info = mtd_to_omap(nand_to_mtd(chip));  	unsigned int dev_width = (chip->options & NAND_BUSWIDTH_16) ? 1 : 0;  	u32 val; @@ -972,8 +981,7 @@ static void omap_enable_hwecc(struct mtd_info *mtd, int mode)  /**   * omap_wait - wait until the command is done - * @mtd: MTD device structure - * @chip: NAND Chip structure + * @this: NAND Chip structure   *   * Wait function is called during Program and erase operations and   * the way it is called from MTD layer, we should wait till the NAND @@ -982,10 +990,9 @@ static void omap_enable_hwecc(struct mtd_info *mtd, int mode)   * Erase can take up to 400ms and program up to 20ms according to   * general NAND and SmartMedia specs   */ -static int omap_wait(struct mtd_info *mtd, struct nand_chip *chip) +static int omap_wait(struct nand_chip *this)  { -	struct nand_chip *this = mtd_to_nand(mtd); -	struct omap_nand_info *info = mtd_to_omap(mtd); +	struct omap_nand_info *info = mtd_to_omap(nand_to_mtd(this));  	unsigned long timeo = jiffies;  	int status, state = this->state; @@ -1012,9 +1019,9 @@ static int omap_wait(struct mtd_info *mtd, struct nand_chip *chip)   *   * Returns true if ready and false if busy.   */ -static int omap_dev_ready(struct mtd_info *mtd) +static int omap_dev_ready(struct nand_chip *chip)  { -	struct omap_nand_info *info = mtd_to_omap(mtd); +	struct omap_nand_info *info = mtd_to_omap(nand_to_mtd(chip));  	return gpiod_get_value(info->ready_gpiod);  } @@ -1030,13 +1037,13 @@ static int omap_dev_ready(struct mtd_info *mtd)   * eccsize0 = 0  (no additional protected byte in spare area)   * eccsize1 = 32 (skip 32 nibbles = 16 bytes per sector in spare area)   */ -static void __maybe_unused omap_enable_hwecc_bch(struct mtd_info *mtd, int mode) +static void __maybe_unused omap_enable_hwecc_bch(struct nand_chip *chip, +						 int mode)  {  	unsigned int bch_type;  	unsigned int dev_width, nsectors; -	struct omap_nand_info *info = mtd_to_omap(mtd); +	struct omap_nand_info *info = mtd_to_omap(nand_to_mtd(chip));  	enum omap_ecc ecc_opt = info->ecc_opt; -	struct nand_chip *chip = mtd_to_nand(mtd);  	u32 val, wr_mode;  	unsigned int ecc_size1, ecc_size0; @@ -1256,7 +1263,7 @@ static int _omap_calculate_ecc_bch(struct mtd_info *mtd,  /**   * omap_calculate_ecc_bch_sw - ECC generator for sector for SW based correction - * @mtd:	MTD device structure + * @chip:	NAND chip object   * @dat:	The pointer to data on which ecc is computed   * @ecc_code:	The ecc_code buffer   * @@ -1264,10 +1271,10 @@ static int _omap_calculate_ecc_bch(struct mtd_info *mtd,   * when SW based correction is required as ECC is required for one sector   * at a time.   */ -static int omap_calculate_ecc_bch_sw(struct mtd_info *mtd, +static int omap_calculate_ecc_bch_sw(struct nand_chip *chip,  				     const u_char *dat, u_char *ecc_calc)  { -	return _omap_calculate_ecc_bch(mtd, dat, ecc_calc, 0); +	return _omap_calculate_ecc_bch(nand_to_mtd(chip), dat, ecc_calc, 0);  }  /** @@ -1339,7 +1346,7 @@ static int erased_sector_bitflips(u_char *data, u_char *oob,  /**   * omap_elm_correct_data - corrects page data area in case error reported - * @mtd:	MTD device structure + * @chip:	NAND chip object   * @data:	page data   * @read_ecc:	ecc read from nand flash   * @calc_ecc:	ecc read from HW ECC registers @@ -1348,10 +1355,10 @@ static int erased_sector_bitflips(u_char *data, u_char *oob,   * In case of non-zero ecc vector, first filter out erased-pages, and   * then process data via ELM to detect bit-flips.   */ -static int omap_elm_correct_data(struct mtd_info *mtd, u_char *data, -				u_char *read_ecc, u_char *calc_ecc) +static int omap_elm_correct_data(struct nand_chip *chip, u_char *data, +				 u_char *read_ecc, u_char *calc_ecc)  { -	struct omap_nand_info *info = mtd_to_omap(mtd); +	struct omap_nand_info *info = mtd_to_omap(nand_to_mtd(chip));  	struct nand_ecc_ctrl *ecc = &info->nand.ecc;  	int eccsteps = info->nand.ecc.steps;  	int i , j, stat = 0; @@ -1512,7 +1519,6 @@ static int omap_elm_correct_data(struct mtd_info *mtd, u_char *data,  /**   * omap_write_page_bch - BCH ecc based write page function for entire page - * @mtd:		mtd info structure   * @chip:		nand chip info structure   * @buf:		data buffer   * @oob_required:	must write chip->oob_poi to OOB @@ -1520,19 +1526,20 @@ static int omap_elm_correct_data(struct mtd_info *mtd, u_char *data,   *   * Custom write page method evolved to support multi sector writing in one shot   */ -static int omap_write_page_bch(struct mtd_info *mtd, struct nand_chip *chip, -			       const uint8_t *buf, int oob_required, int page) +static int omap_write_page_bch(struct nand_chip *chip, const uint8_t *buf, +			       int oob_required, int page)  { +	struct mtd_info *mtd = nand_to_mtd(chip);  	int ret;  	uint8_t *ecc_calc = chip->ecc.calc_buf;  	nand_prog_page_begin_op(chip, page, 0, NULL, 0);  	/* Enable GPMC ecc engine */ -	chip->ecc.hwctl(mtd, NAND_ECC_WRITE); +	chip->ecc.hwctl(chip, NAND_ECC_WRITE);  	/* Write data */ -	chip->write_buf(mtd, buf, mtd->writesize); +	chip->legacy.write_buf(chip, buf, mtd->writesize);  	/* Update ecc vector from GPMC result registers */  	omap_calculate_ecc_bch_multi(mtd, buf, &ecc_calc[0]); @@ -1543,14 +1550,13 @@ static int omap_write_page_bch(struct mtd_info *mtd, struct nand_chip *chip,  		return ret;  	/* Write ecc vector to OOB area */ -	chip->write_buf(mtd, chip->oob_poi, mtd->oobsize); +	chip->legacy.write_buf(chip, chip->oob_poi, mtd->oobsize);  	return nand_prog_page_end_op(chip);  }  /**   * omap_write_subpage_bch - BCH hardware ECC based subpage write - * @mtd:	mtd info structure   * @chip:	nand chip info structure   * @offset:	column address of subpage within the page   * @data_len:	data length @@ -1560,11 +1566,11 @@ static int omap_write_page_bch(struct mtd_info *mtd, struct nand_chip *chip,   *   * OMAP optimized subpage write method.   */ -static int omap_write_subpage_bch(struct mtd_info *mtd, -				  struct nand_chip *chip, u32 offset, +static int omap_write_subpage_bch(struct nand_chip *chip, u32 offset,  				  u32 data_len, const u8 *buf,  				  int oob_required, int page)  { +	struct mtd_info *mtd = nand_to_mtd(chip);  	u8 *ecc_calc = chip->ecc.calc_buf;  	int ecc_size      = chip->ecc.size;  	int ecc_bytes     = chip->ecc.bytes; @@ -1582,10 +1588,10 @@ static int omap_write_subpage_bch(struct mtd_info *mtd,  	nand_prog_page_begin_op(chip, page, 0, NULL, 0);  	/* Enable GPMC ECC engine */ -	chip->ecc.hwctl(mtd, NAND_ECC_WRITE); +	chip->ecc.hwctl(chip, NAND_ECC_WRITE);  	/* Write data */ -	chip->write_buf(mtd, buf, mtd->writesize); +	chip->legacy.write_buf(chip, buf, mtd->writesize);  	for (step = 0; step < ecc_steps; step++) {  		/* mask ECC of un-touched subpages by padding 0xFF */ @@ -1610,14 +1616,13 @@ static int omap_write_subpage_bch(struct mtd_info *mtd,  		return ret;  	/* write OOB buffer to NAND device */ -	chip->write_buf(mtd, chip->oob_poi, mtd->oobsize); +	chip->legacy.write_buf(chip, chip->oob_poi, mtd->oobsize);  	return nand_prog_page_end_op(chip);  }  /**   * omap_read_page_bch - BCH ecc based page read function for entire page - * @mtd:		mtd info structure   * @chip:		nand chip info structure   * @buf:		buffer to store read data   * @oob_required:	caller requires OOB data read to chip->oob_poi @@ -1630,9 +1635,10 @@ static int omap_write_subpage_bch(struct mtd_info *mtd,   * ecc engine enabled. ecc vector updated after read of OOB data.   * For non error pages ecc vector reported as zero.   */ -static int omap_read_page_bch(struct mtd_info *mtd, struct nand_chip *chip, -				uint8_t *buf, int oob_required, int page) +static int omap_read_page_bch(struct nand_chip *chip, uint8_t *buf, +			      int oob_required, int page)  { +	struct mtd_info *mtd = nand_to_mtd(chip);  	uint8_t *ecc_calc = chip->ecc.calc_buf;  	uint8_t *ecc_code = chip->ecc.code_buf;  	int stat, ret; @@ -1641,10 +1647,10 @@ static int omap_read_page_bch(struct mtd_info *mtd, struct nand_chip *chip,  	nand_read_page_op(chip, page, 0, NULL, 0);  	/* Enable GPMC ecc engine */ -	chip->ecc.hwctl(mtd, NAND_ECC_READ); +	chip->ecc.hwctl(chip, NAND_ECC_READ);  	/* Read data */ -	chip->read_buf(mtd, buf, mtd->writesize); +	chip->legacy.read_buf(chip, buf, mtd->writesize);  	/* Read oob bytes */  	nand_change_read_column_op(chip, @@ -1660,7 +1666,7 @@ static int omap_read_page_bch(struct mtd_info *mtd, struct nand_chip *chip,  	if (ret)  		return ret; -	stat = chip->ecc.correct(mtd, buf, ecc_code, ecc_calc); +	stat = chip->ecc.correct(chip, buf, ecc_code, ecc_calc);  	if (stat < 0) {  		mtd->ecc_stats.failed++; @@ -1927,8 +1933,8 @@ static int omap_nand_attach_chip(struct nand_chip *chip)  	/* Re-populate low-level callbacks based on xfer modes */  	switch (info->xfer_type) {  	case NAND_OMAP_PREFETCH_POLLED: -		chip->read_buf = omap_read_buf_pref; -		chip->write_buf = omap_write_buf_pref; +		chip->legacy.read_buf = omap_read_buf_pref; +		chip->legacy.write_buf = omap_write_buf_pref;  		break;  	case NAND_OMAP_POLLED: @@ -1960,8 +1966,8 @@ static int omap_nand_attach_chip(struct nand_chip *chip)  					err);  				return err;  			} -			chip->read_buf = omap_read_buf_dma_pref; -			chip->write_buf = omap_write_buf_dma_pref; +			chip->legacy.read_buf = omap_read_buf_dma_pref; +			chip->legacy.write_buf = omap_write_buf_dma_pref;  		}  		break; @@ -1996,8 +2002,8 @@ static int omap_nand_attach_chip(struct nand_chip *chip)  			return err;  		} -		chip->read_buf = omap_read_buf_irq_pref; -		chip->write_buf = omap_write_buf_irq_pref; +		chip->legacy.read_buf = omap_read_buf_irq_pref; +		chip->legacy.write_buf = omap_write_buf_irq_pref;  		break; @@ -2215,16 +2221,16 @@ static int omap_nand_probe(struct platform_device *pdev)  	}  	res = platform_get_resource(pdev, IORESOURCE_MEM, 0); -	nand_chip->IO_ADDR_R = devm_ioremap_resource(&pdev->dev, res); -	if (IS_ERR(nand_chip->IO_ADDR_R)) -		return PTR_ERR(nand_chip->IO_ADDR_R); +	nand_chip->legacy.IO_ADDR_R = devm_ioremap_resource(&pdev->dev, res); +	if (IS_ERR(nand_chip->legacy.IO_ADDR_R)) +		return PTR_ERR(nand_chip->legacy.IO_ADDR_R);  	info->phys_base = res->start;  	nand_chip->controller = &omap_gpmc_controller; -	nand_chip->IO_ADDR_W = nand_chip->IO_ADDR_R; -	nand_chip->cmd_ctrl  = omap_hwcontrol; +	nand_chip->legacy.IO_ADDR_W = nand_chip->legacy.IO_ADDR_R; +	nand_chip->legacy.cmd_ctrl  = omap_hwcontrol;  	info->ready_gpiod = devm_gpiod_get_optional(&pdev->dev, "rb",  						    GPIOD_IN); @@ -2241,11 +2247,11 @@ static int omap_nand_probe(struct platform_device *pdev)  	 * device and read status register until you get a failure or success  	 */  	if (info->ready_gpiod) { -		nand_chip->dev_ready = omap_dev_ready; -		nand_chip->chip_delay = 0; +		nand_chip->legacy.dev_ready = omap_dev_ready; +		nand_chip->legacy.chip_delay = 0;  	} else { -		nand_chip->waitfunc = omap_wait; -		nand_chip->chip_delay = 50; +		nand_chip->legacy.waitfunc = omap_wait; +		nand_chip->legacy.chip_delay = 50;  	}  	if (info->flash_bbt) @@ -2254,7 +2260,7 @@ static int omap_nand_probe(struct platform_device *pdev)  	/* scan NAND device connected to chip controller */  	nand_chip->options |= info->devsize & NAND_BUSWIDTH_16; -	err = nand_scan(mtd, 1); +	err = nand_scan(nand_chip, 1);  	if (err)  		goto return_error; @@ -2290,7 +2296,7 @@ static int omap_nand_remove(struct platform_device *pdev)  	}  	if (info->dma)  		dma_release_channel(info->dma); -	nand_release(mtd); +	nand_release(nand_chip);  	return 0;  } | 
