Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/arm/sunxi Use nand_attach_mtdparts



details:   https://anonhg.NetBSD.org/src/rev/9659e4ad5dd5
branches:  trunk
changeset: 357515:9659e4ad5dd5
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Mon Nov 13 17:37:02 2017 +0000

description:
Use nand_attach_mtdparts

diffstat:

 sys/arch/arm/sunxi/sunxi_nand.c |  19 ++++++++++++++++---
 1 files changed, 16 insertions(+), 3 deletions(-)

diffs (54 lines):

diff -r b3835fa6b548 -r 9659e4ad5dd5 sys/arch/arm/sunxi/sunxi_nand.c
--- a/sys/arch/arm/sunxi/sunxi_nand.c   Mon Nov 13 17:36:39 2017 +0000
+++ b/sys/arch/arm/sunxi/sunxi_nand.c   Mon Nov 13 17:37:02 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sunxi_nand.c,v 1.3 2017/11/13 14:14:25 jmcneill Exp $ */
+/* $NetBSD: sunxi_nand.c,v 1.4 2017/11/13 17:37:02 jmcneill Exp $ */
 
 /*-
  * Copyright (c) 2017 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sunxi_nand.c,v 1.3 2017/11/13 14:14:25 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sunxi_nand.c,v 1.4 2017/11/13 17:37:02 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -40,6 +40,8 @@
 #include <dev/nand/nand.h>
 #include <dev/nand/onfi.h>
 
+#include <arm/bootconfig.h>
+
 #define        NDFC_CTL                0x00
 #define         NDFC_CTL_CE_SEL                __BITS(27,24)
 #define         NDFC_CTL_PAGE_SIZE             __BITS(11,8)
@@ -432,7 +434,7 @@
     struct sunxi_nand_chip *chip, int phandle)
 {
        struct nand_interface *nand = &chip->chip_nand;
-       const char *ecc_mode;
+       const char *ecc_mode, *mtdparts;
 
        chip->chip_sc = sc;
        chip->chip_phandle = phandle;
@@ -514,6 +516,17 @@
 #endif
 
        chip->chip_dev = nand_attach_mi(nand, sc->sc_dev);
+       if (chip->chip_dev == NULL)
+               return;
+
+       mtdparts = get_bootconf_string(boot_args, "mtdparts");
+       if (mtdparts != NULL) {
+               char mtd_id[strlen("sunxi-nand.X") + 1];
+               snprintf(mtd_id, sizeof(mtd_id), "sunxi-nand.%u",
+                   device_unit(sc->sc_dev));
+
+               nand_attach_mtdparts(chip->chip_dev, mtd_id, mtdparts);
+       }
 }
 
 static int



Home | Main Index | Thread Index | Old Index