Re: [PATCH v1 1/4] clk: samsung: change COMMON_CLK_SAMSUNG default config logic
From: Lee Jones
Date: Thu Sep 23 2021 - 08:57:38 EST
On Tue, 21 Sep 2021, Krzysztof Kozlowski wrote:
> On 21/09/2021 19:58, Will McVicker wrote:
> > On Tue, Sep 21, 2021 at 1:35 AM Krzysztof Kozlowski
> > <krzysztof.kozlowski@xxxxxxxxxxxxx> wrote:
> >>
> >> On 21/09/2021 09:50, Geert Uytterhoeven wrote:
> >>> On Tue, Sep 21, 2021 at 9:31 AM Krzysztof Kozlowski <krzk@xxxxxxxxxx> wrote:
> >>>> On 20/09/2021 21:03, Will McVicker wrote:
> >>>>> COMMON_CLK_SAMSUNG is selected by ARCH_EXYNOS which forces this config
> >>>>> to be built-in when ARCH_EXYNOS is enabled. Switch the logic to use a
> >>>>> "default y if ARCH_EXYNOS" to provide flexibilty for vendors to disable
> >>>>> or modularize this driver.
> >>>>
> >>>> The clock drivers are essential, you cannot disable them for a generic
> >>>> kernel supporting ARCH_EXYNOS. Such kernel won't work properly on platforms.
> >>>
> >>> Obviously it's not gonna work if the clock driver is not enabled
> >>> at all. But does it work if you make the clock driver modular, and
> >>> put it with all other essential driver modules in initramfs? Debugging
> >>> would be hard, as the serial console driver also relies on clocks
> >>> and PM Domains etc.
> >>
> >> The kernel could boot without clock drivers (default settings from
> >> bootloader), probe clocks from initramfs and proceed with rootfs from
> >> eMMC/SD/net.
> >>
> >> In theory.
> >>
> >> However I have no reports that it ever worked. If there is such working
> >> upstream configuration, I don't mind here. Just please explain this in
> >> the commit msg.
> >>
> >>>
> >>> If not, this patch should be NAKed, until it works with a modular
> >>> clock driver.
> >>>
> >>> If yes, perhaps another line should be added (_before_ the other line)?
> >>>
> >>> + default m if ARCH_EXYNOS && MODULES
> >>> default y if ARCH_EXYNOS
> >>>
> >>> However, many developers may want MODULES=y, but not want to bother
> >>> with an initramfs. So perhaps we need a new symbol
> >>> MINIMUM_GENERIC_KERNEL or so, protected by EXPERT, and make the
> >>> driver default to m if that is enabled?
> >>
> >> Yeah, that's indeed a problem to solve. For most users (and distros)
> >> building kernel for Exynos this should be built-in by default.
> >>
> >> Anyway, the option is non-selectable so it cannot be converted to "m" or
> >> disabled. And this is claimed in the commit msg:
> >> "provide flexibilty for vendors to disable or modularize this driver."
> >>
> >> The commit does not achieve it.
> >>
> >> Best regards,
> >> Krzysztof
> >
> > Thanks for the reviews! As Lee has explained in his replies, the
> > intent of this series is to provide config flexibility to create a
> > defconfig that allows us to move out SoC specific drivers in order to
> > create a generic kernel that can be used across multiple devices with
> > different SoCs.
>
> That's quite generic statement... or let me put it that way - we already
> have this ability to create a generic kernel supporting different SoCs.
> Exynos and other ARMv7 and ARMv8 platforms are multiplatform.
>
> Task is done.
multi_v7_defconfig and ARMv8's defconfig are bloated monoliths which
provide limited flexibility. Good for testing and messing around -
not much good for real products.
> Please be more specific about use case and describe what exactly in
> current upstream multiplatform kernel is missing, what is not
> multiplatform enough.
The use-case is GKI. A realistic middle-ground between fully open
source and real-world usage of the Linux kernel in a competitive
technical arena. GKI aims to be as close to Mainline as possible,
whilst allowing hardware vendors to supply their own software
containing their perceived competitive edge and/or supporting
not-yet-released hardware platforms.
If you end up over-constraining the ability to configure the kernel in
useful/meaningful ways, that makes one of the main (best intention)
aims of GKI, (i.e. to have an upstream first ethos in order to be as
close to upstream as possible) much more difficult.
I put in a lot of effort to ensure GKI doesn't end up as just another
fork of the Linux kernel. So far, so good, but flexibility and
understanding is key.
> > I'm sorry I added confusion by mentioning
> > modularization. All of these drivers that I am modifying in this
> > series can be modularized which is an ongoing effort, but is not
> > addressed here and I don't believe that modularizing them should be a
> > requirement before supporting enabling/disabling them.
>
> Since the disabling the driver for a kernel supporting Exynos does not
> make any sense, then making it at least modular unfortunately it is a
> requirement.
I can go with that.
> > I will update the series with my patch that refactors the Samsung SoC
> > drivers menuconfig to make these visible as well.
>
> I would first recommend to really describe your use case because my
> questions about this are still unanswered.
Hopefully my replies have helped somewhat.
Happy to discuss further if required.
If all else fails, feel free to ping me on IRC (lag).
--
Lee Jones [李琼斯]
Senior Technical Lead - Developer Services
Linaro.org │ Open source software for Arm SoCs
Follow Linaro: Facebook | Twitter | Blog