Commit 7b0507eb authored by Kyungmin Park's avatar Kyungmin Park Committed by David Woodhouse

mtd: OneNAND: Samsung SoCs use own chip_probe function

Samsung SoCs use own chip_probe function.
Don't touch the memory configuration at probe time.
Signed-off-by: default avatarKyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: default avatarDavid Woodhouse <David.Woodhouse@intel.com>
parent ad0d363b
...@@ -630,6 +630,12 @@ static int s5pc110_read_bufferram(struct mtd_info *mtd, int area, ...@@ -630,6 +630,12 @@ static int s5pc110_read_bufferram(struct mtd_info *mtd, int area,
return 0; return 0;
} }
static int s5pc110_chip_probe(struct mtd_info *mtd)
{
/* Now just return 0 */
return 0;
}
static int s3c_onenand_bbt_wait(struct mtd_info *mtd, int state) static int s3c_onenand_bbt_wait(struct mtd_info *mtd, int state)
{ {
unsigned int flags = INT_ACT | LOAD_CMP; unsigned int flags = INT_ACT | LOAD_CMP;
...@@ -757,6 +763,7 @@ static void s3c_onenand_setup(struct mtd_info *mtd) ...@@ -757,6 +763,7 @@ static void s3c_onenand_setup(struct mtd_info *mtd)
/* Use generic onenand functions */ /* Use generic onenand functions */
onenand->cmd_map = s5pc1xx_cmd_map; onenand->cmd_map = s5pc1xx_cmd_map;
this->read_bufferram = s5pc110_read_bufferram; this->read_bufferram = s5pc110_read_bufferram;
this->chip_probe = s5pc110_chip_probe;
return; return;
} else { } else {
BUG(); BUG();
...@@ -781,7 +788,6 @@ static int s3c_onenand_probe(struct platform_device *pdev) ...@@ -781,7 +788,6 @@ static int s3c_onenand_probe(struct platform_device *pdev)
struct mtd_info *mtd; struct mtd_info *mtd;
struct resource *r; struct resource *r;
int size, err; int size, err;
unsigned long onenand_ctrl_cfg = 0;
pdata = pdev->dev.platform_data; pdata = pdev->dev.platform_data;
/* No need to check pdata. the platform data is optional */ /* No need to check pdata. the platform data is optional */
...@@ -900,14 +906,6 @@ static int s3c_onenand_probe(struct platform_device *pdev) ...@@ -900,14 +906,6 @@ static int s3c_onenand_probe(struct platform_device *pdev)
} }
onenand->phys_base = onenand->base_res->start; onenand->phys_base = onenand->base_res->start;
onenand_ctrl_cfg = readl(onenand->dma_addr + 0x100);
if ((onenand_ctrl_cfg & ONENAND_SYS_CFG1_SYNC_WRITE) &&
onenand->dma_addr)
writel(onenand_ctrl_cfg & ~ONENAND_SYS_CFG1_SYNC_WRITE,
onenand->dma_addr + 0x100);
else
onenand_ctrl_cfg = 0;
} }
if (onenand_scan(mtd, 1)) { if (onenand_scan(mtd, 1)) {
...@@ -915,10 +913,7 @@ static int s3c_onenand_probe(struct platform_device *pdev) ...@@ -915,10 +913,7 @@ static int s3c_onenand_probe(struct platform_device *pdev)
goto scan_failed; goto scan_failed;
} }
if (onenand->type == TYPE_S5PC110) { if (onenand->type != TYPE_S5PC110) {
if (onenand_ctrl_cfg && onenand->dma_addr)
writel(onenand_ctrl_cfg, onenand->dma_addr + 0x100);
} else {
/* S3C doesn't handle subpage write */ /* S3C doesn't handle subpage write */
mtd->subpage_sft = 0; mtd->subpage_sft = 0;
this->subpagesize = mtd->writesize; this->subpagesize = mtd->writesize;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment