fsl/fman: allow modular build
authorArnd Bergmann <arnd@arndb.de>
Fri, 1 Jan 2016 13:55:24 +0000 (14:55 +0100)
committerDavid S. Miller <davem@davemloft.net>
Tue, 5 Jan 2016 02:53:42 +0000 (21:53 -0500)
ARM allmodconfig fails because of the addition of the FMAN driver:

drivers/built-in.o: In function `dtsec_restart_autoneg':
binder.c:(.text+0x173328): undefined reference to `mdiobus_read'
binder.c:(.text+0x173348): undefined reference to `mdiobus_write'
drivers/built-in.o: In function `dtsec_config':
binder.c:(.text+0x173d24): undefined reference to `of_phy_find_device'
drivers/built-in.o: In function `init_phy':
binder.c:(.text+0x1763b0): undefined reference to `of_phy_connect'
drivers/built-in.o: In function `stop':
binder.c:(.text+0x176014): undefined reference to `phy_stop'
drivers/built-in.o: In function `start':
binder.c:(.text+0x176078): undefined reference to `phy_start'

The reason is that the driver uses PHYLIB, but that is a loadable
module here, and fman itself is built-in.

This patch makes it possible to configure fman as a module as well
so we don't change the status of PHYLIB in an allmodconfig kernel,
and it adds a 'select PHYLIB' statement to ensure that phylib is
always built-in when fman is.

The driver uses "builtin_platform_driver(fman_driver);", which means
it cannot be unloaded, but it's still possible to have it as a loadable
module that gets loaded once and never removed.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Fixes: 5adae51a64b8 ("fsl/fman: Add FMan MURAM support")
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/freescale/fman/Kconfig

index 66b729692b4845b32ebd5d7be60885f08f63f1ad..79b7c84b7869939425f93a2175ef8254a2d6bb03 100644 (file)
@@ -1,7 +1,8 @@
 config FSL_FMAN
-       bool "FMan support"
+       tristate "FMan support"
        depends on FSL_SOC || COMPILE_TEST
        select GENERIC_ALLOCATOR
+       select PHYLIB
        default n
        help
                Freescale Data-Path Acceleration Architecture Frame Manager