Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755132AbbGaOYD (ORCPT ); Fri, 31 Jul 2015 10:24:03 -0400 Received: from mail-bl2on0110.outbound.protection.outlook.com ([65.55.169.110]:43200 "EHLO na01-bl2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1755112AbbGaOX6 (ORCPT ); Fri, 31 Jul 2015 10:23:58 -0400 Authentication-Results: spf=fail (sender IP is 192.88.158.2) smtp.mailfrom=freescale.com; vger.kernel.org; dkim=none (message not signed) header.d=none; Date: Fri, 31 Jul 2015 22:15:08 +0800 From: Dong Aisheng To: Haibo Chen CC: , , , , , , , , , , , , , , , Subject: Re: [PATCH v3 1/6] mmc: sdhci-esdhc-imx: add imx7d support and support HS400 Message-ID: <20150731141507.GB27806@shlinux1.ap.freescale.net> References: <1438160637-28061-1-git-send-email-haibo.chen@freescale.com> <1438160637-28061-2-git-send-email-haibo.chen@freescale.com> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: <1438160637-28061-2-git-send-email-haibo.chen@freescale.com> User-Agent: Mutt/1.5.20 (2009-06-14) X-EOPAttributedMessage: 0 X-Microsoft-Exchange-Diagnostics: 1;BN1BFFO11FD047;1:EL09oRGBKnnJXRanHK6tZ81FKQT0a8mTEtG6FATuLEwgFqzwVGh95wza4YOCz8Sj8Ob0OEwPDay71bu2tyhzpIGvOpPe4TQXS/4yyFouNFglPc7Rf44d/QJzzTy/x4K3vsFpoLfbylkW0GuNPao/Nqg8/RWzBYHcOH5033d5rBaNFQNPdHw9p6l9mQUPBKm44r4gHC85z4O6YcMBDYL//L9f++tuSdrwPtwFWSk57DLZgSAeqOIh8BlOXqfqOS9TJOmqIgxNJsVKjE0E6ja5a/SWxhps50d1+kV6cIQmUoCL3HDeQ6bLq+0NSE4oESl9QlM6q0uybGrOBWj5xBUAkQ== X-Forefront-Antispam-Report: CIP:192.88.158.2;CTRY:US;IPV:NLI;EFV:NLI;SFV:NSPM;SFS:(10019020)(6009001)(2980300002)(339900001)(199003)(24454002)(189002)(4001350100001)(230783001)(106466001)(4001450100002)(47776003)(92566002)(50986999)(97756001)(50466002)(54356999)(83506001)(77156002)(105606002)(19580405001)(77096005)(2950100001)(85426001)(46102003)(76176999)(6806004)(87936001)(23726002)(5003600100002)(86362001)(19580395003)(62966003)(104016003)(33656002)(110136002)(46406003)(189998001)(5001960100002);DIR:OUT;SFP:1102;SCL:1;SRVR:BN3PR03MB1383;H:az84smr01.freescale.net;FPR:;SPF:Fail;MLV:sfv;A:1;MX:1;LANG:en; X-Microsoft-Exchange-Diagnostics: 1;BN3PR03MB1383;2:JaUWODcU21ojp+AqHFmnO1JUYMJT1GvKJ7Tdv7Y3xIyQ0UYlelBAWIQl+ED+UxoH6YX8PmVseg5sPLfXCY/2kGIjNRBuNtMnJLNqqnCl5tL15DMFhPADUZjEp9IyKzlpeL64hDYCg0JWnnD0R+x4RXMnXoq0bL5J2kSrok5BTsk=;3:jewv1ZTlA6QOEbzGmrHdRPUjboV294KLFNpV186fCNIWconIeRDR4lLOYh4QymcZv21RWJl7YoEPCwjLm1pDaDSI3DevzlXOyb6Dfp3d7AZfC6ZCA/MGnGcuATLVKI99soBDGGjykm9h9FEStcXV7OLw7LHCQitF8RFlswY9mpkTH1AXw7V6GrWZVjMTyTR8XsEPEdqsgDo/5jNjsWmS6yTpj7JdLF2hlvO5Cu1NHQ8=;25:LFDrnFbBirvCcEU3OpdIuJVrxjNHS2YTDAmAUrMsP/gEY/BQL8mq0Y/PULn1AuVKpoPsLGbk90gJsEzy5h7jzA0HCbTmXteAeSKQGvgKaQjoiqn246PpuKI1MnqGWumO5uVhAH5mINbBBuTvq/FN/goa0eZHbKRi1yLafFOQF6bqVnvrxjFlConC+TZfHHLyLpVT8nlYbu1zLKeE94QM+U/NC3bnEeAl1ev6CRRwIanrMsvo5AE/iFPlbaPWitTGmZjvbxMX3mK9ytNcbx0S/w== X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BN3PR03MB1383; X-Microsoft-Exchange-Diagnostics: 1;BN3PR03MB1383;20:0eFT2X8tAZ3aKOkVUkPvLtDncUMgOm0TBupO1bvgLh6XyJUNnKnpX0YvCo/XvMjldX20+mG9BFXWFWDF8dAgk3RLpKj6u0e15fyBN9WP0yE/CiSFr02PdzTCgji2rMek6E5sglyv11cN0rBjCElyd59bQ0YxSArIxB97A1s4Pxa8Gb6QYygmw8ddMk41jfOifqOqhDpQzT3AkCdXWaZ8vFYs+3G+jSDezg4iAE7Hj0vYTt+vKh1GVd5m2yATdLOBjA5AuVAYv7iUwOakD/BEOuCzEtZSYdMepL1KTEnkyPqMfED1EbjidqUjW11POO5NWziEGVSQMWGqVYbDF2HnXieL1g7SWBOtH0Sq/JQaYm0=;4:D/LhpP7N4F6a0E5yR81wc7LislN3ryMvI30gvTrkfZuGct9+r9Ll787nQ23isJZFdSKGOOnwHUqAT8nD2w4sAUDXxs7pYiXJLGaiyVzEu0HK0E1DLrzYE5xUPE7nmd18SUOulw0ZoNeZWDbvKgt0/s3ZHtCnpNX+6dLWqv2Ci21ugIIIRv8XYB+6zwFpvVMudYlUO0YbMuvtfhSuobWaxT5URoENiIsyFuH854gyzAv3ktGsGWfMb6ikrx62elfsq+IUe4UZdDwvzpiQAqx0Fjv7vdJX2Sws2sl8Nd2kWtU= BN3PR03MB1383: X-MS-Exchange-Organization-RulesExecuted X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(601004)(5005006)(3002001);SRVR:BN3PR03MB1383;BCL:0;PCL:0;RULEID:;SRVR:BN3PR03MB1383; X-Forefront-PRVS: 0654257CF5 X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1;BN3PR03MB1383;23:VmMu04110FByAaW702aR80X1IxcE62mYrn/hRYwCf?= =?us-ascii?Q?oUi7ZTR+Elgv9nUGHI9Eselyq9DEaHbgvt+pSzOj8yzzG8JSpkDXFT+WiOe/?= =?us-ascii?Q?4h7RZ3yRY7SBPQSqARGyoXANPYyJZX44w5KHZ4+vrp9APQI/Z9CVAGsrPS+6?= =?us-ascii?Q?ZtUutWNCTqMD5gTvT/YnQGI6Dvz13ncqKY4RXhu8aUQzxnekkHNPTIfrt56F?= =?us-ascii?Q?oncauLvvnQk/HsKthJFyvmEQI6lX89ip9lRPk80DmbO3FSzWTNkNVFp9+qP7?= =?us-ascii?Q?AnO57o2hjBdm87ysse3jY7gI5o9DM5kjlTmaWPURUHCO68B9db5hMp6NmYbD?= =?us-ascii?Q?H8JKubuUmgyhGifwoMXD/1YXxwPfTml1Jm7bGJJpn8zdAJRCBKtjeYx3NJkJ?= =?us-ascii?Q?GVPaJpBaE83rt/DQjtqAiHoJW36LuvOcQAB/jRWuEicjHRX7GzwVbX4PV9ms?= =?us-ascii?Q?+oD8EGY34nea/n/BGMtYZ0R2C476o6r1bd7BSBohYhqt4UPpKscoiDpRizXH?= =?us-ascii?Q?QkII1RQ9+3NPP2OyCNNwUa/omO1k1pEj+M1K6gBeLqUOBkR5kSnKVWq1ifDh?= =?us-ascii?Q?J6MasFhdJlAWKMLW7dVj/R0kPlqXQKfNoxWt7noPGRv8RWrycCl3c+sAAEXo?= =?us-ascii?Q?tsuXYxMrQ0f0OSw781DMbP1WTSDAtfCqczjol4EaOuEwHe/giijE+LqZ0Dsa?= =?us-ascii?Q?Q0lDA546SiCpi7SAmP1cp97bYsNVyHV3kVKdr0x5c+j3DaspyXbHlpqYOCpj?= =?us-ascii?Q?IGWmIUTf/fj1D9WhgVBqU5x4f/V98FiZplmO6/DoLIYCKUFd9G3aF0B9ZcH2?= =?us-ascii?Q?fMg1HXkWf0gDEo7+fmr7Z0s/HT35Bl77zUlu9vln91gNQBiggXrECJKpMnBO?= =?us-ascii?Q?8Po3aZhZrufvV1WW6d+kop/4iccyUeFwSRAJS6t9EkfMNtMkLQgCfEy2idlx?= =?us-ascii?Q?feUgBPa/1n4PvAx29It4jJX3I0VetvAfqU7FX2E5O5Vs2Jx/2jm1fFtDjnfB?= =?us-ascii?Q?QrANnw7tSOqye7CUYozm9xg?= X-Microsoft-Exchange-Diagnostics: 1;BN3PR03MB1383;5:1VzDGtP6vHFJmRvs1xJZrPUmDVuxK3RGkbFdp8YkYAscDASOSEaG/PSguGGFIimwqEeBZObwkoqylpN3euL2TtiHhh13tskaAYbm2QdOu8gj18cH/ZRcqJ1ruQpRwoINyHQTVHUrG3kHFymY2sqjAQ==;24:AkAAxzGOu6xU2KdPoVvshxiR8Wfe/KPl7ntzkAe7iRl1YePFuW/4QZtn8LV1qGt7dU0q3B66LCBA4qY6DppJkjGuIJMXi52vZdNgx2Bv1sY=;20:CXBEOp6homuwvkDGhx17qMgzzakzTAzuEpvqW751kwp4cwU0lhTIgJajWRKzLnTiEYswLvRHVTstkdzEna1KyA== X-OriginatorOrg: freescale.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 31 Jul 2015 14:23:55.2384 (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.158.2];Helo=[az84smr01.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BN3PR03MB1383 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 6437 Lines: 182 On Wed, Jul 29, 2015 at 05:03:52PM +0800, Haibo Chen wrote: > The imx7d usdhc is derived from imx6sx, the difference is that > imx7d support HS400. > > So introduce a new compatible string for imx7d and add HS400 > support for imx7d usdhc. > > Signed-off-by: Haibo Chen > --- > drivers/mmc/host/sdhci-esdhc-imx.c | 66 ++++++++++++++++++++++++++++++++++++++ > 1 file changed, 66 insertions(+) > > diff --git a/drivers/mmc/host/sdhci-esdhc-imx.c b/drivers/mmc/host/sdhci-esdhc-imx.c > index c6b9f64..b441eed 100644 > --- a/drivers/mmc/host/sdhci-esdhc-imx.c > +++ b/drivers/mmc/host/sdhci-esdhc-imx.c > @@ -44,6 +44,7 @@ > #define ESDHC_MIX_CTRL_EXE_TUNE (1 << 22) > #define ESDHC_MIX_CTRL_SMPCLK_SEL (1 << 23) > #define ESDHC_MIX_CTRL_FBCLK_SEL (1 << 25) > +#define ESDHC_MIX_CTRL_HS400_EN (1 << 26) > /* Bits 3 and 6 are not SDHCI standard definitions */ > #define ESDHC_MIX_CTRL_SDHCI_MASK 0xb7 > /* Tuning bits */ > @@ -60,6 +61,16 @@ > #define ESDHC_TUNE_CTRL_MIN 0 > #define ESDHC_TUNE_CTRL_MAX ((1 << 7) - 1) > > +/* strobe dll register */ > +#define ESDHC_STROBE_DLL_CTRL 0x70 > +#define ESDHC_STROBE_DLL_CTRL_ENABLE (1 << 0) > +#define ESDHC_STROBE_DLL_CTRL_RESET (1 << 1) > +#define ESDHC_STROBE_DLL_CTRL_SLV_DLY_TARGET_SHIFT 3 > + > +#define ESDHC_STROBE_DLL_STATUS 0x74 > +#define ESDHC_STROBE_DLL_STS_REF_LOCK (1 << 1) > +#define ESDHC_STROBE_DLL_STS_SLV_LOCK 0x1 > + > #define ESDHC_TUNING_CTRL 0xcc > #define ESDHC_STD_TUNING_EN (1 << 24) > /* NOTE: the minimum valid tuning start tap for mx6sl is 1 */ > @@ -120,6 +131,8 @@ > #define ESDHC_FLAG_ERR004536 BIT(7) > /* The IP supports HS200 mode */ > #define ESDHC_FLAG_HS200 BIT(8) > +/* The IP supports HS400 mode */ > +#define ESDHC_FLAG_SUP_HS400 BIT(9) > > struct esdhc_soc_data { > u32 flags; > @@ -156,6 +169,12 @@ static struct esdhc_soc_data usdhc_imx6sx_data = { > | ESDHC_FLAG_HAVE_CAP1 | ESDHC_FLAG_HS200, > }; > > +static struct esdhc_soc_data usdhc_imx7d_data = { > + .flags = ESDHC_FLAG_USDHC | ESDHC_FLAG_STD_TUNING > + | ESDHC_FLAG_HAVE_CAP1 | ESDHC_FLAG_HS200 > + | ESDHC_FLAG_SUP_HS400, > +}; > + > struct pltfm_imx_data { > u32 scratchpad; > struct pinctrl *pinctrl; > @@ -199,6 +218,7 @@ static const struct of_device_id imx_esdhc_dt_ids[] = { > { .compatible = "fsl,imx6sx-usdhc", .data = &usdhc_imx6sx_data, }, > { .compatible = "fsl,imx6sl-usdhc", .data = &usdhc_imx6sl_data, }, > { .compatible = "fsl,imx6q-usdhc", .data = &usdhc_imx6q_data, }, > + { .compatible = "fsl,imx7d-usdhc", .data = &usdhc_imx7d_data, }, > { /* sentinel */ } > }; > MODULE_DEVICE_TABLE(of, imx_esdhc_dt_ids); > @@ -274,6 +294,10 @@ static u32 esdhc_readl_le(struct sdhci_host *host, int reg) > val = SDHCI_SUPPORT_DDR50 | SDHCI_SUPPORT_SDR104 > | SDHCI_SUPPORT_SDR50 > | SDHCI_USE_SDR50_TUNING; > + > + /* imx7d does not have a support_hs400 register, fake one */ You could remove this line. It's bit, not register and i think no need such comment. > + if (imx_data->socdata->flags & ESDHC_FLAG_SUP_HS400) > + val |= SDHCI_SUPPORT_HS400; > } > } > > @@ -774,6 +798,7 @@ static int esdhc_change_pinstate(struct sdhci_host *host, > break; > case MMC_TIMING_UHS_SDR104: > case MMC_TIMING_MMC_HS200: > + case MMC_TIMING_MMC_HS400: > pinctrl = imx_data->pins_200mhz; > break; > default: > @@ -784,6 +809,30 @@ static int esdhc_change_pinstate(struct sdhci_host *host, > return pinctrl_select_state(imx_data->pinctrl, pinctrl); > } > > +static void esdhc_set_strobe_dll(struct sdhci_host *host) It would be good if we can add some comments for this function for better understand. > +{ > + u32 v; > + > + /* force a reset on strobe dll */ > + writel(ESDHC_STROBE_DLL_CTRL_RESET, host->ioaddr + ESDHC_STROBE_DLL_CTRL); > + /* > + * enable strobe dll ctrl and adjust the delay target > + * for the uSDHC loopback read clock > + */ > + v = ESDHC_STROBE_DLL_CTRL_ENABLE | > + (7 << ESDHC_STROBE_DLL_CTRL_SLV_DLY_TARGET_SHIFT); > + writel(v, host->ioaddr + ESDHC_STROBE_DLL_CTRL); > + /* wait 1us to make sure strobe dll status register stable */ > + udelay(1); > + v = readl(host->ioaddr + ESDHC_STROBE_DLL_STATUS); > + if (!(v & ESDHC_STROBE_DLL_STS_REF_LOCK)) > + dev_warn(mmc_dev(host->mmc), > + "warning! HS400 strobe DLL status REF not lock!\n"); > + if (!(v & ESDHC_STROBE_DLL_STS_SLV_LOCK)) > + dev_warn(mmc_dev(host->mmc), > + "warning! HS400 strobe DLL status SLV not lock!\n"); > +} > + > static void esdhc_set_uhs_signaling(struct sdhci_host *host, unsigned timing) > { > struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host); > @@ -795,7 +844,13 @@ static void esdhc_set_uhs_signaling(struct sdhci_host *host, unsigned timing) > case MMC_TIMING_UHS_SDR25: > case MMC_TIMING_UHS_SDR50: > case MMC_TIMING_UHS_SDR104: > + break; > case MMC_TIMING_MMC_HS200: > + /* disable ddr mode and disable HS400 mode */ > + writel(readl(host->ioaddr + ESDHC_MIX_CTRL) & > + ~(ESDHC_MIX_CTRL_DDREN | ESDHC_MIX_CTRL_HS400_EN), > + host->ioaddr + ESDHC_MIX_CTRL); > + imx_data->is_ddr = 0; > break; > case MMC_TIMING_UHS_DDR50: > case MMC_TIMING_MMC_DDR52: > @@ -813,6 +868,14 @@ static void esdhc_set_uhs_signaling(struct sdhci_host *host, unsigned timing) > writel(v, host->ioaddr + ESDHC_DLL_CTRL); > } > break; > + case MMC_TIMING_MMC_HS400: > + writel(readl(host->ioaddr + ESDHC_MIX_CTRL) | > + ESDHC_MIX_CTRL_DDREN | ESDHC_MIX_CTRL_HS400_EN, > + host->ioaddr + ESDHC_MIX_CTRL); > + imx_data->is_ddr = 1; > + if (host->clock == 200000000) I can't remember, but could this be a range required by SoC? > + esdhc_set_strobe_dll(host); > + break; > } > > esdhc_change_pinstate(host, timing); > @@ -1100,6 +1163,9 @@ static int sdhci_esdhc_imx_probe(struct platform_device *pdev) > if (imx_data->socdata->flags & ESDHC_FLAG_ERR004536) > host->quirks |= SDHCI_QUIRK_BROKEN_ADMA; > > + if (imx_data->socdata->flags & ESDHC_FLAG_SUP_HS400) > + host->quirks2 |= SDHCI_QUIRK2_CAPS_BIT63_FOR_HS400; > + > if (of_id) > err = sdhci_esdhc_imx_probe_dt(pdev, host, imx_data); > else > -- > 1.9.1 > Regards Dong Aisheng -- 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/