Re: [PATCH] clk: scpi: error when clock fails to register

From: Jerome Brunet
Date: Thu Jun 29 2017 - 04:50:34 EST


On Wed, 2017-06-28 at 18:07 +0100, Sudeep Holla wrote:
>
> On 28/06/17 17:46, Jerome Brunet wrote:
> > On Wed, 2017-06-28 at 16:52 +0100, Sudeep Holla wrote:
>
> [..]
>
> > >
> > > Thanks for this stack. I just worked out the same path now. I did come
> > > up with the patch as below. That should work if my understanding is
> > > correct.
> >
> > I tried.
>
> Thanks.
>
> > It does not work unfortunately. Still crashes but somewhere else:
> > [ÂÂÂÂ2.301482] [<ffff00000849e67c>] scpi_of_clk_src_get+0x14/0x58
> > [ÂÂÂÂ2.307261] [<ffff000008495f40>] __of_clk_get_by_name+0x100/0x118
> > [ÂÂÂÂ2.313297] [<ffff000008495fac>] clk_get+0x2c/0x78
> > [ÂÂÂÂ2.318044] [<ffff00000856f4d0>] dev_pm_opp_get_opp_table+0xb0/0x118
> > [ÂÂÂÂ2.324338] [<ffff00000856fd00>] dev_pm_opp_add+0x20/0x68
> > [ÂÂÂÂ2.329687] [<ffff0000087a04f8>] scpi_init_opp_table+0xa8/0x188
> > [ÂÂÂÂ2.335550] [<ffff00000879fb20>]
> > _get_cluster_clk_and_freq_table+0x80/0x180
> > [ÂÂÂÂ2.342450] [<ffff0000087a0010>] bL_cpufreq_init+0x3f0/0x480
> > [ÂÂÂÂ2.348056] [<ffff00000879e4a0>] cpufreq_online+0xc0/0x658
> > [ÂÂÂÂ2.353490] [<ffff00000879eac8>] cpufreq_add_dev+0x78/0x88
> > [ÂÂÂÂ2.358924] [<ffff00000855b684>] subsys_interface_register+0x84/0xc8
> > [ÂÂÂÂ2.365220] [<ffff00000879d8f8>] cpufreq_register_driver+0x138/0x1b8
> > [ÂÂÂÂ2.371516] [<ffff0000087a0114>] bL_cpufreq_register+0x74/0x120
> > [ÂÂÂÂ2.377381] [<ffff0000087a0600>] scpi_cpufreq_probe+0x28/0x38
> > [ÂÂÂÂ2.383076] [<ffff00000855efb0>] platform_drv_probe+0x50/0xb8
> > [ÂÂÂÂ2.388766] [<ffff00000855d144>] driver_probe_device+0x21c/0x2d8
> >
>
> Looks like a different route and I know why. I have added an extra check
> now which should work if I have not missed anything more.
>
> > I have not looked at ALL the clock providers, but I have seen a few and I
> > don't
> > remember seeing any which fails, at some point, to register a clocks and
> > still
> > register successfully.Â
> >
>
> No problem, as I said I am fine with the patch you sent as a fix for now
> but just curious to know what are the issues to be fixed to continue
> supporting that feature. Please bear with me.

I am :) and I understand what you are trying to do, having a degraded clock
provider is better than nothing according to you, correct?

I'm wondering whether this is correct or not, that why I'm challenging this a
bit.

If you failed to register an scpi clock it is probably because the communication
with the FW is not working, or at least 'not that good', right ?

If for some reason, you manage to register some other clocks from the same FW,
how confident can you be that communication will be ok for them ? that the
settings you request will be applied correctly ?

Is it possible that you may be causing more harm/damage playing with a broken HW
?

>
> > It seems strange to continue with a broken controller.
> >
>
> I would have agreed if it was single driver or h/w controlled by Linux.
> Since it's in the firmware, we should allow the working clocks/opps to
> work though few are broken. It's not good if we had to disable
> everything if some piece of firmware is not yet ready or broken.
> But again, we can get it working later, for now, I am fine with you patch.

I tried your last version, and it does not Oops, at least not for me.

The end result still looks odd to me:
[ÂÂÂÂ1.115219] scpi_clocks scpi:clocks: failed to register clock 'vcpu'
[ÂÂÂÂ1.159490] cpu cpu0: _get_cluster_clk_and_freq_table: Failed to get clk for
cpu: 0, cluster: 0
[ÂÂÂÂ1.162986] cpu cpu0: _get_cluster_clk_and_freq_table: Failed to get data for
cluster: 0
[ÂÂÂÂ1.170945] cpu cpu1: _get_cluster_clk_and_freq_table: Failed to get clk for
cpu: 1, cluster: 0
[ÂÂÂÂ1.179634] cpu cpu1: _get_cluster_clk_and_freq_table: Failed to get data for
cluster: 0
[ÂÂÂÂ1.187654] cpu cpu2: _get_cluster_clk_and_freq_table: Failed to get clk for
cpu: 2, cluster: 0
[ÂÂÂÂ1.196284] cpu cpu2: _get_cluster_clk_and_freq_table: Failed to get data for
cluster: 0
[ÂÂÂÂ1.204375] cpu cpu3: _get_cluster_clk_and_freq_table: Failed to get clk for
cpu: 3, cluster: 0
[ÂÂÂÂ1.212911] cpu cpu3: _get_cluster_clk_and_freq_table: Failed to get data for
cluster: 0
[ÂÂÂÂ1.220612] arm_big_little: bL_cpufreq_register: Registered platform driver:
scpi

So now, I have an scpi clock provider which registers successfully but fails to
register its only clock. As a consequence, I also have a cpufreq driver which
manages to register but has no clock cpu clock to drive ...

>
> Regards,
> Sudeep
>
> ---
>
> diff --git i/drivers/clk/clk-scpi.c w/drivers/clk/clk-scpi.c
> index 96d37175d0ad..a0b9b4c84be3 100644
> --- i/drivers/clk/clk-scpi.c
> +++ w/drivers/clk/clk-scpi.c
> @@ -192,7 +192,7 @@ scpi_of_clk_src_get(struct of_phandle_args *clkspec,
> void *data)
>
> ÂÂÂÂÂÂÂÂfor (count = 0; count < clk_data->clk_num; count++) {
> ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂsclk = clk_data->clk[count];
> -ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂif (idx == sclk->id)
> +ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂif (sclk && idx == sclk->id)
> ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂreturn &sclk->hw;
> ÂÂÂÂÂÂÂÂ}
>
> @@ -245,11 +245,14 @@ static int scpi_clk_add(struct device *dev, struct
> device_node *np,
> ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂsclk->id = val;
>
> ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂerr = scpi_clk_ops_init(dev, match, sclk, name);
> -ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂif (err)
> +ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂif (err) {
> ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂdev_err(dev, "failed to register clock '%s'\n",
> name);
> -ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂelse
> +ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂclk_data->clk[idx] = NULL;
> +ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂdevm_kfree(dev, sclk);
> +ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂ} else {
> ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂdev_dbg(dev, "Registered clock '%s'\n", name);
> -ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂclk_data->clk[idx] = sclk;
> +ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂclk_data->clk[idx] = sclk;
> +ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂ}
> ÂÂÂÂÂÂÂÂ}
>
> ÂÂÂÂÂÂÂÂreturn of_clk_add_hw_provider(np, scpi_of_clk_src_get, clk_data);
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-clk" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info atÂÂhttp://vger.kernel.org/majordomo-info.html