Message ID | 20250218-k1-pinctrl-option-v3-1-36e031e0da1b@gentoo.org |
---|---|
State | New |
Headers | show |
Series | [v3] pinctrl: spacemit: enable config option | expand |
On Sun, Feb 23, 2025 at 1:06 PM Yixun Lan <dlan@gentoo.org> wrote: > Hi Linus Walleij: > > On 08:31 Tue 18 Feb , Yixun Lan wrote: > > Pinctrl is an essential driver for SpacemiT's SoC, > > The uart driver requires it, same as sd card driver, > > so let's enable it by default for this SoC. > > > > The CONFIG_PINCTRL_SPACEMIT_K1 isn't enabled when using > > 'make defconfig' to select kernel configuration options. > > This result in a broken uart driver where fail at probe() > > stage due to no pins found. > > > > Can you take this patch via pinctrl fixes tree? if possible in this cycle OK! Patch applied for fixes. Yours, Linus Walleij
Hi Yixun, On Mon, 17 Mar 2025 at 14:30, Yixun Lan <dlan@gentoo.org> wrote: > On 13:59 Mon 17 Mar , Geert Uytterhoeven wrote: > > On Mon, 17 Mar 2025 at 13:41, Yixun Lan <dlan@gentoo.org> wrote: > > > On 09:18 Mon 17 Mar , Geert Uytterhoeven wrote: > > > > Thanks for your patch, which is now commit 7ff4faba63571c51 > > > > ("pinctrl: spacemit: enable config option") in v6.14-rc7. > > > > > > > > On Tue, 18 Feb 2025 at 01:32, Yixun Lan <dlan@gentoo.org> wrote: > > > > > Pinctrl is an essential driver for SpacemiT's SoC, > > > > > The uart driver requires it, same as sd card driver, > > > > > so let's enable it by default for this SoC. > > > > > > > > > > The CONFIG_PINCTRL_SPACEMIT_K1 isn't enabled when using > > > > > 'make defconfig' to select kernel configuration options. > > > > > This result in a broken uart driver where fail at probe() > > > > > stage due to no pins found. > > > > > > > > Perhaps this is an issue with the uart driver? > > > > I just disabled CONFIG_PINCTRL_RZA2 on RZA2MEVB (which is one of the > > > > few Renesas platforms where the pin control driver is not enabled by > > > > default, for saving memory), and the system booted fine into a Debian > > > > nfsroot. Probe order of some devices did change, and "Trying to > > > > probe devices needed for running init" was printed. > > > > > > > my problem was CONFIG_PINCTRL_SPACEMIT_K1 isn't enabled, result as > > > # CONFIG_PINCTRL_SPACEMIT_K1 is not set > > > > > > for your case, is CONFIG_PINCTRL_RZA2 built as module? > > > it should work for uart driver with deferred probe mechanism.. > > > > No, CONFIG_PINCTRL_RZA2 was disabled in my testing. > > > emm, this is interesting, there might be problem that uart driver > fail to have correct pin settings without pre initialization.. > > which uart driver is used in RZA2MEVB platform? any pinctrl dts property? > different hardware may vary.. It indeed depends on both hardware and firmware. RZA2MEVB uses the sh-sci driver, and its serial console is set up by the boot loader. Does your serial console work with "earlycon"? Gr{oetje,eeting}s, Geert
diff --git a/arch/riscv/Kconfig.socs b/arch/riscv/Kconfig.socs index 1916cf7ba450ec9958265de2ca41dc504d4d2f7c..17606940bb5239d0fdfc6b5aefb50eeb982d14aa 100644 --- a/arch/riscv/Kconfig.socs +++ b/arch/riscv/Kconfig.socs @@ -26,6 +26,7 @@ config ARCH_SOPHGO config ARCH_SPACEMIT bool "SpacemiT SoCs" + select PINCTRL help This enables support for SpacemiT SoC platform hardware. diff --git a/drivers/pinctrl/spacemit/Kconfig b/drivers/pinctrl/spacemit/Kconfig index 168f8a5ffbb952cbeae3e3401c11149558e0a84b..a2f98b3f8a75580d2d157008997cc48f42a89368 100644 --- a/drivers/pinctrl/spacemit/Kconfig +++ b/drivers/pinctrl/spacemit/Kconfig @@ -4,9 +4,10 @@ # config PINCTRL_SPACEMIT_K1 - tristate "SpacemiT K1 SoC Pinctrl driver" + bool "SpacemiT K1 SoC Pinctrl driver" depends on ARCH_SPACEMIT || COMPILE_TEST depends on OF + default y select GENERIC_PINCTRL_GROUPS select GENERIC_PINMUX_FUNCTIONS select GENERIC_PINCONF diff --git a/drivers/pinctrl/spacemit/pinctrl-k1.c b/drivers/pinctrl/spacemit/pinctrl-k1.c index a32579d736130c80bd12f0f9d8b3b2f69c428b3d..59fd555ff38d4453f446263a8fdb4a61faf63cfc 100644 --- a/drivers/pinctrl/spacemit/pinctrl-k1.c +++ b/drivers/pinctrl/spacemit/pinctrl-k1.c @@ -1044,7 +1044,7 @@ static struct platform_driver k1_pinctrl_driver = { .of_match_table = k1_pinctrl_ids, }, }; -module_platform_driver(k1_pinctrl_driver); +builtin_platform_driver(k1_pinctrl_driver); MODULE_AUTHOR("Yixun Lan <dlan@gentoo.org>"); MODULE_DESCRIPTION("Pinctrl driver for the SpacemiT K1 SoC");