Re: [PATCH] clk: amlogic: axg-audio: select RESET_MESON_AUX
From: Jerome Brunet
Date: Wed Dec 04 2024 - 12:56:03 EST
On Tue 03 Dec 2024 at 12:15, Stephen Boyd <sboyd@xxxxxxxxxx> wrote:
> Quoting Jerome Brunet (2024-12-03 03:15:41)
>> On Mon 02 Dec 2024 at 18:53, Stephen Boyd <sboyd@xxxxxxxxxx> wrote:
>> >
>> > I think the best approach is to add the reset auxilary device with a
>> > function that creates the auxiliary device directly by string name and
>> > does nothing else. Maybe we can have some helper in the auxiliary
>> > layer that does that all for us, because it's quite a bit of boiler
>> > plate that we need to write over and over again. Something like:
>> >
>> > int devm_auxiliary_device_create(struct device *parent, const char *name)
>> >
>> > that does the whole kzalloc() + ida dance that
>> > devm_meson_rst_aux_register() is doing today and wraps it all up so that
>> > the device is removed when the parent driver unbinds. Then this clk
>> > driver can register the reset device with a single call and not need to
>> > do anything besides select AUXILIARY_BUS.
>>
>> I think this is fairly close to what I proposed in the inital RFC, but
>> generic instead of specific.
>
> Ok :-/ I've realized that we need this sort of approach in more places
> to logically split the device without making it SoC specific. It's only
> useful to have the registration API live in the driver when we need to
> call functions provided by that module from the driver registering the
> auxiliary device.
>
>>
>> I suspect the the generic path is likely to trigger more discussion.
>> I'd like to be able to finish this migration, instead of leaving half
>> finished like it is now.
>
> Is the half finished migration a problem for this cycle? I was intending
> to send the revert later this week and try again next cycle.
Not really, with the fix you applied. There is just code present in
reset that should not be used in its current form. I'd prefer to
sanitise the situation sooner rather than later.
>
>>
>> May I add back the boiler plate code in drivers/clk/meson, similar to
>> what was proposed in the RFC [1] and propose the generic implementation
>> in parallel ? It will just be a matter of switching when/if it is approved.
>
> Sure. You can make devm_meson_clk_rst_aux_register() use the same
> signature as I proposed above so that it's a one line patch later. And
> definitely drop the imply RESET_MESON and depends on REGMAP part. Maybe
> you can put it in the clkc-utils file?
Sure. Few things I'd like to clarify
* I tend think like Arnd, platform data will be needed eventually. Not
sure having 2 functions, one with the param, one without is really
worth it. We could just pass NULL when it is not needed. It is not
uncommon. Would it be acceptable ? (for the generic helper, the
temporary solution does not need that for sure)
* You mean (meson-)clkc-utils.c ? I could but that would add dependency on
the auxiliary_bus for clock controllers that don't need it. It is a
minor problem really that I could just ignore.
I'd rather keep this helper separate if possible.
* Why drop 'imply RESET_MESON_AUX' ? I would still like the
COMMON_CLK_AXG_AUDIO to 'strongly suggest' RESET_MESON_AUX, with
dependency problem sorted out.
--
Jerome