summaryrefslogtreecommitdiffstats
path: root/target/linux/sunxi/patches-4.1/122-mtd-nand-sunxi-add-partition-support.patch
diff options
context:
space:
mode:
Diffstat (limited to 'target/linux/sunxi/patches-4.1/122-mtd-nand-sunxi-add-partition-support.patch')
-rw-r--r--target/linux/sunxi/patches-4.1/122-mtd-nand-sunxi-add-partition-support.patch160
1 files changed, 0 insertions, 160 deletions
diff --git a/target/linux/sunxi/patches-4.1/122-mtd-nand-sunxi-add-partition-support.patch b/target/linux/sunxi/patches-4.1/122-mtd-nand-sunxi-add-partition-support.patch
deleted file mode 100644
index cdf573891f..0000000000
--- a/target/linux/sunxi/patches-4.1/122-mtd-nand-sunxi-add-partition-support.patch
+++ /dev/null
@@ -1,160 +0,0 @@
-From 5cb31780791d0f6b68e3712f1b35f1a28c47add0 Mon Sep 17 00:00:00 2001
-From: Boris Brezillon <boris.brezillon@free-electrons.com>
-Date: Tue, 21 Oct 2014 14:37:15 +0200
-Subject: [PATCH] mtd: nand: sunxi: Add NAND partition support
-
-Add NAND partition support to the sunxi_nand driver.
-
-Signed-off-by: Boris Brezillon <boris.brezillon@free-electrons.com>
-Signed-off-by: Hans de Goede <hdegoede@redhat.com>
----
- drivers/mtd/nand/Kconfig | 1 +
- drivers/mtd/nand/sunxi_nand.c | 73 +++++++++++++++++++++++++++++++++++++------
- 2 files changed, 65 insertions(+), 9 deletions(-)
-
---- a/drivers/mtd/nand/Kconfig
-+++ b/drivers/mtd/nand/Kconfig
-@@ -525,6 +525,7 @@ config MTD_NAND_XWAY
- config MTD_NAND_SUNXI
- tristate "Support for NAND on Allwinner SoCs"
- depends on ARCH_SUNXI
-+ select MTD_OF_NAND_PARTS
- help
- Enables support for NAND Flash chips on Allwinner SoCs.
-
---- a/drivers/mtd/nand/sunxi_nand.c
-+++ b/drivers/mtd/nand/sunxi_nand.c
-@@ -206,6 +206,23 @@ struct sunxi_nand_hw_ecc {
- };
-
- /*
-+ * sunxi NAND partition structure: stores NAND partitions information
-+ *
-+ * @part: base paritition structure
-+ * @ecc: per-partition ECC info
-+ */
-+struct sunxi_nand_part {
-+ struct nand_part part;
-+ struct nand_ecc_ctrl ecc;
-+};
-+
-+static inline struct sunxi_nand_part *
-+to_sunxi_nand_part(struct nand_part *part)
-+{
-+ return container_of(part, struct sunxi_nand_part, part);
-+}
-+
-+/*
- * NAND chip structure: stores NAND chip device related information
- *
- * @node: used to store NAND chips into a list
-@@ -525,7 +542,7 @@ static int sunxi_nfc_hw_ecc_read_page(st
- int oob_required, int page)
- {
- struct sunxi_nfc *nfc = to_sunxi_nfc(chip->controller);
-- struct nand_ecc_ctrl *ecc = &chip->ecc;
-+ struct nand_ecc_ctrl *ecc = chip->cur_ecc;
- struct nand_ecclayout *layout = ecc->layout;
- struct sunxi_nand_hw_ecc *data = ecc->priv;
- unsigned int max_bitflips = 0;
-@@ -611,7 +628,7 @@ static int sunxi_nfc_hw_ecc_write_page(s
- const uint8_t *buf, int oob_required)
- {
- struct sunxi_nfc *nfc = to_sunxi_nfc(chip->controller);
-- struct nand_ecc_ctrl *ecc = &chip->ecc;
-+ struct nand_ecc_ctrl *ecc = chip->cur_ecc;
- struct nand_ecclayout *layout = ecc->layout;
- struct sunxi_nand_hw_ecc *data = ecc->priv;
- int offset;
-@@ -679,7 +696,7 @@ static int sunxi_nfc_hw_syndrome_ecc_rea
- int page)
- {
- struct sunxi_nfc *nfc = to_sunxi_nfc(chip->controller);
-- struct nand_ecc_ctrl *ecc = &chip->ecc;
-+ struct nand_ecc_ctrl *ecc = chip->cur_ecc;
- struct sunxi_nand_hw_ecc *data = ecc->priv;
- unsigned int max_bitflips = 0;
- uint8_t *oob = chip->oob_poi;
-@@ -747,7 +764,7 @@ static int sunxi_nfc_hw_syndrome_ecc_wri
- int oob_required)
- {
- struct sunxi_nfc *nfc = to_sunxi_nfc(chip->controller);
-- struct nand_ecc_ctrl *ecc = &chip->ecc;
-+ struct nand_ecc_ctrl *ecc = chip->cur_ecc;
- struct sunxi_nand_hw_ecc *data = ecc->priv;
- uint8_t *oob = chip->oob_poi;
- int offset = 0;
-@@ -1091,8 +1108,13 @@ static int sunxi_nand_ecc_init(struct mt
- ecc->strength = nand->ecc_strength_ds;
- }
-
-- if (!ecc->size || !ecc->strength)
-- return -EINVAL;
-+ if (!ecc->size || !ecc->strength) {
-+ if (ecc == &nand->ecc)
-+ return -EINVAL;
-+
-+ ecc->size = nand->ecc.size;
-+ ecc->strength = nand->ecc.strength;
-+ }
-
- ecc->mode = NAND_ECC_HW;
-
-@@ -1127,12 +1149,39 @@ static int sunxi_nand_ecc_init(struct mt
- return 0;
- }
-
-+static void sunxi_nand_part_release(struct nand_part *part)
-+{
-+ kfree(to_sunxi_nand_part(part));
-+}
-+
-+struct nand_part *sunxi_ofnandpart_parse(void *priv, struct mtd_info *master,
-+ struct device_node *pp)
-+{
-+ struct sunxi_nand_part *part;
-+ int ret;
-+
-+ part = kzalloc(sizeof(*part), GFP_KERNEL);
-+ part->part.release = sunxi_nand_part_release;
-+
-+ ret = sunxi_nand_ecc_init(master, &part->ecc, pp);
-+ if (ret)
-+ goto err;
-+
-+ part->part.ecc = &part->ecc;
-+
-+ return &part->part;
-+
-+err:
-+ kfree(part);
-+ return ERR_PTR(ret);
-+}
-+
- static int sunxi_nand_chip_init(struct device *dev, struct sunxi_nfc *nfc,
- struct device_node *np)
- {
- const struct nand_sdr_timings *timings;
- struct sunxi_nand_chip *chip;
-- struct mtd_part_parser_data ppdata;
-+ struct ofnandpart_data ppdata;
- struct mtd_info *mtd;
- struct nand_chip *nand;
- int nsels;
-@@ -1261,8 +1310,14 @@ static int sunxi_nand_chip_init(struct d
- return ret;
- }
-
-- ppdata.of_node = np;
-- ret = mtd_device_parse_register(mtd, NULL, &ppdata, NULL, 0);
-+ ppdata.node = np;
-+ ppdata.parse = sunxi_ofnandpart_parse;
-+ ret = ofnandpart_parse(mtd, &ppdata);
-+ if (!ret)
-+ ret = mtd_device_register(mtd, NULL, 0);
-+ else if (ret > 0)
-+ ret = 0;
-+
- if (ret) {
- dev_err(dev, "failed to register mtd device: %d\n", ret);
- nand_release(mtd);