diff options
author | David Woodhouse <David.Woodhouse@intel.com> | 2010-02-26 13:32:56 -0500 |
---|---|---|
committer | David Woodhouse <David.Woodhouse@intel.com> | 2010-02-26 13:32:56 -0500 |
commit | 5e81e88a4c140586d9212999cea683bcd66a15c6 (patch) | |
tree | 1d67825bb2cbcb3830fe4584bac04f6d9413d41a | |
parent | 9fc51a37a8da84618df7584cad67c078317f6720 (diff) |
mtd: nand: Allow caller to pass alternative ID table to nand_scan_ident()
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
-rw-r--r-- | drivers/mtd/nand/atmel_nand.c | 2 | ||||
-rw-r--r-- | drivers/mtd/nand/bcm_umi_nand.c | 2 | ||||
-rw-r--r-- | drivers/mtd/nand/cafe_nand.c | 2 | ||||
-rw-r--r-- | drivers/mtd/nand/davinci_nand.c | 2 | ||||
-rw-r--r-- | drivers/mtd/nand/fsl_elbc_nand.c | 2 | ||||
-rw-r--r-- | drivers/mtd/nand/mxc_nand.c | 2 | ||||
-rw-r--r-- | drivers/mtd/nand/nand_base.c | 29 | ||||
-rw-r--r-- | drivers/mtd/nand/s3c2410.c | 3 | ||||
-rw-r--r-- | drivers/mtd/nand/sh_flctl.c | 2 | ||||
-rw-r--r-- | drivers/mtd/nand/sm_common.c | 2 | ||||
-rw-r--r-- | drivers/mtd/nand/socrates_nand.c | 2 | ||||
-rw-r--r-- | drivers/mtd/nand/txx9ndfmc.c | 2 | ||||
-rw-r--r-- | include/linux/mtd/nand.h | 4 |
13 files changed, 30 insertions, 26 deletions
diff --git a/drivers/mtd/nand/atmel_nand.c b/drivers/mtd/nand/atmel_nand.c index 524e6c9e0672..04d30887ca7f 100644 --- a/drivers/mtd/nand/atmel_nand.c +++ b/drivers/mtd/nand/atmel_nand.c | |||
@@ -474,7 +474,7 @@ static int __init atmel_nand_probe(struct platform_device *pdev) | |||
474 | } | 474 | } |
475 | 475 | ||
476 | /* first scan to find the device and get the page size */ | 476 | /* first scan to find the device and get the page size */ |
477 | if (nand_scan_ident(mtd, 1)) { | 477 | if (nand_scan_ident(mtd, 1, NULL)) { |
478 | res = -ENXIO; | 478 | res = -ENXIO; |
479 | goto err_scan_ident; | 479 | goto err_scan_ident; |
480 | } | 480 | } |
diff --git a/drivers/mtd/nand/bcm_umi_nand.c b/drivers/mtd/nand/bcm_umi_nand.c index 087bcd745bb7..5ff90b7e565e 100644 --- a/drivers/mtd/nand/bcm_umi_nand.c +++ b/drivers/mtd/nand/bcm_umi_nand.c | |||
@@ -446,7 +446,7 @@ static int __devinit bcm_umi_nand_probe(struct platform_device *pdev) | |||
446 | * layout we'll be using. | 446 | * layout we'll be using. |
447 | */ | 447 | */ |
448 | 448 | ||
449 | err = nand_scan_ident(board_mtd, 1); | 449 | err = nand_scan_ident(board_mtd, 1, NULL); |
450 | if (err) { | 450 | if (err) { |
451 | printk(KERN_ERR "nand_scan failed: %d\n", err); | 451 | printk(KERN_ERR "nand_scan failed: %d\n", err); |
452 | iounmap(bcm_umi_io_base); | 452 | iounmap(bcm_umi_io_base); |
diff --git a/drivers/mtd/nand/cafe_nand.c b/drivers/mtd/nand/cafe_nand.c index 67e2b33f7eff..01a6fe1c7805 100644 --- a/drivers/mtd/nand/cafe_nand.c +++ b/drivers/mtd/nand/cafe_nand.c | |||
@@ -761,7 +761,7 @@ static int __devinit cafe_nand_probe(struct pci_dev *pdev, | |||
761 | cafe_readl(cafe, GLOBAL_CTRL), cafe_readl(cafe, GLOBAL_IRQ_MASK)); | 761 | cafe_readl(cafe, GLOBAL_CTRL), cafe_readl(cafe, GLOBAL_IRQ_MASK)); |
762 | 762 | ||
763 | /* Scan to find existence of the device */ | 763 | /* Scan to find existence of the device */ |
764 | if (nand_scan_ident(mtd, 2)) { | 764 | if (nand_scan_ident(mtd, 2, NULL)) { |
765 | err = -ENXIO; | 765 | err = -ENXIO; |
766 | goto out_irq; | 766 | goto out_irq; |
767 | } | 767 | } |
diff --git a/drivers/mtd/nand/davinci_nand.c b/drivers/mtd/nand/davinci_nand.c index e2eeaf1e51a3..45bb931c0848 100644 --- a/drivers/mtd/nand/davinci_nand.c +++ b/drivers/mtd/nand/davinci_nand.c | |||
@@ -690,7 +690,7 @@ static int __init nand_davinci_probe(struct platform_device *pdev) | |||
690 | spin_unlock_irq(&davinci_nand_lock); | 690 | spin_unlock_irq(&davinci_nand_lock); |
691 | 691 | ||
692 | /* Scan to find existence of the device(s) */ | 692 | /* Scan to find existence of the device(s) */ |
693 | ret = nand_scan_ident(&info->mtd, pdata->mask_chipsel ? 2 : 1); | 693 | ret = nand_scan_ident(&info->mtd, pdata->mask_chipsel ? 2 : 1, NULL); |
694 | if (ret < 0) { | 694 | if (ret < 0) { |
695 | dev_dbg(&pdev->dev, "no NAND chip(s) found\n"); | 695 | dev_dbg(&pdev->dev, "no NAND chip(s) found\n"); |
696 | goto err_scan; | 696 | goto err_scan; |
diff --git a/drivers/mtd/nand/fsl_elbc_nand.c b/drivers/mtd/nand/fsl_elbc_nand.c index 1b8328fbb9dc..3f38fb8e6666 100644 --- a/drivers/mtd/nand/fsl_elbc_nand.c +++ b/drivers/mtd/nand/fsl_elbc_nand.c | |||
@@ -891,7 +891,7 @@ static int __devinit fsl_elbc_chip_probe(struct fsl_elbc_ctrl *ctrl, | |||
891 | if (ret) | 891 | if (ret) |
892 | goto err; | 892 | goto err; |
893 | 893 | ||
894 | ret = nand_scan_ident(&priv->mtd, 1); | 894 | ret = nand_scan_ident(&priv->mtd, 1, NULL); |
895 | if (ret) | 895 | if (ret) |
896 | goto err; | 896 | goto err; |
897 | 897 | ||
diff --git a/drivers/mtd/nand/mxc_nand.c b/drivers/mtd/nand/mxc_nand.c index 06cc378196b5..474a09e53131 100644 --- a/drivers/mtd/nand/mxc_nand.c +++ b/drivers/mtd/nand/mxc_nand.c | |||
@@ -819,7 +819,7 @@ static int __init mxcnd_probe(struct platform_device *pdev) | |||
819 | } | 819 | } |
820 | 820 | ||
821 | /* first scan to find the device and get the page size */ | 821 | /* first scan to find the device and get the page size */ |
822 | if (nand_scan_ident(mtd, 1)) { | 822 | if (nand_scan_ident(mtd, 1, NULL)) { |
823 | err = -ENXIO; | 823 | err = -ENXIO; |
824 | goto escan; | 824 | goto escan; |
825 | } | 825 | } |
diff --git a/drivers/mtd/nand/nand_base.c b/drivers/mtd/nand/nand_base.c index ba29a29bd743..1c4823696be2 100644 --- a/drivers/mtd/nand/nand_base.c +++ b/drivers/mtd/nand/nand_base.c | |||
@@ -2766,10 +2766,10 @@ static void nand_set_defaults(struct nand_chip *chip, int busw) | |||
2766 | */ | 2766 | */ |
2767 | static struct nand_flash_dev *nand_get_flash_type(struct mtd_info *mtd, | 2767 | static struct nand_flash_dev *nand_get_flash_type(struct mtd_info *mtd, |
2768 | struct nand_chip *chip, | 2768 | struct nand_chip *chip, |
2769 | int busw, int *maf_id) | 2769 | int busw, int *maf_id, |
2770 | struct nand_flash_dev *type) | ||
2770 | { | 2771 | { |
2771 | struct nand_flash_dev *type = NULL; | 2772 | int dev_id, maf_idx; |
2772 | int i, dev_id, maf_idx; | ||
2773 | int tmp_id, tmp_manf; | 2773 | int tmp_id, tmp_manf; |
2774 | 2774 | ||
2775 | /* Select the device */ | 2775 | /* Select the device */ |
@@ -2808,15 +2808,14 @@ static struct nand_flash_dev *nand_get_flash_type(struct mtd_info *mtd, | |||
2808 | return ERR_PTR(-ENODEV); | 2808 | return ERR_PTR(-ENODEV); |
2809 | } | 2809 | } |
2810 | 2810 | ||
2811 | /* Lookup the flash id */ | ||
2812 | for (i = 0; nand_flash_ids[i].name != NULL; i++) { | ||
2813 | if (dev_id == nand_flash_ids[i].id) { | ||
2814 | type = &nand_flash_ids[i]; | ||
2815 | break; | ||
2816 | } | ||
2817 | } | ||
2818 | |||
2819 | if (!type) | 2811 | if (!type) |
2812 | type = nand_flash_ids; | ||
2813 | |||
2814 | for (; type->name != NULL; type++) | ||
2815 | if (dev_id == type->id) | ||
2816 | break; | ||
2817 | |||
2818 | if (!type->name) | ||
2820 | return ERR_PTR(-ENODEV); | 2819 | return ERR_PTR(-ENODEV); |
2821 | 2820 | ||
2822 | if (!mtd->name) | 2821 | if (!mtd->name) |
@@ -2926,13 +2925,15 @@ static struct nand_flash_dev *nand_get_flash_type(struct mtd_info *mtd, | |||
2926 | * nand_scan_ident - [NAND Interface] Scan for the NAND device | 2925 | * nand_scan_ident - [NAND Interface] Scan for the NAND device |
2927 | * @mtd: MTD device structure | 2926 | * @mtd: MTD device structure |
2928 | * @maxchips: Number of chips to scan for | 2927 | * @maxchips: Number of chips to scan for |
2928 | * @table: Alternative NAND ID table | ||
2929 | * | 2929 | * |
2930 | * This is the first phase of the normal nand_scan() function. It | 2930 | * This is the first phase of the normal nand_scan() function. It |
2931 | * reads the flash ID and sets up MTD fields accordingly. | 2931 | * reads the flash ID and sets up MTD fields accordingly. |
2932 | * | 2932 | * |
2933 | * The mtd->owner field must be set to the module of the caller. | 2933 | * The mtd->owner field must be set to the module of the caller. |
2934 | */ | 2934 | */ |
2935 | int nand_scan_ident(struct mtd_info *mtd, int maxchips) | 2935 | int nand_scan_ident(struct mtd_info *mtd, int maxchips, |
2936 | struct nand_flash_dev *table) | ||
2936 | { | 2937 | { |
2937 | int i, busw, nand_maf_id; | 2938 | int i, busw, nand_maf_id; |
2938 | struct nand_chip *chip = mtd->priv; | 2939 | struct nand_chip *chip = mtd->priv; |
@@ -2944,7 +2945,7 @@ int nand_scan_ident(struct mtd_info *mtd, int maxchips) | |||
2944 | nand_set_defaults(chip, busw); | 2945 | nand_set_defaults(chip, busw); |
2945 | 2946 | ||
2946 | /* Read the flash type */ | 2947 | /* Read the flash type */ |
2947 | type = nand_get_flash_type(mtd, chip, busw, &nand_maf_id); | 2948 | type = nand_get_flash_type(mtd, chip, busw, &nand_maf_id, table); |
2948 | 2949 | ||
2949 | if (IS_ERR(type)) { | 2950 | if (IS_ERR(type)) { |
2950 | if (!(chip->options & NAND_SCAN_SILENT_NODEV)) | 2951 | if (!(chip->options & NAND_SCAN_SILENT_NODEV)) |
@@ -3235,7 +3236,7 @@ int nand_scan(struct mtd_info *mtd, int maxchips) | |||
3235 | BUG(); | 3236 | BUG(); |
3236 | } | 3237 | } |
3237 | 3238 | ||
3238 | ret = nand_scan_ident(mtd, maxchips); | 3239 | ret = nand_scan_ident(mtd, maxchips, NULL); |
3239 | if (!ret) | 3240 | if (!ret) |
3240 | ret = nand_scan_tail(mtd); | 3241 | ret = nand_scan_tail(mtd); |
3241 | return ret; | 3242 | return ret; |
diff --git a/drivers/mtd/nand/s3c2410.c b/drivers/mtd/nand/s3c2410.c index c41ad2285c63..dc02dcd0c08f 100644 --- a/drivers/mtd/nand/s3c2410.c +++ b/drivers/mtd/nand/s3c2410.c | |||
@@ -1013,7 +1013,8 @@ static int s3c24xx_nand_probe(struct platform_device *pdev) | |||
1013 | s3c2410_nand_init_chip(info, nmtd, sets); | 1013 | s3c2410_nand_init_chip(info, nmtd, sets); |
1014 | 1014 | ||
1015 | nmtd->scan_res = nand_scan_ident(&nmtd->mtd, | 1015 | nmtd->scan_res = nand_scan_ident(&nmtd->mtd, |
1016 | (sets) ? sets->nr_chips : 1); | 1016 | (sets) ? sets->nr_chips : 1, |
1017 | NULL); | ||
1017 | 1018 | ||
1018 | if (nmtd->scan_res == 0) { | 1019 | if (nmtd->scan_res == 0) { |
1019 | s3c2410_nand_update_chip(info, nmtd); | 1020 | s3c2410_nand_update_chip(info, nmtd); |
diff --git a/drivers/mtd/nand/sh_flctl.c b/drivers/mtd/nand/sh_flctl.c index 4260ab78f95c..dbc09a81866e 100644 --- a/drivers/mtd/nand/sh_flctl.c +++ b/drivers/mtd/nand/sh_flctl.c | |||
@@ -825,7 +825,7 @@ static int __init flctl_probe(struct platform_device *pdev) | |||
825 | nand->select_chip = flctl_select_chip; | 825 | nand->select_chip = flctl_select_chip; |
826 | nand->cmdfunc = flctl_cmdfunc; | 826 | nand->cmdfunc = flctl_cmdfunc; |
827 | 827 | ||
828 | ret = nand_scan_ident(flctl_mtd, 1); | 828 | ret = nand_scan_ident(flctl_mtd, 1, NULL); |
829 | if (ret) | 829 | if (ret) |
830 | goto err; | 830 | goto err; |
831 | 831 | ||
diff --git a/drivers/mtd/nand/sm_common.c b/drivers/mtd/nand/sm_common.c index 07b6f725723f..f52bb3949275 100644 --- a/drivers/mtd/nand/sm_common.c +++ b/drivers/mtd/nand/sm_common.c | |||
@@ -75,7 +75,7 @@ int sm_register_device(struct mtd_info *mtd) | |||
75 | chip->options |= NAND_SKIP_BBTSCAN | NAND_SMARTMEDIA; | 75 | chip->options |= NAND_SKIP_BBTSCAN | NAND_SMARTMEDIA; |
76 | 76 | ||
77 | /* Scan for card properties */ | 77 | /* Scan for card properties */ |
78 | ret = nand_scan_ident(mtd, 1); | 78 | ret = nand_scan_ident(mtd, 1, NULL); |
79 | 79 | ||
80 | if (ret) | 80 | if (ret) |
81 | return ret; | 81 | return ret; |
diff --git a/drivers/mtd/nand/socrates_nand.c b/drivers/mtd/nand/socrates_nand.c index 65748ea2b348..b37cbde6e7db 100644 --- a/drivers/mtd/nand/socrates_nand.c +++ b/drivers/mtd/nand/socrates_nand.c | |||
@@ -220,7 +220,7 @@ static int __devinit socrates_nand_probe(struct of_device *ofdev, | |||
220 | dev_set_drvdata(&ofdev->dev, host); | 220 | dev_set_drvdata(&ofdev->dev, host); |
221 | 221 | ||
222 | /* first scan to find the device and get the page size */ | 222 | /* first scan to find the device and get the page size */ |
223 | if (nand_scan_ident(mtd, 1)) { | 223 | if (nand_scan_ident(mtd, 1, NULL)) { |
224 | res = -ENXIO; | 224 | res = -ENXIO; |
225 | goto out; | 225 | goto out; |
226 | } | 226 | } |
diff --git a/drivers/mtd/nand/txx9ndfmc.c b/drivers/mtd/nand/txx9ndfmc.c index 863513c3b69a..054a41c0ef4a 100644 --- a/drivers/mtd/nand/txx9ndfmc.c +++ b/drivers/mtd/nand/txx9ndfmc.c | |||
@@ -274,7 +274,7 @@ static int txx9ndfmc_nand_scan(struct mtd_info *mtd) | |||
274 | struct nand_chip *chip = mtd->priv; | 274 | struct nand_chip *chip = mtd->priv; |
275 | int ret; | 275 | int ret; |
276 | 276 | ||
277 | ret = nand_scan_ident(mtd, 1); | 277 | ret = nand_scan_ident(mtd, 1, NULL); |
278 | if (!ret) { | 278 | if (!ret) { |
279 | if (mtd->writesize >= 512) { | 279 | if (mtd->writesize >= 512) { |
280 | chip->ecc.size = mtd->writesize; | 280 | chip->ecc.size = mtd->writesize; |
diff --git a/include/linux/mtd/nand.h b/include/linux/mtd/nand.h index f2d4a1ac14b8..d152bdf9161f 100644 --- a/include/linux/mtd/nand.h +++ b/include/linux/mtd/nand.h | |||
@@ -25,11 +25,13 @@ | |||
25 | #include <linux/mtd/bbm.h> | 25 | #include <linux/mtd/bbm.h> |
26 | 26 | ||
27 | struct mtd_info; | 27 | struct mtd_info; |
28 | struct nand_flash_dev; | ||
28 | /* Scan and identify a NAND device */ | 29 | /* Scan and identify a NAND device */ |
29 | extern int nand_scan (struct mtd_info *mtd, int max_chips); | 30 | extern int nand_scan (struct mtd_info *mtd, int max_chips); |
30 | /* Separate phases of nand_scan(), allowing board driver to intervene | 31 | /* Separate phases of nand_scan(), allowing board driver to intervene |
31 | * and override command or ECC setup according to flash type */ | 32 | * and override command or ECC setup according to flash type */ |
32 | extern int nand_scan_ident(struct mtd_info *mtd, int max_chips); | 33 | extern int nand_scan_ident(struct mtd_info *mtd, int max_chips, |
34 | struct nand_flash_dev *table); | ||
33 | extern int nand_scan_tail(struct mtd_info *mtd); | 35 | extern int nand_scan_tail(struct mtd_info *mtd); |
34 | 36 | ||
35 | /* Free resources held by the NAND device */ | 37 | /* Free resources held by the NAND device */ |