net: fealnx: fix build for UML
authorRandy Dunlap <rdunlap@infradead.org>
Thu, 14 Oct 2021 05:05:00 +0000 (22:05 -0700)
committerJakub Kicinski <kuba@kernel.org>
Fri, 15 Oct 2021 02:18:22 +0000 (19:18 -0700)
On i386, when builtin (not a loadable module), the fealnx driver
inspects boot_cpu_data to see what CPU family it is running on, and
then acts on that data. The "family" struct member (x86) does not exist
when running on UML, so prevent that test and do the default action.

Prevents this build error on UML + i386:

../drivers/net/ethernet/fealnx.c: In function ‘netdev_open’:
../drivers/net/ethernet/fealnx.c:861:19: error: ‘struct cpuinfo_um’ has no member named ‘x86’

Fixes: 68f5d3f3b654 ("um: add PCI over virtio emulation driver")
Signed-off-by: Randy Dunlap <rdunlap@infradead.org>
Cc: linux-um@lists.infradead.org
Cc: Jeff Dike <jdike@addtoit.com>
Cc: Richard Weinberger <richard@nod.at>
Cc: Anton Ivanov <anton.ivanov@cambridgegreys.com>
Link: https://lore.kernel.org/r/20211014050500.5620-1-rdunlap@infradead.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/fealnx.c

index 63c935e7b625c70b84b486fd3df91b48325c24d0..ab194c9b0691e3fe6a5348932e4ecba03e0a3dd6 100644 (file)
@@ -857,7 +857,7 @@ static int netdev_open(struct net_device *dev)
        np->bcrvalue |= 0x04;   /* big-endian */
 #endif
 
-#if defined(__i386__) && !defined(MODULE)
+#if defined(__i386__) && !defined(MODULE) && !defined(CONFIG_UML)
        if (boot_cpu_data.x86 <= 4)
                np->crvalue = 0xa00;
        else