All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jisheng Zhang <jszhang@marvell.com>
To: Ludovic Desroches <ludovic.desroches@atmel.com>
Cc: ulf.hansson@linaro.org, arnd@arndb.de, swarren@wwwdotorg.org,
	lee@kernel.org, eric@anholt.net, michal.simek@xilinx.com,
	soren.brinkmann@xilinx.com, srinivas.kandagatla@gmail.com,
	maxime.coquelin@st.com, patrice.chotard@st.com,
	thierry.reding@gmail.com, sebastian.hesselbarth@gmail.com,
	linux-mmc@vger.kernel.org, linux-rpi-kernel@lists.infradead.org,
	linux-arm-kernel@lists.infradead.org,
	linux-kernel@vger.kernel.org, kernel@stlinux.com,
	linux-tegra@vger.kernel.org
Subject: Re: [PATCH v2 06/12] mmc: sdhci-of-at91: use sdhci_pltfm_init for private allocation
Date: Wed, 6 Jan 2016 17:22:48 +0800	[thread overview]
Message-ID: <20160106172248.7ab58050@xhacker> (raw)
In-Reply-To: <20160106090215.GG2334@odux.rfo.atmel.com>

Dear Ludovic,

On Wed, 6 Jan 2016 10:02:15 +0100 Ludovic Desroches wrote:

> Hi Jisheng,
> 
> Thanks for your patch but it needs to be updated since it breaks this
> driver.
> 
> -       struct sdhci_at91_priv  *priv = pltfm_host->priv;
> +       struct sdhci_at91_priv  *priv = sdhci_pltfm_priv(pltfm_host);
> 
> is missing in sdhci_at91_runtime_suspend and sdhci_at91_runtime_resume
> causing a NULL pointer dereference.

My code base is 4.4-rc8.
I didn't see sdhci_at91_runtime_suspend and sdhci_at91_runtime_resume
functions in the sdhci-of-at91.c. Seems the at91 runtime pm support
is newly added and intends for 4.5.

So the question is which code base should I use? 

Hi Ulf,

could you please give some suggestions?

Thanks in advance,
Jisheng

> 
> On Wed, Jan 06, 2016 at 11:55:59AM +0800, Jisheng Zhang wrote:
> > Commit 0e748234293f ("mmc: sdhci: Add size for caller in init+register")
> > allows users of sdhci_pltfm to allocate private space in calls to
> > sdhci_pltfm_init+sdhci_pltfm_register. This patch migrates the
> > sdhci-of-at91 driver to this allocation.
> > 
> > Signed-off-by: Jisheng Zhang <jszhang@marvell.com>
> > Acked-by: Arnd Bergmann <arnd@arndb.de>
> > ---
> >  drivers/mmc/host/sdhci-of-at91.c | 21 ++++++++-------------
> >  1 file changed, 8 insertions(+), 13 deletions(-)
> > 
> > diff --git a/drivers/mmc/host/sdhci-of-at91.c b/drivers/mmc/host/sdhci-of-at91.c
> > index 06d0b50..765eb09 100644
> > --- a/drivers/mmc/host/sdhci-of-at91.c
> > +++ b/drivers/mmc/host/sdhci-of-at91.c
> > @@ -68,11 +68,13 @@ static int sdhci_at91_probe(struct platform_device *pdev)
> >  		return -EINVAL;
> >  	soc_data = match->data;
> >  
> > -	priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL);
> > -	if (!priv) {
> > -		dev_err(&pdev->dev, "unable to allocate private data\n");
> > -		return -ENOMEM;
> > -	}
> > +	host = sdhci_pltfm_init(pdev, soc_data,
> > +				sizeof(*priv));  
> 
> Can be on the same line.

Great! will do in v3.

> 
> Regards
> 
> Ludovic
> 
> > +	if (IS_ERR(host))
> > +		return PTR_ERR(host);
> > +
> > +	pltfm_host = sdhci_priv(host);
> > +	priv = sdhci_pltfm_priv(pltfm_host);
> >  
> >  	priv->mainck = devm_clk_get(&pdev->dev, "baseclk");
> >  	if (IS_ERR(priv->mainck)) {
> > @@ -92,10 +94,6 @@ static int sdhci_at91_probe(struct platform_device *pdev)
> >  		return PTR_ERR(priv->gck);
> >  	}
> >  
> > -	host = sdhci_pltfm_init(pdev, soc_data, 0);
> > -	if (IS_ERR(host))
> > -		return PTR_ERR(host);
> > -
> >  	/*
> >  	 * The mult clock is provided by as a generated clock by the PMC
> >  	 * controller. In order to set the rate of gck, we have to get the
> > @@ -135,9 +133,6 @@ static int sdhci_at91_probe(struct platform_device *pdev)
> >  	clk_prepare_enable(priv->mainck);
> >  	clk_prepare_enable(priv->gck);
> >  
> > -	pltfm_host = sdhci_priv(host);
> > -	pltfm_host->priv = priv;
> > -
> >  	ret = mmc_of_parse(host->mmc);
> >  	if (ret)
> >  		goto clocks_disable_unprepare;
> > @@ -163,7 +158,7 @@ static int sdhci_at91_remove(struct platform_device *pdev)
> >  {
> >  	struct sdhci_host	*host = platform_get_drvdata(pdev);
> >  	struct sdhci_pltfm_host	*pltfm_host = sdhci_priv(host);
> > -	struct sdhci_at91_priv	*priv = pltfm_host->priv;
> > +	struct sdhci_at91_priv	*priv = sdhci_pltfm_priv(pltfm_host);
> >  
> >  	sdhci_pltfm_unregister(pdev);
> >  
> > -- 
> > 2.7.0.rc3
> >   

WARNING: multiple messages have this Message-ID (diff)
From: jszhang@marvell.com (Jisheng Zhang)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v2 06/12] mmc: sdhci-of-at91: use sdhci_pltfm_init for private allocation
Date: Wed, 6 Jan 2016 17:22:48 +0800	[thread overview]
Message-ID: <20160106172248.7ab58050@xhacker> (raw)
In-Reply-To: <20160106090215.GG2334@odux.rfo.atmel.com>

Dear Ludovic,

On Wed, 6 Jan 2016 10:02:15 +0100 Ludovic Desroches wrote:

> Hi Jisheng,
> 
> Thanks for your patch but it needs to be updated since it breaks this
> driver.
> 
> -       struct sdhci_at91_priv  *priv = pltfm_host->priv;
> +       struct sdhci_at91_priv  *priv = sdhci_pltfm_priv(pltfm_host);
> 
> is missing in sdhci_at91_runtime_suspend and sdhci_at91_runtime_resume
> causing a NULL pointer dereference.

My code base is 4.4-rc8.
I didn't see sdhci_at91_runtime_suspend and sdhci_at91_runtime_resume
functions in the sdhci-of-at91.c. Seems the at91 runtime pm support
is newly added and intends for 4.5.

So the question is which code base should I use? 

Hi Ulf,

could you please give some suggestions?

Thanks in advance,
Jisheng

> 
> On Wed, Jan 06, 2016 at 11:55:59AM +0800, Jisheng Zhang wrote:
> > Commit 0e748234293f ("mmc: sdhci: Add size for caller in init+register")
> > allows users of sdhci_pltfm to allocate private space in calls to
> > sdhci_pltfm_init+sdhci_pltfm_register. This patch migrates the
> > sdhci-of-at91 driver to this allocation.
> > 
> > Signed-off-by: Jisheng Zhang <jszhang@marvell.com>
> > Acked-by: Arnd Bergmann <arnd@arndb.de>
> > ---
> >  drivers/mmc/host/sdhci-of-at91.c | 21 ++++++++-------------
> >  1 file changed, 8 insertions(+), 13 deletions(-)
> > 
> > diff --git a/drivers/mmc/host/sdhci-of-at91.c b/drivers/mmc/host/sdhci-of-at91.c
> > index 06d0b50..765eb09 100644
> > --- a/drivers/mmc/host/sdhci-of-at91.c
> > +++ b/drivers/mmc/host/sdhci-of-at91.c
> > @@ -68,11 +68,13 @@ static int sdhci_at91_probe(struct platform_device *pdev)
> >  		return -EINVAL;
> >  	soc_data = match->data;
> >  
> > -	priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL);
> > -	if (!priv) {
> > -		dev_err(&pdev->dev, "unable to allocate private data\n");
> > -		return -ENOMEM;
> > -	}
> > +	host = sdhci_pltfm_init(pdev, soc_data,
> > +				sizeof(*priv));  
> 
> Can be on the same line.

Great! will do in v3.

> 
> Regards
> 
> Ludovic
> 
> > +	if (IS_ERR(host))
> > +		return PTR_ERR(host);
> > +
> > +	pltfm_host = sdhci_priv(host);
> > +	priv = sdhci_pltfm_priv(pltfm_host);
> >  
> >  	priv->mainck = devm_clk_get(&pdev->dev, "baseclk");
> >  	if (IS_ERR(priv->mainck)) {
> > @@ -92,10 +94,6 @@ static int sdhci_at91_probe(struct platform_device *pdev)
> >  		return PTR_ERR(priv->gck);
> >  	}
> >  
> > -	host = sdhci_pltfm_init(pdev, soc_data, 0);
> > -	if (IS_ERR(host))
> > -		return PTR_ERR(host);
> > -
> >  	/*
> >  	 * The mult clock is provided by as a generated clock by the PMC
> >  	 * controller. In order to set the rate of gck, we have to get the
> > @@ -135,9 +133,6 @@ static int sdhci_at91_probe(struct platform_device *pdev)
> >  	clk_prepare_enable(priv->mainck);
> >  	clk_prepare_enable(priv->gck);
> >  
> > -	pltfm_host = sdhci_priv(host);
> > -	pltfm_host->priv = priv;
> > -
> >  	ret = mmc_of_parse(host->mmc);
> >  	if (ret)
> >  		goto clocks_disable_unprepare;
> > @@ -163,7 +158,7 @@ static int sdhci_at91_remove(struct platform_device *pdev)
> >  {
> >  	struct sdhci_host	*host = platform_get_drvdata(pdev);
> >  	struct sdhci_pltfm_host	*pltfm_host = sdhci_priv(host);
> > -	struct sdhci_at91_priv	*priv = pltfm_host->priv;
> > +	struct sdhci_at91_priv	*priv = sdhci_pltfm_priv(pltfm_host);
> >  
> >  	sdhci_pltfm_unregister(pdev);
> >  
> > -- 
> > 2.7.0.rc3
> >   

WARNING: multiple messages have this Message-ID (diff)
From: Jisheng Zhang <jszhang@marvell.com>
To: Ludovic Desroches <ludovic.desroches@atmel.com>
Cc: <ulf.hansson@linaro.org>, <arnd@arndb.de>,
	<swarren@wwwdotorg.org>, <lee@kernel.org>, <eric@anholt.net>,
	<michal.simek@xilinx.com>, <soren.brinkmann@xilinx.com>,
	<srinivas.kandagatla@gmail.com>, <maxime.coquelin@st.com>,
	<patrice.chotard@st.com>, <thierry.reding@gmail.com>,
	<sebastian.hesselbarth@gmail.com>, <linux-mmc@vger.kernel.org>,
	<linux-rpi-kernel@lists.infradead.org>,
	<linux-arm-kernel@lists.infradead.org>,
	<linux-kernel@vger.kernel.org>, <kernel@stlinux.com>,
	<linux-tegra@vger.kernel.org>
Subject: Re: [PATCH v2 06/12] mmc: sdhci-of-at91: use sdhci_pltfm_init for private allocation
Date: Wed, 6 Jan 2016 17:22:48 +0800	[thread overview]
Message-ID: <20160106172248.7ab58050@xhacker> (raw)
In-Reply-To: <20160106090215.GG2334@odux.rfo.atmel.com>

Dear Ludovic,

On Wed, 6 Jan 2016 10:02:15 +0100 Ludovic Desroches wrote:

> Hi Jisheng,
> 
> Thanks for your patch but it needs to be updated since it breaks this
> driver.
> 
> -       struct sdhci_at91_priv  *priv = pltfm_host->priv;
> +       struct sdhci_at91_priv  *priv = sdhci_pltfm_priv(pltfm_host);
> 
> is missing in sdhci_at91_runtime_suspend and sdhci_at91_runtime_resume
> causing a NULL pointer dereference.

My code base is 4.4-rc8.
I didn't see sdhci_at91_runtime_suspend and sdhci_at91_runtime_resume
functions in the sdhci-of-at91.c. Seems the at91 runtime pm support
is newly added and intends for 4.5.

So the question is which code base should I use? 

Hi Ulf,

could you please give some suggestions?

Thanks in advance,
Jisheng

> 
> On Wed, Jan 06, 2016 at 11:55:59AM +0800, Jisheng Zhang wrote:
> > Commit 0e748234293f ("mmc: sdhci: Add size for caller in init+register")
> > allows users of sdhci_pltfm to allocate private space in calls to
> > sdhci_pltfm_init+sdhci_pltfm_register. This patch migrates the
> > sdhci-of-at91 driver to this allocation.
> > 
> > Signed-off-by: Jisheng Zhang <jszhang@marvell.com>
> > Acked-by: Arnd Bergmann <arnd@arndb.de>
> > ---
> >  drivers/mmc/host/sdhci-of-at91.c | 21 ++++++++-------------
> >  1 file changed, 8 insertions(+), 13 deletions(-)
> > 
> > diff --git a/drivers/mmc/host/sdhci-of-at91.c b/drivers/mmc/host/sdhci-of-at91.c
> > index 06d0b50..765eb09 100644
> > --- a/drivers/mmc/host/sdhci-of-at91.c
> > +++ b/drivers/mmc/host/sdhci-of-at91.c
> > @@ -68,11 +68,13 @@ static int sdhci_at91_probe(struct platform_device *pdev)
> >  		return -EINVAL;
> >  	soc_data = match->data;
> >  
> > -	priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL);
> > -	if (!priv) {
> > -		dev_err(&pdev->dev, "unable to allocate private data\n");
> > -		return -ENOMEM;
> > -	}
> > +	host = sdhci_pltfm_init(pdev, soc_data,
> > +				sizeof(*priv));  
> 
> Can be on the same line.

Great! will do in v3.

> 
> Regards
> 
> Ludovic
> 
> > +	if (IS_ERR(host))
> > +		return PTR_ERR(host);
> > +
> > +	pltfm_host = sdhci_priv(host);
> > +	priv = sdhci_pltfm_priv(pltfm_host);
> >  
> >  	priv->mainck = devm_clk_get(&pdev->dev, "baseclk");
> >  	if (IS_ERR(priv->mainck)) {
> > @@ -92,10 +94,6 @@ static int sdhci_at91_probe(struct platform_device *pdev)
> >  		return PTR_ERR(priv->gck);
> >  	}
> >  
> > -	host = sdhci_pltfm_init(pdev, soc_data, 0);
> > -	if (IS_ERR(host))
> > -		return PTR_ERR(host);
> > -
> >  	/*
> >  	 * The mult clock is provided by as a generated clock by the PMC
> >  	 * controller. In order to set the rate of gck, we have to get the
> > @@ -135,9 +133,6 @@ static int sdhci_at91_probe(struct platform_device *pdev)
> >  	clk_prepare_enable(priv->mainck);
> >  	clk_prepare_enable(priv->gck);
> >  
> > -	pltfm_host = sdhci_priv(host);
> > -	pltfm_host->priv = priv;
> > -
> >  	ret = mmc_of_parse(host->mmc);
> >  	if (ret)
> >  		goto clocks_disable_unprepare;
> > @@ -163,7 +158,7 @@ static int sdhci_at91_remove(struct platform_device *pdev)
> >  {
> >  	struct sdhci_host	*host = platform_get_drvdata(pdev);
> >  	struct sdhci_pltfm_host	*pltfm_host = sdhci_priv(host);
> > -	struct sdhci_at91_priv	*priv = pltfm_host->priv;
> > +	struct sdhci_at91_priv	*priv = sdhci_pltfm_priv(pltfm_host);
> >  
> >  	sdhci_pltfm_unregister(pdev);
> >  
> > -- 
> > 2.7.0.rc3
> >   


  reply	other threads:[~2016-01-06  9:22 UTC|newest]

Thread overview: 51+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-01-06  3:55 [PATCH v2 00/12] mmc: use sdhci_pltfm_init for private allocation and clean up Jisheng Zhang
2016-01-06  3:55 ` Jisheng Zhang
2016-01-06  3:55 ` Jisheng Zhang
2016-01-06  3:55 ` [PATCH v2 01/12] mmc: sdhci-bcm2835: use sdhci_pltfm_init for private allocation Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
     [not found] ` <1452052565-4232-1-git-send-email-jszhang-eYqpPyKDWXRBDgjK7y7TUQ@public.gmane.org>
2016-01-06  3:55   ` [PATCH v2 02/12] mmc: sdhci-esdhc-imx: " Jisheng Zhang
2016-01-06  3:55     ` Jisheng Zhang
2016-01-06  3:55     ` Jisheng Zhang
2016-01-06  3:56   ` [PATCH v2 07/12] mmc: sdhci-of-esdhc: " Jisheng Zhang
2016-01-06  3:56     ` Jisheng Zhang
2016-01-06  3:56     ` Jisheng Zhang
2016-01-06  3:56   ` [PATCH v2 09/12] mmc: sdhci-st: " Jisheng Zhang
2016-01-06  3:56     ` Jisheng Zhang
2016-01-06  3:56     ` Jisheng Zhang
2016-01-06  3:55 ` [PATCH v2 03/12] mmc: sdhci-msm: factorise sdhci_msm_pdata outisde of sdhci_msm_host Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
2016-01-06  3:55 ` [PATCH v2 04/12] mmc: sdhci-msm: use sdhci_pltfm_init for private allocation Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
2016-01-06  3:55 ` [PATCH v2 05/12] mmc: sdhci-of-arasan: " Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
2016-01-06  3:55 ` [PATCH v2 06/12] mmc: sdhci-of-at91: " Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
2016-01-06  3:55   ` Jisheng Zhang
     [not found]   ` <1452052565-4232-7-git-send-email-jszhang-eYqpPyKDWXRBDgjK7y7TUQ@public.gmane.org>
2016-01-06  9:02     ` Ludovic Desroches
2016-01-06  9:02       ` Ludovic Desroches
2016-01-06  9:02       ` Ludovic Desroches
2016-01-06  9:22       ` Jisheng Zhang [this message]
2016-01-06  9:22         ` Jisheng Zhang
2016-01-06  9:22         ` Jisheng Zhang
2016-01-06  9:34         ` Jisheng Zhang
2016-01-06  9:34           ` Jisheng Zhang
2016-01-06  9:34           ` Jisheng Zhang
2016-01-06 10:11         ` Ludovic Desroches
2016-01-06 10:11           ` Ludovic Desroches
2016-01-06 10:11           ` Ludovic Desroches
2016-01-06  3:56 ` [PATCH v2 08/12] mmc: sdhci-pxav3: " Jisheng Zhang
2016-01-06  3:56   ` Jisheng Zhang
2016-01-06  3:56   ` Jisheng Zhang
2016-01-06  3:56 ` [PATCH v2 10/12] mmc: sdhci-tegra: " Jisheng Zhang
2016-01-06  3:56   ` Jisheng Zhang
2016-01-06  3:56   ` Jisheng Zhang
2016-01-06  3:56 ` [PATCH v2 11/12] mmc: sdhci-pxav2: remove unnecessary assignment of pltfm_host->priv Jisheng Zhang
2016-01-06  3:56   ` Jisheng Zhang
2016-01-06  3:56   ` Jisheng Zhang
2016-01-06  3:56 ` [PATCH v2 12/12] mmc: sdhci-pltfm: remove priv variable from sdhci_pltfm_host Jisheng Zhang
2016-01-06  3:56   ` Jisheng Zhang
2016-01-06  3:56   ` Jisheng Zhang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20160106172248.7ab58050@xhacker \
    --to=jszhang@marvell.com \
    --cc=arnd@arndb.de \
    --cc=eric@anholt.net \
    --cc=kernel@stlinux.com \
    --cc=lee@kernel.org \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mmc@vger.kernel.org \
    --cc=linux-rpi-kernel@lists.infradead.org \
    --cc=linux-tegra@vger.kernel.org \
    --cc=ludovic.desroches@atmel.com \
    --cc=maxime.coquelin@st.com \
    --cc=michal.simek@xilinx.com \
    --cc=patrice.chotard@st.com \
    --cc=sebastian.hesselbarth@gmail.com \
    --cc=soren.brinkmann@xilinx.com \
    --cc=srinivas.kandagatla@gmail.com \
    --cc=swarren@wwwdotorg.org \
    --cc=thierry.reding@gmail.com \
    --cc=ulf.hansson@linaro.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.