Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755886AbcC2GPc (ORCPT ); Tue, 29 Mar 2016 02:15:32 -0400 Received: from mailout2.samsung.com ([203.254.224.25]:59273 "EHLO mailout2.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751407AbcC2GP3 (ORCPT ); Tue, 29 Mar 2016 02:15:29 -0400 MIME-version: 1.0 Content-type: text/plain; charset=utf-8 X-AuditID: cbfee68f-f79c86d0000012ad-58-56fa1d7e5958 Content-transfer-encoding: 8BIT Message-id: <56FA1D7D.1090807@samsung.com> Date: Tue, 29 Mar 2016 15:15:25 +0900 From: Jaehoon Chung User-Agent: Mozilla/5.0 (X11; Linux i686; rv:31.0) Gecko/20100101 Thunderbird/31.6.0 To: Shawn Lin , Guodong Xu Cc: robh+dt@kernel.org, =?UTF-8?B?UGF3ZcWCIE1vbGw=?= , Mark Rutland , ijc+devicetree@hellion.org.uk, Kumar Gala , Ulf Hansson , devicetree@vger.kernel.org, "linux-kernel@vger.kernel.org" , linux-mmc@vger.kernel.org, Xinwei Kong , Zhangfei Gao Subject: Re: [PATCH 2/2] mmc: dw_mmc: add resets support to dw_mmc References: <1457254062-22677-1-git-send-email-guodong.xu@linaro.org> <1457254062-22677-2-git-send-email-guodong.xu@linaro.org> <56DC3BAD.8020107@rock-chips.com> <56F9E6E5.9000100@kernel-upstream.org> <56FA192A.9030209@samsung.com> <56FA1C1C.4090008@rock-chips.com> In-reply-to: <56FA1C1C.4090008@rock-chips.com> X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFjrHIsWRmVeSWpSXmKPExsWyRsSkSLdO9leYwfO7vBbzj5xjteh/s5DV 4v+dHlaLc69WMlr8+LuP1eLyrjlsFkf+9zNaLL1+kcliwvS1LBate4+wW9x5sp7V4vjacIub ay6wO/B6rJm3htHjcl8vk8fK5V/YPB7P3cjusWlVJ5vHnWt72Dz+ztrP4vF5k1wARxSXTUpq TmZZapG+XQJXRse8j0wFDy0rGjY2sDUwXlLrYuTkkBAwkbh1cx0rhC0mceHeerYuRi4OIYEV jBKPfm1hhim6+/YYI0RiKaPEocPdTCAJXgFBiR+T77F0MXJwMAvISxy5lA1hqktMmZILUf6A UWLe215miHItibvLFzKC2CwCqhITL84FW8wmoCOx/dtxsJGiAmESD9btBYuLCPhI/Fx7HGwv s8BaZol9l6aDDRIWcJLYNP081EE3mCQOLrkOluAU0JN4emQTE0hCQmAqh8TynknMEOsEJL5N PgR2qYSArMSmA1CfSUocXHGDZQKj2Cwk/8xC+GcWwj8LGJlXMYqmFiQXFCelFxnrFSfmFpfm pesl5+duYgRG8+l/z/p3MN49YH2IUYCDUYmHN2LRzzAh1sSy4srcQ4ymQDdMZJYSTc4Hpoy8 knhDYzMjC1MTU2Mjc0szJXHehVI/g4UE0hNLUrNTUwtSi+KLSnNSiw8xMnFwSjUwGn9WEls5 o3rhRNGeyM1WYqunHQuaftL/yMddbvtrFq2evntF3er7//cozvEsTd+5V3/jvurUzr/n5nga F7Ackg+Q2siQluVSXKeYOn3y7oe5XoxzJFZGJN3lbTbdpyIrsV6A60iKxe+/kWf8gy7KbVrs 96Plm/eMjxOj9JdrVi7/LmraGLdgkRJLcUaioRZzUXEiAFL6s97hAgAA X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFprNKsWRmVeSWpSXmKPExsVy+t9jAd062V9hBu93slnMP3KO1aL/zUJW i/93elgtzr1ayWjx4+8+VovLu+awWRz5389osfT6RSaLCdPXsli07j3CbnHnyXpWi+Nrwy1u rrnA7sDrsWbeGkaPy329TB4rl39h83g8dyO7x6ZVnWwed67tYfP4O2s/i8fnTXIBHFENjDYZ qYkpqUUKqXnJ+SmZeem2St7B8c7xpmYGhrqGlhbmSgp5ibmptkouPgG6bpk5QDcrKZQl5pQC hQISi4uV9O0wTQgNcdO1gGmM0PUNCYLrMTJAAwlrGDM65n1kKnhoWdGwsYGtgfGSWhcjJ4eE gInE3bfHGCFsMYkL99azdTFycQgJLGWUOHS4mwkkwSsgKPFj8j2WLkYODmYBeYkjl7IhTHWJ KVNyIcofMErMe9vLDFGuJXF3+UKwmSwCqhITL85lBbHZBHQktn87DjZSVCBM4sG6vWBxEQEf iZ9rjzOCDGIWWMssse/SdLBBwgJOEpumn2eE2HCDSeLgkutgCU4BPYmnRzYxTWAUmIXkvlkI 981CuG8BI/MqRonUguSC4qT0XKO81HK94sTc4tK8dL3k/NxNjOCE8Ux6B+PhXe6HGAU4GJV4 eBkW/AwTYk0sK67MPcQowcGsJMJbJf4rTIg3JbGyKrUoP76oNCe1+BCjKdCDE5mlRJPzgcks ryTe0NjEzMjSyNzQwsjYXEmc9/H/dWFCAumJJanZqakFqUUwfUwcnFINjFVyby6rfrE4fHiT b9LJ/Nzu6HTHxb6tsT4v3pmyO1lONa5Jmj8l78fHeybT/076N+1p22P9Dy+38XjdLGpi9uP8 F+yUk2/ZfLL6s2fbq7bJNyo3J0W36YffnrX86MRDLhdNStRTE8/8FrKOPshfZCVkz/Hu/tfq 3Fm8PI0hcbm7W2sWST45pMRSnJFoqMVcVJwIAI1K+BMuAwAA DLP-Filter: Pass X-MTR: 20000000000000000@CPGS X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 7182 Lines: 209 On 03/29/2016 03:09 PM, Shawn Lin wrote: > 在 2016/3/29 13:56, Jaehoon Chung 写道: >> On 03/29/2016 11:22 AM, Shawn Lin wrote: >>> 在 2016/3/25 13:35, Guodong Xu 写道: >>>> Hi, Shawn >>>> >>>> Sorry I replied late. I added comments below. >>>> >>>> On 6 March 2016 at 22:16, Shawn Lin >>> > wrote: >>>> >>>> On 2016/3/6 16:47, Guodong Xu wrote: >>>> >>>> mmc registers may in abnormal state if mmc is used in bootloader, >>>> eg. to support booting from eMMC. So we need reset mmc registers >>>> when kernel boots up, instead of assuming mmc is in clean state. >>>> >>>> With this patch, user can add a 'resets' property into dw_mmc dts >>>> node. When driver parse_dt and probe, it calls reset API to >>>> deassert the 'reset' of dw_mmc host controller. When probe error or >>>> remove, it calls reset API to assert it. >>>> >>>> Please also refer to >>>> Documentation/devicetree/bindings/reset/reset.txt >>>> >>>> Signed-off-by: Guodong Xu >>> > >>>> Signed-off-by: Xinwei Kong >>> > >>>> Signed-off-by: Zhangfei Gao >>> > >>>> >>>> >>>> Really should V2 and add the changelog. >>>> >>>> >>>> Yes, will do. next version I sent will be labelled as V3. >>>> >>>> >>>> >>>> --- >>>> drivers/mmc/host/dw_mmc.c | 22 +++++++++++++++++++++- >>>> 1 file changed, 21 insertions(+), 1 deletion(-) >>>> >>>> diff --git a/drivers/mmc/host/dw_mmc.c b/drivers/mmc/host/dw_mmc.c >>>> index 242f9a0..281ea9c 100644 >>>> --- a/drivers/mmc/host/dw_mmc.c >>>> +++ b/drivers/mmc/host/dw_mmc.c >>>> @@ -2878,6 +2878,14 @@ static struct dw_mci_board >>>> *dw_mci_parse_dt(struct dw_mci *host) >>>> if (!pdata) >>>> return ERR_PTR(-ENOMEM); >>>> >>>> + /* find reset controller when exist */ >>>> + pdata->rstc = devm_reset_control_get_optional(dev, NULL); >>>> + if (IS_ERR(pdata->rstc)) { >>>> + if (PTR_ERR(pdata->rstc) == -EPROBE_DEFER) >>>> + return ERR_PTR(-EPROBE_DEFER); >>>> + pdata->rstc = NULL; >>>> >>>> >>>> maybe we can remove "pdata->rstc = NULL", and directly >>>> use IS_ERR(..) for the following "if (host->pdata->rstc != NULL)" >>>> statement >>>> >>>> >>>> Yes, will do. >>>> I see your point, other lines in this file are using IS_ERR(!..), I will >>>> use this style too. >>>> >>>> + } >>>> + >>>> /* find out number of slots supported */ >>>> of_property_read_u32(np, "num-slots", &pdata->num_slots); >>>> >>>> @@ -2949,7 +2957,9 @@ int dw_mci_probe(struct dw_mci *host) >>>> >>>> if (!host->pdata) { >>>> host->pdata = dw_mci_parse_dt(host); >>>> - if (IS_ERR(host->pdata)) { >>>> + if (PTR_ERR(host->pdata) == -EPROBE_DEFER) >>>> + return -EPROBE_DEFER; >>>> >>>> >>>> please fix the coding style here. >>>> >>>> >>>> Do you mean to add additional {} for this 'if' , like this? >>>> >>>> + if (PTR_ERR(host->pdata) == -EPROBE_DEFER) { >>>> + return -EPROBE_DEFER; >>>> >>>> + } >>>> >>>> I will add {}. >>>> >>>> >>>> >>>> + else if (IS_ERR(host->pdata)) { >>>> dev_err(host->dev, "platform data not >>>> available\n"); >>>> return -EINVAL; >>>> } >>>> @@ -3012,6 +3022,9 @@ int dw_mci_probe(struct dw_mci *host) >>>> } >>>> } >>>> >>>> + if (host->pdata->rstc != NULL) >>>> + reset_control_deassert(host->pdata->rstc); >>>> + >>>> >>>> >>>> sorry, I can't follow your intention here. Shouldn't it be something >>>> like "assert mmc -> may need delay -> deassert mmc". As your current >>>> code, nothing happend right? >>>> >>>> >>>> The chip exits from bootloader with this bit asserted. And when entering >>>> kernel, we only need to deassert. >>>> >>>> In my current code, the driver deassert mmc in _probe(), and assert mmc >>>> in _remove(). >>> >>> I catch your point. From the previous discussion, we add it to make sure >>> dw_mmc in good state after leaving bootloader to kernel. But My real question is that you can assert it in bootloader, so you can also >>> dessert it in bootloaer to make sure dw_mmc work fine when probing >>> in kernel. In that way, we don't need this patch? >> >> Doesn't dw_mci_hw_reset work fine? I think that card should be reset with MMC_CAP_HW_RESET. >> Could you check this? >> > > MMC_CAP_HW_RESET actually reset the mmc card, but Guodong means to > reset the controller rather than mmc card :) We have talked about FBE scenarios, right? :) Now, I remembered it. > > >> Best Regards, >> Jaehoon Chung >> >>> >>> More to think, Is it ok to match the behaviour of bootloader stage? >>> My bootloader doesn't assert the reset pin of dw_mmc, so it seams if >>> I want to fix you issue on kernel stage, I need a new round of >>> assert->delay->deassert. >>> >>> >>>> >>>> >>>> >>>> setup_timer(&host->cmd11_timer, >>>> dw_mci_cmd11_timer, (unsigned long)host); >>>> >>>> @@ -3164,6 +3177,9 @@ err_dmaunmap: >>>> if (host->use_dma && host->dma_ops->exit) >>>> host->dma_ops->exit(host); >>>> >>>> + if (host->pdata->rstc != NULL) >>>> + reset_control_assert(host->pdata->rstc); >>>> + >>>> err_clk_ciu: >>>> if (!IS_ERR(host->ciu_clk)) >>>> clk_disable_unprepare(host->ciu_clk); >>>> @@ -3196,11 +3212,15 @@ void dw_mci_remove(struct dw_mci *host) >>>> if (host->use_dma && host->dma_ops->exit) >>>> host->dma_ops->exit(host); >>>> >>>> + if (host->pdata->rstc != NULL) >>>> + reset_control_assert(host->pdata->rstc); >>>> + >>>> if (!IS_ERR(host->ciu_clk)) >>>> clk_disable_unprepare(host->ciu_clk); >>>> >>>> if (!IS_ERR(host->biu_clk)) >>>> clk_disable_unprepare(host->biu_clk); >>>> + >>>> } >>>> >>>> >>>> unnecessary new line here. >>>> >>>> >>>> Will fix. >>>> >>>> -Guodong >>>> >>>> >>>> EXPORT_SYMBOL(dw_mci_remove); >>>> >>>> >>>> >>>> >>>> -- >>>> Best Regards >>>> Shawn Lin >>>> >>>> >>> >>> >>> >> >> >> >> > >