mtd: rawnand: Fill memorg during detection
If we want to use the generic NAND layer, we need to have the memorg struct appropriately filled. Patch the detection code to fill this struct. Signed-off-by: Boris Brezillon <bbrezillon@kernel.org> Reviewed-by: Frieder Schrempf <frieder.schrempf@kontron.de> Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
This commit is contained in:

committed by
Miquel Raynal

parent
3020e30af6
commit
629a442cad
@@ -22,12 +22,15 @@
|
||||
int nand_jedec_detect(struct nand_chip *chip)
|
||||
{
|
||||
struct mtd_info *mtd = nand_to_mtd(chip);
|
||||
struct nand_memory_organization *memorg;
|
||||
struct nand_jedec_params *p;
|
||||
struct jedec_ecc_info *ecc;
|
||||
int jedec_version = 0;
|
||||
char id[5];
|
||||
int i, val, ret;
|
||||
|
||||
memorg = nanddev_get_memorg(&chip->base);
|
||||
|
||||
/* Try JEDEC for unknown chip or LP */
|
||||
ret = nand_readid_op(chip, 0x40, id, sizeof(id));
|
||||
if (ret || strncmp(id, "JEDEC", sizeof(id)))
|
||||
@@ -81,17 +84,26 @@ int nand_jedec_detect(struct nand_chip *chip)
|
||||
goto free_jedec_param_page;
|
||||
}
|
||||
|
||||
mtd->writesize = le32_to_cpu(p->byte_per_page);
|
||||
memorg->pagesize = le32_to_cpu(p->byte_per_page);
|
||||
mtd->writesize = memorg->pagesize;
|
||||
|
||||
/* Please reference to the comment for nand_flash_detect_onfi. */
|
||||
mtd->erasesize = 1 << (fls(le32_to_cpu(p->pages_per_block)) - 1);
|
||||
mtd->erasesize *= mtd->writesize;
|
||||
memorg->pages_per_eraseblock =
|
||||
1 << (fls(le32_to_cpu(p->pages_per_block)) - 1);
|
||||
mtd->erasesize = memorg->pages_per_eraseblock * memorg->pagesize;
|
||||
|
||||
mtd->oobsize = le16_to_cpu(p->spare_bytes_per_page);
|
||||
memorg->oobsize = le16_to_cpu(p->spare_bytes_per_page);
|
||||
mtd->oobsize = memorg->oobsize;
|
||||
|
||||
memorg->luns_per_target = p->lun_count;
|
||||
memorg->planes_per_lun = 1 << p->multi_plane_addr;
|
||||
|
||||
/* Please reference to the comment for nand_flash_detect_onfi. */
|
||||
chip->chipsize = 1 << (fls(le32_to_cpu(p->blocks_per_lun)) - 1);
|
||||
memorg->eraseblocks_per_lun =
|
||||
1 << (fls(le32_to_cpu(p->blocks_per_lun)) - 1);
|
||||
chip->chipsize = memorg->eraseblocks_per_lun;
|
||||
chip->chipsize *= (uint64_t)mtd->erasesize * p->lun_count;
|
||||
memorg->bits_per_cell = p->bits_per_cell;
|
||||
chip->bits_per_cell = p->bits_per_cell;
|
||||
|
||||
if (le16_to_cpu(p->features) & JEDEC_FEATURE_16_BIT_BUS)
|
||||
|
Reference in New Issue
Block a user