Hi Biju, On Thu, Oct 27, 2022 at 4:49 PM Biju Das <biju.das.jz@xxxxxxxxxxxxxx> wrote: > Add RZ/G2L MTU3 core driver for the Multi-Function Timer Pulse > Unit 3 (MTU3a) hardware available on SoCs from Renesas. The core > driver allow to share the clk and channel between the other > drivers like PWM, Clock Source, Clock event and Counter. > > Signed-off-by: Biju Das <biju.das.jz@xxxxxxxxxxxxxx> > --- > v4->v5: Thanks for the update! > * Moved core driver from MFD to timer > * Child devices instatiated using mfd_add_devices() > --- a/drivers/clocksource/Kconfig > +++ b/drivers/clocksource/Kconfig > @@ -524,6 +524,16 @@ config SH_TIMER_MTU2 > Timer Pulse Unit 2 (MTU2) hardware available on SoCs from Renesas. > This hardware comes with 16-bit timer registers. > > +config RZ_MTU3 > + bool "Renesas RZ/G2L MTU3 core driver" > + depends on (ARCH_RZG2L && OF) || COMPILE_TEST As you are calling mfd_add_devices(), this driver needs (a very small part of) the functionality provided by MFD. If CONFIG_MFD_CORE is not set: aarch64-linux-gnu-ld: drivers/clocksource/rz-mtu3.o: in function `rz_mtu3_reset_assert': rz-mtu3.c:(.text+0x38): undefined reference to `mfd_remove_devices' aarch64-linux-gnu-ld: drivers/clocksource/rz-mtu3.o: in function `rz_mtu3_probe': rz-mtu3.c:(.text+0x180): undefined reference to `mfd_add_devices' So either you should make this depend on MFD_CORE, or move to another mechanism for registering the sub devices (e.g. calling platform_device_{alloc,add}(), cfr. rpcif_probe()). > + help > + Select this option to enable Renesas RZ/G2L MTU3 core driver for > + the Multi-Function Timer Pulse Unit 3 (MTU3a) hardware available on > + SoCs from Renesas. The core driver allow to share the clk and channel > + between the others drivers like PWM, Clock Source, Clock event and > + Counter. > + Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@xxxxxxxxxxxxxx In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds