Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752306AbbHRDdd (ORCPT ); Mon, 17 Aug 2015 23:33:33 -0400 Received: from mail-bl2on0145.outbound.protection.outlook.com ([65.55.169.145]:55760 "EHLO na01-bl2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1752204AbbHRDd1 (ORCPT ); Mon, 17 Aug 2015 23:33:27 -0400 Authentication-Results: spf=fail (sender IP is 192.88.168.50) smtp.mailfrom=freescale.com; vger.kernel.org; dkim=none (message not signed) header.d=none; From: Han Xu To: CC: , , , , , , , , , , Subject: [PATCH v2 4/6] mtd: nand: gpmi: add GPMI NAND support for i.MX7D Date: Mon, 17 Aug 2015 22:24:55 -0500 Message-ID: <1439868295-24890-1-git-send-email-b45815@freescale.com> X-Mailer: git-send-email 1.9.1 X-EOPAttributedMessage: 0 X-Microsoft-Exchange-Diagnostics: 1;BY2FFO11FD019;1:w3CD8wm0XsgskNejIYlfqzIv5WBr0uZyVJf7/4yhDR6WDKvGwoHUscMn1YUwr1PATjZLKi2mGUsJhKcK1leTIlaYgKVcfpM/jjrHsyspUdJGyylR62SMWoG7F+lJfMc1cxgUxRH4QZkvAz2ccMXscUyXGvrrsQFqBsyTkgSbxcnYYR7Tov/rtzKaEGTfjTX5PCG/rJavEWfKjg2nOE82OYAlNutguH9ZGHAAovA+JNz6g94/w5iczR0cGkZSiKYG4RWCGrTGFgtqkEwIuvNaEzOchFk/FgRXv6B0lOLESDISF27biPjJFnSiRGA0h3G4g1dwvJbE3eVPbt4KjTLCJ7kAk0PwveZbt6oRRQhpuwI6FwqYv0zOoAS82+7H/eu7hErFgYD5sQecGF5zNkMFaQ== X-Forefront-Antispam-Report: CIP:192.88.168.50;CTRY:US;IPV:NLI;EFV:NLI;SFV:NSPM;SFS:(10019020)(6009001)(2980300002)(3050300001)(339900001)(199003)(189002)(81156007)(64706001)(47776003)(19580405001)(4001540100001)(92566002)(2351001)(229853001)(575784001)(5001830100001)(5001860100001)(97736004)(189998001)(110136002)(5001960100002)(5003940100001)(106466001)(105606002)(50466002)(33646002)(104016003)(77156002)(50986999)(36756003)(19580395003)(77096005)(46102003)(6806004)(87936001)(48376002)(85426001)(68736005)(50226001)(62966003)(2004002)(217873001);DIR:OUT;SFP:1102;SCL:1;SRVR:BL2PR03MB548;H:tx30smr01.am.freescale.net;FPR:;SPF:Fail;PTR:InfoDomainNonexistent;A:1;MX:1;LANG:en; MIME-Version: 1.0 Content-Type: text/plain X-Microsoft-Exchange-Diagnostics: 1;BL2PR03MB548;2:y1NLZNE/6od4VRoKA3VZQ80SIVDtGTdDUZZgs57CCcq82tckTUgIxeCmbE+FXrJ8KvlSdMfMoCZEN/WTIjI2139i4XHCeB8Avm3Bc2TAdMdTsAneL0j9ypXge3fO4RMkIFOf+2MC1kOY8RnRyekQFCzXDrEwXuRkVa6zPMxMRE4=;3:+El0HiLVFVNacDrIMlTwg+gt8Xc/NepuB9TpoluKdf1nDhNcQ8hyAXlqiYFhOvJeDjhcwjSQfltMaPb1PJw26jGe3mZCHlcPD9+UtdnDNL9KzMuSuJEdrRvQrxYeRpzo4YD5wp7BQbNs8e/v6g04Qz4ouijzFLmO6BDtKf7C8nDwZCJW36yzl+RMTc2rOt3Iys22YMdgdmfH8VQGX6axi829Qbnpo5rSHiRrBmGZtlg=;25:f787BnaTWaukMcKObYS07RHQJOljC8X1emchI8wG1ZRRWz7e+NaNuSsHwRWYQ8esKt62bXGqj4QqXz6h10BblAs7cyO8/W7AFcZhCgFyY4rM/akbtAOGxPMv1YKq4ZQW793ZkJ1zQIjI6wJrp9H14Ie4FTyA1YzlCgCkXHPvle2fxVnrK09TdU98PnX8IxdYk0eZwFoOVxFqXpcDNu/Qlvi1O1Lh7DtlfOxQDD92je7haxFH82uibXL3a9RkkcL6 X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BL2PR03MB548; X-Microsoft-Exchange-Diagnostics: 1;BL2PR03MB548;20:Z4peqWFe8c/MGYA3VdQJcpLd761pDI/HuCsDKfsAfT1xx3ev14DcaltUR95k1sTX/jNKi7loZ4NxabjyEW1k2q1IZhqJwh76z8IqPKR6p+ijOzDp872gAm5onRIR0T7LiKVr3Hbrb8vFWsSYb7Edj2eElMnmCNNaa8BRsplZj1ZQMJxRXpbpHqloAM1nez43FA+6RsKS5reJvkbT+HRBROyERQbc2bqQVy4eMgM73gCA+nIVJtADN3mehc0RdrMgB8wQXWe++GvdubBDVdg9dVicsyoHAPhipK51n1nIDJpAyEvd88LRuZeRwLp7oJFJJbKXydalqiPsvDMWKsaqN/F33D0D6y8Kdq9sWxssMSE=;4:83i6D9ZM/nyDAu69LD7I2QL+y3qo/wuLx8NpgOvEJ44dDCQZfXAfDIRRTa2gZi/YfkOcQPP6Xl1JcSBrVDXuWM9KHTjw5PLi9KQjH0kl7vIQJ3vfcSWmV/ru65cYD2nG7OBDWuBBns9ujan3A80tuyRkmIBzCSn5Zpvye5WC2gl1CYmF8svesi1+JOmtIDTjjo+3RNFfUzkrTTA48jyPhktBsuu2+mzxpqB7aiBAoBEWLUdljXXF3dKw+6k0kK4N/Agi9T4Wem25WesHL3Jdqqlml/vuR4DdUZ+RnS0XpuQt8QFRaC5r8cqySH5A5aiZ X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(601004)(8121501046)(5005006)(3002001);SRVR:BL2PR03MB548;BCL:0;PCL:0;RULEID:;SRVR:BL2PR03MB548; X-Forefront-PRVS: 067270ECAF X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1;BL2PR03MB548;23:ejz6ejuydsMSPs+xuW37alcd4of8FB7+cau+oQhXL1?= =?us-ascii?Q?ml2BQK2Si1ejOItwOODvgTdGtNa0xeeZAdn65a5zLag222vcawQfVWaucZHh?= =?us-ascii?Q?ff+fajk8AaCgtPCztSwTQPayJyT5AX24+xrZ0CUxXl8m12S75/exNYqt3QRd?= =?us-ascii?Q?BOXlqRNTMnV+JoXR/R6Hog6jhbP3G28CV3yVnd4jKby6FewBvUgA85Ax2R3h?= =?us-ascii?Q?7pV+90RaAru9nUKN/URwqC2dg/4ZCCJ1gnYDavzZ1tlxqwOMNVOKlckBqSN+?= =?us-ascii?Q?6n7TpKAZsYE7PLpqPKBC8SudYzqHWL47OwsE6XW2vDrH/q0FF+Pbueu++n3R?= =?us-ascii?Q?B7FJsoSabTg4akpkOiAtVrue/9ZOMVOuo6jhe0jnOQj4b0bnbt5pr594PzwZ?= =?us-ascii?Q?3PTyWqt+okxpjz+Cgqa13o9wVYyRIBqipN7BOebOKyBkH/1zpjiw3s3zDNY3?= =?us-ascii?Q?1QkPnytJg4vUHrNbE2gQDp7rtsh66Tek4HwzBRbITN5a/0EsfgNAkwERtcC8?= =?us-ascii?Q?tCuEFCffJtsrf2ff+EYEB6qh/3Bw//4RE3K67X9RCQOxINFK9kB5V5byFO3D?= =?us-ascii?Q?oQzcFwXAm7Uc93fXea5rHxlnNbpdzSavRkiIcg2jsDb0Ox0m0bT0IJc1Wwyu?= =?us-ascii?Q?TkmzKxQ+NT420HQRKeGChhM0ldSBap8Luyx2hPZ4mIyOtX9z7e4FUyH3DCA6?= =?us-ascii?Q?AVRgQN9lVqkoWsSaYhNzQGhZmQi/ANd1hAsz/p46lvqoXuEiTB/uLDtUqpfz?= =?us-ascii?Q?8kFgUufzBvxAuN6On+zK5zdirgK58OLUD2rPRmZVhUmd5Vl+nJcqRIlJRdcc?= =?us-ascii?Q?oljn3nvr+1wi3Hm+Qe2zPiMYhgffYhV0wouA0a/n6nL/ajwt9Xr6zauOs3hk?= =?us-ascii?Q?/p0nUi1mYsjvFSynR6kl7+ROX1pGRQ+qgtRBuhqmvTm56vjyzjKZE0GiztfD?= =?us-ascii?Q?SRfGFH3r6VUDKRAwC96BY79yiG2mzjO2rWuzYg5G62IF8RcQ7E2lVre2c+sH?= =?us-ascii?Q?JwuwVbVlv4WdY6XUj929NiU5D/uu6bzo8Pr1/pEh7T963OgLTpglrmyEX9PC?= =?us-ascii?Q?gKOsLIQIsau8u7269C/ZtLOCADVQOmjWJ5VwwfoMlk5syY7PlhEqeWe2uoyZ?= =?us-ascii?Q?lwPIX/JYTKh5O9mJDsiApYhLSRBxV3?= X-Microsoft-Exchange-Diagnostics: 1;BL2PR03MB548;5:VwKwgG0GHV+CokV9l8xqdXPBiwYW5Clm92tOA7mCq05Opy9tXGC92fWuezS5/nSocYwae3wwkO9/irt3MUk0ZGvOVshMXAhXQSLgVw58jSVf0adYD6jp+ey8mg9q2DE3Ost08pz1XRK7lO5y19wPtQ==;24:oYoM4KbCGzcc8MmPSL3KoJN5iSAe+Gh/sZ2WFT29kzAqeI+vq1BFXVbWV2IIG4JKBkeG5QqdeL8Jmv3mMj2LGZ5zfVUIJ+o3IK2pJ4pWulA=;20:5RVOWK9FwDSyhEQm52Cr8FBoq4JPb/2l+xK9PvTK9QQcSP5hXOXY41wtmFoGZs7LhhYeC5vzo1O2qDnCzVdffg== X-OriginatorOrg: freescale.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Aug 2015 03:33:24.1128 (UTC) X-MS-Exchange-CrossTenant-Id: 710a03f5-10f6-4d38-9ff4-a80b81da590d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=710a03f5-10f6-4d38-9ff4-a80b81da590d;Ip=[192.88.168.50];Helo=[tx30smr01.am.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BL2PR03MB548 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 8235 Lines: 233 support GPMI NAND on i.MX7D Signed-off-by: Han Xu --- drivers/mtd/nand/gpmi-nand/bch-regs.h | 14 +++++++------- drivers/mtd/nand/gpmi-nand/gpmi-lib.c | 10 ++++++---- drivers/mtd/nand/gpmi-nand/gpmi-nand.c | 24 ++++++++++++++++++++---- drivers/mtd/nand/gpmi-nand/gpmi-nand.h | 7 +++++-- 4 files changed, 38 insertions(+), 17 deletions(-) diff --git a/drivers/mtd/nand/gpmi-nand/bch-regs.h b/drivers/mtd/nand/gpmi-nand/bch-regs.h index 05bb91f..53e58bc 100644 --- a/drivers/mtd/nand/gpmi-nand/bch-regs.h +++ b/drivers/mtd/nand/gpmi-nand/bch-regs.h @@ -1,7 +1,7 @@ /* * Freescale GPMI NAND Flash Driver * - * Copyright 2008-2011 Freescale Semiconductor, Inc. + * Copyright 2008-2015 Freescale Semiconductor, Inc. * Copyright 2008 Embedded Alley Solutions, Inc. * * This program is free software; you can redistribute it and/or modify @@ -54,7 +54,7 @@ #define MX6Q_BP_BCH_FLASH0LAYOUT0_ECC0 11 #define MX6Q_BM_BCH_FLASH0LAYOUT0_ECC0 (0x1f << MX6Q_BP_BCH_FLASH0LAYOUT0_ECC0) #define BF_BCH_FLASH0LAYOUT0_ECC0(v, x) \ - (GPMI_IS_MX6(x) \ + ((GPMI_IS_MX6(x) || GPMI_IS_MX7(x)) \ ? (((v) << MX6Q_BP_BCH_FLASH0LAYOUT0_ECC0) \ & MX6Q_BM_BCH_FLASH0LAYOUT0_ECC0) \ : (((v) << BP_BCH_FLASH0LAYOUT0_ECC0) \ @@ -65,7 +65,7 @@ #define MX6Q_BM_BCH_FLASH0LAYOUT0_GF_13_14 \ (0x1 << MX6Q_BP_BCH_FLASH0LAYOUT0_GF_13_14) #define BF_BCH_FLASH0LAYOUT0_GF(v, x) \ - ((GPMI_IS_MX6(x) && ((v) == 14)) \ + (((GPMI_IS_MX6(x) || GPMI_IS_MX7(x)) && ((v) == 14))\ ? (((1) << MX6Q_BP_BCH_FLASH0LAYOUT0_GF_13_14) \ & MX6Q_BM_BCH_FLASH0LAYOUT0_GF_13_14) \ : 0 \ @@ -77,7 +77,7 @@ #define MX6Q_BM_BCH_FLASH0LAYOUT0_DATA0_SIZE \ (0x3ff << BP_BCH_FLASH0LAYOUT0_DATA0_SIZE) #define BF_BCH_FLASH0LAYOUT0_DATA0_SIZE(v, x) \ - (GPMI_IS_MX6(x) \ + ((GPMI_IS_MX6(x) || GPMI_IS_MX7(x)) \ ? (((v) >> 2) & MX6Q_BM_BCH_FLASH0LAYOUT0_DATA0_SIZE) \ : ((v) & BM_BCH_FLASH0LAYOUT0_DATA0_SIZE) \ ) @@ -96,7 +96,7 @@ #define MX6Q_BP_BCH_FLASH0LAYOUT1_ECCN 11 #define MX6Q_BM_BCH_FLASH0LAYOUT1_ECCN (0x1f << MX6Q_BP_BCH_FLASH0LAYOUT1_ECCN) #define BF_BCH_FLASH0LAYOUT1_ECCN(v, x) \ - (GPMI_IS_MX6(x) \ + ((GPMI_IS_MX6(x) || GPMI_IS_MX7(x)) \ ? (((v) << MX6Q_BP_BCH_FLASH0LAYOUT1_ECCN) \ & MX6Q_BM_BCH_FLASH0LAYOUT1_ECCN) \ : (((v) << BP_BCH_FLASH0LAYOUT1_ECCN) \ @@ -107,7 +107,7 @@ #define MX6Q_BM_BCH_FLASH0LAYOUT1_GF_13_14 \ (0x1 << MX6Q_BP_BCH_FLASH0LAYOUT1_GF_13_14) #define BF_BCH_FLASH0LAYOUT1_GF(v, x) \ - ((GPMI_IS_MX6(x) && ((v) == 14)) \ + (((GPMI_IS_MX6(x) || GPMI_IS_MX7(x)) && ((v) == 14))\ ? (((1) << MX6Q_BP_BCH_FLASH0LAYOUT1_GF_13_14) \ & MX6Q_BM_BCH_FLASH0LAYOUT1_GF_13_14) \ : 0 \ @@ -119,7 +119,7 @@ #define MX6Q_BM_BCH_FLASH0LAYOUT1_DATAN_SIZE \ (0x3ff << BP_BCH_FLASH0LAYOUT1_DATAN_SIZE) #define BF_BCH_FLASH0LAYOUT1_DATAN_SIZE(v, x) \ - (GPMI_IS_MX6(x) \ + ((GPMI_IS_MX6(x) || GPMI_IS_MX7(x)) \ ? (((v) >> 2) & MX6Q_BM_BCH_FLASH0LAYOUT1_DATAN_SIZE) \ : ((v) & BM_BCH_FLASH0LAYOUT1_DATAN_SIZE) \ ) diff --git a/drivers/mtd/nand/gpmi-nand/gpmi-lib.c b/drivers/mtd/nand/gpmi-nand/gpmi-lib.c index 43fa16b..6b37414 100644 --- a/drivers/mtd/nand/gpmi-nand/gpmi-lib.c +++ b/drivers/mtd/nand/gpmi-nand/gpmi-lib.c @@ -1,7 +1,7 @@ /* * Freescale GPMI NAND Flash Driver * - * Copyright (C) 2008-2011 Freescale Semiconductor, Inc. + * Copyright (C) 2008-2015 Freescale Semiconductor, Inc. * Copyright (C) 2008 Embedded Alley Solutions, Inc. * * This program is free software; you can redistribute it and/or modify @@ -971,7 +971,8 @@ int gpmi_extra_init(struct gpmi_nand_data *this) struct nand_chip *chip = &this->nand; /* Enable the asynchronous EDO feature. */ - if (GPMI_IS_MX6(this) && chip->onfi_version) { + if ((GPMI_IS_MX6(this) || GPMI_IS_MX7(this)) + && chip->onfi_version) { int mode = onfi_get_async_timing_mode(chip); /* We only support the timing mode 4 and mode 5. */ @@ -1093,12 +1094,13 @@ int gpmi_is_ready(struct gpmi_nand_data *this, unsigned chip) if (GPMI_IS_MX23(this)) { mask = MX23_BM_GPMI_DEBUG_READY0 << chip; reg = readl(r->gpmi_regs + HW_GPMI_DEBUG); - } else if (GPMI_IS_MX28(this) || GPMI_IS_MX6(this)) { + } else if (GPMI_IS_MX28(this) || GPMI_IS_MX6(this) || + GPMI_IS_MX7(this)) { /* * In the imx6, all the ready/busy pins are bound * together. So we only need to check chip 0. */ - if (GPMI_IS_MX6(this)) + if (GPMI_IS_MX6(this) || GPMI_IS_MX7(this)) chip = 0; /* MX28 shares the same R/B register as MX6Q. */ diff --git a/drivers/mtd/nand/gpmi-nand/gpmi-nand.c b/drivers/mtd/nand/gpmi-nand/gpmi-nand.c index 01d24dd..0462103 100644 --- a/drivers/mtd/nand/gpmi-nand/gpmi-nand.c +++ b/drivers/mtd/nand/gpmi-nand/gpmi-nand.c @@ -77,6 +77,12 @@ static const struct gpmi_devdata gpmi_devdata_imx6sx = { .max_chain_delay = 12, }; +static const struct gpmi_devdata gpmi_devdata_imx7d = { + .type = IS_MX7D, + .bch_max_ecc_strength = 62, + .max_chain_delay = 12, +}; + static irqreturn_t bch_irq(int irq, void *cookie) { struct gpmi_nand_data *this = cookie; @@ -575,6 +581,10 @@ static char *extra_clks_for_mx6q[GPMI_CLK_MAX] = { "gpmi_apb", "gpmi_bch", "gpmi_bch_apb", "per1_bch", }; +static char *extra_clks_for_mx7d[GPMI_CLK_MAX] = { + "gpmi_bch_apb", +}; + static int gpmi_get_clks(struct gpmi_nand_data *this) { struct resources *r = &this->resources; @@ -592,6 +602,8 @@ static int gpmi_get_clks(struct gpmi_nand_data *this) /* Get extra clocks */ if (GPMI_IS_MX6(this)) extra_clks = extra_clks_for_mx6q; + if (GPMI_IS_MX7(this)) + extra_clks = extra_clks_for_mx7d; if (!extra_clks) return 0; @@ -608,7 +620,7 @@ static int gpmi_get_clks(struct gpmi_nand_data *this) r->clock[i] = clk; } - if (GPMI_IS_MX6(this)) + if (GPMI_IS_MX6(this) || GPMI_IS_MX7(this)) /* * Set the default value for the gpmi clock. * @@ -1869,7 +1881,7 @@ static int gpmi_init_last(struct gpmi_nand_data *this) * (1) the chip is imx6, and * (2) the size of the ECC parity is byte aligned. */ - if (GPMI_IS_MX6(this) && + if ((GPMI_IS_MX6(this) || GPMI_IS_MX7(this)) && ((bch_geo->gf_len * bch_geo->ecc_strength) % 8) == 0) { ecc->read_subpage = gpmi_ecc_read_subpage; chip->options |= NAND_SUBPAGE_READ; @@ -1936,7 +1948,8 @@ static int gpmi_nand_init(struct gpmi_nand_data *this) if (ret) goto err_out; - ret = nand_scan_ident(mtd, GPMI_IS_MX6(this) ? 2 : 1, NULL); + ret = nand_scan_ident(mtd, GPMI_IS_MX6(this) || GPMI_IS_MX7(this)\ + ? 2 : 1, NULL); if (ret) goto err_out; @@ -1980,7 +1993,10 @@ static const struct of_device_id gpmi_nand_id_table[] = { }, { .compatible = "fsl,imx6sx-gpmi-nand", .data = &gpmi_devdata_imx6sx, - }, {} + }, { + .compatible = "fsl,imx7d-gpmi-nand", + .data = (void *)&gpmi_devdata_imx7d, + } }; MODULE_DEVICE_TABLE(of, gpmi_nand_id_table); diff --git a/drivers/mtd/nand/gpmi-nand/gpmi-nand.h b/drivers/mtd/nand/gpmi-nand/gpmi-nand.h index 544062f..1e105f1 100644 --- a/drivers/mtd/nand/gpmi-nand/gpmi-nand.h +++ b/drivers/mtd/nand/gpmi-nand/gpmi-nand.h @@ -1,7 +1,7 @@ /* * Freescale GPMI NAND Flash Driver * - * Copyright (C) 2010-2011 Freescale Semiconductor, Inc. + * Copyright (C) 2010-2015 Freescale Semiconductor, Inc. * Copyright (C) 2008 Embedded Alley Solutions, Inc. * * This program is free software; you can redistribute it and/or modify @@ -123,7 +123,8 @@ enum gpmi_type { IS_MX23, IS_MX28, IS_MX6Q, - IS_MX6SX + IS_MX6SX, + IS_MX7D }; struct gpmi_devdata { @@ -306,6 +307,8 @@ void gpmi_copy_bits(u8 *dst, size_t dst_bit_off, #define GPMI_IS_MX28(x) ((x)->devdata->type == IS_MX28) #define GPMI_IS_MX6Q(x) ((x)->devdata->type == IS_MX6Q) #define GPMI_IS_MX6SX(x) ((x)->devdata->type == IS_MX6SX) +#define GPMI_IS_MX7D(x) ((x)->devdata->type == IS_MX7D) #define GPMI_IS_MX6(x) (GPMI_IS_MX6Q(x) || GPMI_IS_MX6SX(x)) +#define GPMI_IS_MX7(x) (GPMI_IS_MX7D(x)) #endif -- 1.9.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/