All of lore.kernel.org
 help / color / mirror / Atom feed
From: Bjorn Andersson <bjorn.andersson@linaro.org>
To: Ritesh Harjani <riteshh@codeaurora.org>
Cc: adrian.hunter@intel.com, ulf.hansson@linaro.org,
	shawn.lin@rock-chips.com, jh80.chung@samsung.com,
	linux-mmc@vger.kernel.org, linux-arm-msm@vger.kernel.org,
	georgi.djakov@linaro.org, alex.lemberg@sandisk.com,
	mateusz.nowak@intel.com, Yuliy.Izrailov@sandisk.com,
	asutoshd@codeaurora.org, kdorfman@codeaurora.org,
	david.griego@linaro.org, stummala@codeaurora.org,
	venkatg@codeaurora.org
Subject: Re: [PATCH v3 3/9] mmc: sdhci-msm: add pltfm_data support to get clk-rates from DT
Date: Mon, 22 Aug 2016 21:31:21 -0700	[thread overview]
Message-ID: <20160823043121.GC26240@tuxbot> (raw)
In-Reply-To: <1471581384-18961-4-git-send-email-riteshh@codeaurora.org>

On Thu 18 Aug 21:36 PDT 2016, Ritesh Harjani wrote:

> This adds support for sdhc-msm controllers to get supported
> clk-rates from DT. sdhci-msm would need it's own set_clock
> ops to be implemented. For this, supported clk-rates needs
> to be populated in sdhci_msm_pltfm_data.
> 
> Signed-off-by: Ritesh Harjani <riteshh@codeaurora.org>
> ---
>  .../devicetree/bindings/mmc/sdhci-msm.txt          |  1 +
>  drivers/mmc/host/sdhci-msm.c                       | 71 ++++++++++++++++++++++
>  2 files changed, 72 insertions(+)
> 
> diff --git a/Documentation/devicetree/bindings/mmc/sdhci-msm.txt b/Documentation/devicetree/bindings/mmc/sdhci-msm.txt
> index 485483a..6a83b38 100644
> --- a/Documentation/devicetree/bindings/mmc/sdhci-msm.txt
> +++ b/Documentation/devicetree/bindings/mmc/sdhci-msm.txt
> @@ -17,6 +17,7 @@ Required properties:
>  	"iface" - Main peripheral bus clock (PCLK/HCLK - AHB Bus clock) (required)
>  	"core"	- SDC MMC clock (MCLK) (required)
>  	"bus"	- SDCC bus voter clock (optional)
> +- clk-rates: Array of supported GCC clock frequencies for sdhc, Units - Hz.
>  
>  Example:
>  
> diff --git a/drivers/mmc/host/sdhci-msm.c b/drivers/mmc/host/sdhci-msm.c
> index 85ddaae..2bf141b 100644
> --- a/drivers/mmc/host/sdhci-msm.c
> +++ b/drivers/mmc/host/sdhci-msm.c
> @@ -74,6 +74,11 @@
>  #define CMUX_SHIFT_PHASE_SHIFT	24
>  #define CMUX_SHIFT_PHASE_MASK	(7 << CMUX_SHIFT_PHASE_SHIFT)
>  
> +struct sdhci_msm_pltfm_data {
> +	u32 *clk_table;
> +	size_t clk_table_sz;
> +};

Rather than calling this "platform data", just call it
sdhci_msm_freq_table and make it:

struct sdhci_msm_freq_table {
	size_t num_freqs;
	u32 freqs[];
};

> +
>  struct sdhci_msm_host {
>  	struct platform_device *pdev;
>  	void __iomem *core_mem;	/* MSM SDCC mapped address */
> @@ -83,6 +88,7 @@ struct sdhci_msm_host {
>  	struct clk *bus_clk;	/* SDHC bus voter clock */
>  	struct mmc_host *mmc;
>  	bool use_14lpp_dll_reset;
> +	struct sdhci_msm_pltfm_data *pdata;
>  };
>  
>  /* Platform specific tuning */
> @@ -582,6 +588,67 @@ static const struct sdhci_pltfm_data sdhci_msm_pdata = {
>  	.ops = &sdhci_msm_ops,
>  };
>  
> +static int sdhci_msm_dt_get_array(struct device *dev, const char *prop_name,
> +				u32 **table, size_t *size)
> +{
> +	struct device_node *np = dev->of_node;
> +	int count = 0;
> +	u32 *arr = NULL;
> +	int ret = 0;
> +
> +	count = of_property_count_elems_of_size(np, prop_name, sizeof(u32));
> +	if (count < 0) {
> +		dev_err(dev, "%s: Invalid dt property, err(%d)\n",
> +				prop_name, count);
> +		ret = count;
> +		goto out;
> +	}
> +
> +	arr = devm_kzalloc(dev, count * sizeof(*arr), GFP_KERNEL);
> +	if (!arr) {
> +		ret = -ENOMEM;
> +		goto out;
> +	}
> +
> +	ret = of_property_read_u32_array(np, prop_name, arr, count);
> +	if (ret) {
> +		dev_err(dev, "%s Invalid dt array property, err(%d)\n",
> +				prop_name, ret);
> +		goto out;
> +	}
> +	*table = arr;
> +	*size = count;
> +out:
> +	return ret;
> +}
> +
> +static struct sdhci_msm_pltfm_data *sdhci_msm_populate_pdata(struct device *dev,
> +						struct sdhci_msm_host *msm_host)
> +{
> +	struct sdhci_msm_pltfm_data *pdata = NULL;
> +	size_t table_sz = 0;
> +	u32 *table = NULL;
> +

Count of_property_count_elems_of_size() here and then allocate
sizeof(*tbl) + count * sizeof(tbl->freqs[0]) and fill that in, no need
for the two allocations.

> +	pdata = devm_kzalloc(dev, sizeof(*pdata), GFP_KERNEL);
> +	if (!pdata)
> +		goto out;

No need for a goto for early errors, just return as you haven't touch
any state yet.

> +
> +	if (sdhci_msm_dt_get_array(dev, "clk-rates", &table, &table_sz)) {
> +		dev_err(dev, "failed in DT parsing for supported clk-rates\n");
> +		goto out;
> +	}
> +	if (!table || !table_sz) {

A general comment; don't be too defensive in your code. Neither table
nor table_sz should be able to be zero if the above condition fails...

> +		dev_err(dev, "Invalid clock table\n");
> +		goto out;
> +	}
> +	pdata->clk_table = table;
> +	pdata->clk_table_sz = table_sz;
> +
> +	return pdata;
> +out:
> +	return NULL;
> +}
> +
>  static int sdhci_msm_probe(struct platform_device *pdev)
>  {
>  	struct sdhci_host *host;
> @@ -608,6 +675,10 @@ static int sdhci_msm_probe(struct platform_device *pdev)
>  
>  	sdhci_get_of_property(pdev);
>  
> +	msm_host->pdata = sdhci_msm_populate_pdata(&pdev->dev, msm_host);
> +	if (!msm_host->pdata)
> +		goto pltfm_free;

Adding this as a requirement breaks existing platforms/dtbs, you may
force it for 8996 if you can detect that, but you should not change it
for existing platforms.

> +
>  	/* Setup SDCC bus voter clock. */
>  	msm_host->bus_clk = devm_clk_get(&pdev->dev, "bus");
>  	if (!IS_ERR(msm_host->bus_clk)) {

Regards,
Bjorn

  parent reply	other threads:[~2016-08-23  4:31 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-08-19  4:36 [PATCH v3 0/9] mmc: sdhci-msm: Add clk-rates and DDR support Ritesh Harjani
2016-08-19  4:36 ` [PATCH v3 1/9] mmc: sdhci-msm: Change poor style writel/readl of registers Ritesh Harjani
2016-08-19 13:02   ` Adrian Hunter
2016-08-19  4:36 ` [PATCH v3 2/9] mmc: sdhci-msm: Update DLL reset sequence Ritesh Harjani
2016-08-19 13:03   ` Adrian Hunter
2016-08-19  4:36 ` [PATCH v3 3/9] mmc: sdhci-msm: add pltfm_data support to get clk-rates from DT Ritesh Harjani
2016-08-19 13:03   ` Adrian Hunter
2016-08-19 13:36     ` Ritesh Harjani
2016-08-23  4:31   ` Bjorn Andersson [this message]
2016-08-23  6:35     ` Ritesh Harjani
2016-08-24 16:56       ` Bjorn Andersson
2016-08-25  6:03         ` Ritesh Harjani
2016-08-19  4:36 ` [PATCH v3 4/9] arm64: dts: qcom: msm8916: Add clk-rates to sdhc1 & sdhc2 Ritesh Harjani
2016-08-19  4:36 ` [PATCH v3 5/9] mmc: sdhci-msm: Add get_min_clock() and get_max_clock() callback Ritesh Harjani
2016-08-19 13:03   ` Adrian Hunter
2016-08-19  4:36 ` [PATCH v3 6/9] mmc: sdhci-msm: Enable few quirks Ritesh Harjani
2016-08-19 13:04   ` Adrian Hunter
2016-08-19  4:36 ` [PATCH v3 7/9] mmc: sdhci-msm: Implement set_clock callback for sdhci-msm Ritesh Harjani
2016-08-19 13:04   ` Adrian Hunter
2016-08-19 13:31     ` Ritesh Harjani
2016-08-22  6:20       ` Adrian Hunter
2016-08-22  9:07         ` Ritesh Harjani
2016-08-22  9:29           ` Adrian Hunter
2016-08-22 12:56             ` Ritesh Harjani
2016-08-23 13:17               ` Adrian Hunter
2016-08-23 13:39                 ` Ritesh Harjani
2016-08-19  4:36 ` [PATCH v3 8/9] mmc: sdhci-msm: Add clock changes for DDR mode Ritesh Harjani
2016-08-19 13:04   ` Adrian Hunter
2016-08-19 13:26     ` Ritesh Harjani
2016-08-19  4:36 ` [PATCH v3 9/9] arm64: dts: qcom: msm8916: Add ddr support to sdhc1 Ritesh Harjani

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=20160823043121.GC26240@tuxbot \
    --to=bjorn.andersson@linaro.org \
    --cc=Yuliy.Izrailov@sandisk.com \
    --cc=adrian.hunter@intel.com \
    --cc=alex.lemberg@sandisk.com \
    --cc=asutoshd@codeaurora.org \
    --cc=david.griego@linaro.org \
    --cc=georgi.djakov@linaro.org \
    --cc=jh80.chung@samsung.com \
    --cc=kdorfman@codeaurora.org \
    --cc=linux-arm-msm@vger.kernel.org \
    --cc=linux-mmc@vger.kernel.org \
    --cc=mateusz.nowak@intel.com \
    --cc=riteshh@codeaurora.org \
    --cc=shawn.lin@rock-chips.com \
    --cc=stummala@codeaurora.org \
    --cc=ulf.hansson@linaro.org \
    --cc=venkatg@codeaurora.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.