patch-2.3.27 linux/drivers/net/setup.c

Next file: linux/drivers/net/sk_mca.c
Previous file: linux/drivers/net/seeq8005.c
Back to the patch index
Back to the overall index

diff -u --recursive --new-file v2.3.26/linux/drivers/net/setup.c linux/drivers/net/setup.c
@@ -0,0 +1,371 @@
+/*
+ *	New style setup code for the network devices
+ */
+ 
+#include <linux/config.h>
+#include <linux/netdevice.h>
+#include <linux/errno.h>
+#include <linux/init.h>
+#include <linux/netlink.h>
+
+extern int mkiss_init_ctrl_dev(void);
+extern int ppp_init(void);
+extern int slip_init_ctrl_dev(void);
+extern int strip_init_ctrl_dev(void);
+extern int x25_asy_init_ctrl_dev(void);
+  
+extern int bpq_init(void);
+extern int dmascc_init(void);
+extern int scc_init(void);
+extern int yam_init(void);
+
+extern int acenic_probe(void); 
+extern int arcnet_init(void); 
+extern int bigmac_probe(void); 
+extern int bmac_probe(void); 
+extern int cpm_enet_init(void); 
+extern int dlci_setup(void); 
+extern int dgrs_probe(void); 
+extern int dmfe_reg_board(void); 
+extern int eepro100_probe(void); 
+extern int epic100_probe(void); 
+extern int happy_meal_probe(void); 
+extern int lapbeth_init(void);
+extern int mace_probe(void); 
+extern int myri_sbus_probe(void); 
+extern int ncr885e_probe(void); 
+extern int ne2k_pci_probe(void); 
+extern int pcnet32_probe(void); 
+extern int qec_probe(void); 
+extern int rcpci_probe(void); 
+extern int rr_hippi_probe(void); 
+extern int rtl8139_probe(void); 
+extern int sdla_setup(void); 
+extern int sis900_probe(void); 
+extern int sparc_lance_probe(void); 
+extern int starfire_probe(void); 
+extern int tc59x_probe(void); 
+extern int tulip_probe(void); 
+extern int via_rhine_probe(void); 
+extern int yellowfin_probe(void);
+
+/* Pad device name to IFNAMSIZ=16. F.e. __PAD6 is tring of 9 zeros. */
+#define __PAD6 "\0\0\0\0\0\0\0\0\0"
+#define __PAD5 __PAD6 "\0"
+#define __PAD4 __PAD5 "\0"
+#define __PAD3 __PAD4 "\0"
+#define __PAD2 __PAD3 "\0"
+
+
+/*
+ *	Devices in this list must do new style probing. That is they must
+ *	allocate their own device objects and do their own bus scans.
+ */
+
+struct net_probe
+{
+	int (*probe)(void);
+	int status;	/* non-zero if autoprobe has failed */
+};
+ 
+struct net_probe pci_probes[] __initdata = {
+	/*
+	 *	Early setup devices
+	 */
+
+#if defined(CONFIG_SCC)
+	{scc_init, 0},
+#endif
+#if defined(CONFIG_DMASCC)
+	{dmascc_init, 0},
+#endif	
+#if defined(CONFIG_BPQETHER)
+	{bpq_init, 0},
+#endif
+#if defined(CONFIG_DLCI)
+	{dlci_setup, 0},
+#endif
+#if defined(CONFIG_SDLA)
+	{sdla_setup, 0},
+#endif
+#if defined(CONFIG_LAPBETHER)
+	{lapbeth_init, 0},
+#endif
+#if defined(CONFIG_PLIP)
+	{plip_init, 0},
+#endif
+#if defined(CONFIG_ARCNET)
+	{arcnet_init, 0},
+#endif
+#if defined(CONFIG_8xx)
+        {cpm_enet_init, 0},
+#endif
+	/*
+	 *	SLHC if present needs attaching so other people see it
+	 *	even if not opened.
+	 */
+	 
+#ifdef CONFIG_INET	 
+#if (defined(CONFIG_SLIP) && defined(CONFIG_SLIP_COMPRESSED)) \
+	 || defined(CONFIG_PPP) \
+    || (defined(CONFIG_ISDN) && defined(CONFIG_ISDN_PPP))
+	{slhc_install, 0},
+#endif	
+#endif
+/*
+ *	HIPPI
+ */
+#ifdef CONFIG_ROADRUNNER
+	{rr_hippi_probe, 0},
+#endif
+
+/*
+ *	ETHERNET
+ */
+ 
+/*
+ *	SBUS Ethernet
+ */
+
+#ifdef CONFIG_HAPPYMEAL
+	{happy_meal_probe, 0},
+#endif
+#ifdef CONFIG_SUNLANCE
+	{sparc_lance_probe, 0},
+#endif
+#ifdef CONFIG_SUNQE
+	{qec_probe, 0},
+#endif
+#ifdef CONFIG_SUNBMAC
+	{bigmac_probe, 0},
+#endif
+#ifdef CONFIG_MYRI_SBUS
+	{myri_sbus_probe, 0},
+#endif
+
+/*
+ *	PowerPC Mainboard
+ */
+
+#ifdef CONFIG_MACE
+	{mace_probe, 0},
+#endif
+#ifdef CONFIG_BMAC
+	{bmac_probe, 0},
+#endif
+#ifdef CONFIG_NCR885E
+	{ncr885e_probe, 0},
+#endif
+
+/*
+ *	PCI Ethernet
+ */
+#ifdef CONFIG_DGRS
+	{dgrs_probe, 0},
+#endif
+#ifdef CONFIG_RCPCI
+	{rcpci_probe, 0},
+#endif
+#ifdef CONFIG_VORTEX
+	{tc59x_probe, 0},
+#endif
+#ifdef CONFIG_NE2K_PCI
+	{ne2k_pci_probe, 0},
+#endif
+#ifdef CONFIG_PCNET32
+	{pcnet32_probe, 0},
+#endif	
+#ifdef CONFIG_EEXPRESS_PRO100	/* Intel EtherExpress Pro/100 */
+	{eepro100_probe, 0},
+#endif
+#ifdef CONFIG_DEC_ELCP 
+	{tulip_probe, 0},
+#endif
+#ifdef CONFIG_DE4X5             /* DEC DE425, DE434, DE435 adapters */
+	{de4x5_probe, 0},
+#endif
+#ifdef CONFIG_EPIC100
+	{epic100_probe, 0},
+#endif
+#ifdef CONFIG_RTL8139
+	{rtl8139_probe, 0},
+#endif
+#ifdef CONFIG_SIS900
+	{sis900_probe, 0},
+#endif
+
+#ifdef CONFIG_DM9102
+	{dmfe_reg_board, 0}, 
+#endif
+
+#ifdef CONFIG_YELLOWFIN
+	{yellowfin_probe, 0},
+#endif
+#ifdef CONFIG_ACENIC
+	{acenic_probe, 0},
+#endif
+#ifdef CONFIG_VIA_RHINE
+	{via_rhine_probe, 0},
+#endif
+#ifdef CONFIG_ADAPTEC_STARFIRE
+	{starfire_probe, 0},
+#endif
+
+/*
+ *	Amateur Radio Drivers
+ */	
+
+#ifdef CONFIG_YAM
+	{yam_init, 0},
+#endif	/* CONFIG_YAM */
+  
+ 
+	{NULL, 0},
+};
+
+
+/*
+ *	Run the updated device probes. These do not need a device passed
+ *	into them.
+ */
+ 
+static void __init network_probe(void)
+{
+	struct net_probe *p = pci_probes;
+
+	while (p->probe != NULL)
+	{
+		p->status = p->probe();
+		p++;
+	}
+}
+
+
+/*
+ *	Initialise the line discipline drivers
+ */
+ 
+static void __init network_ldisc_init(void)
+{
+#if defined(CONFIG_SLIP)
+	slip_init_ctrl_dev();
+#endif
+#if defined(CONFIG_X25_ASY)
+	x25_asy_init_ctrl_dev();
+#endif
+#if defined(CONFIG_MKISS)
+	mkiss_init_ctrl_dev();
+#endif
+#if defined(CONFIG_STRIP)
+	strip_init_ctrl_dev();
+#endif
+#if defined(CONFIG_PPP)
+	ppp_init();
+#endif
+}
+
+
+static void __init appletalk_device_init(void)
+{
+#if defined(CONFIG_IPDDP)
+	extern int ipddp_init(struct net_device *dev);
+	static struct net_device dev_ipddp = {
+				"ipddp0"  __PAD6,
+				0, 0, 0, 0,
+				0x0, 0,
+				0, 0, 0, NULL, ipddp_init 
+	};
+	
+	dev_ipddp.init(&dev_ipddp);
+#endif /* CONFIG_IPDDP */
+}
+
+
+/*
+ *	The loopback device is global so it can be directly referenced
+ *	by the network code.
+ */
+ 
+extern int loopback_init(struct net_device *dev);
+struct net_device loopback_dev = 
+{
+	"lo" __PAD2,		/* Software Loopback interface		*/
+	0x0,			/* recv memory end			*/
+	0x0,			/* recv memory start			*/
+	0x0,			/* memory end				*/
+	0x0,			/* memory start				*/
+	0,			/* base I/O address			*/
+	0,			/* IRQ					*/
+	0, 0, 0,		/* flags				*/
+	NULL,			/* next device				*/
+	loopback_init		/* loopback_init should set up the rest	*/
+};
+
+static void special_device_init(void)
+{
+#ifdef CONFIG_DUMMY
+	{
+		extern int dummy_init(struct net_device *dev);
+		static struct net_device dummy_dev = {
+			"dummy" __PAD5, 0x0, 0x0, 0x0, 0x0, 0, 0, 0, 0, 0, NULL, dummy_init, 
+		};
+		register_netdev(&sb1000_dev);
+	}
+#endif	
+#ifdef CONFIG_EQUALIZER
+	{
+		extern int eql_init(struct net_device *dev);
+		static struct net_device eql_dev = 
+		{
+			"eql" __PAD3,			/* Master device for IP traffic load balancing */
+			0x0, 0x0, 0x0, 0x0,		/* recv end/start; mem end/start */
+			0,				/* base I/O address */
+			0,				/* IRQ */
+			0, 0, 0,			/* flags */
+			NULL,				/* next device */
+			eql_init			/* set up the rest */
+		};
+		register_netdev(&sb1000_dev);
+	}
+#endif	
+#ifdef CONFIG_APBIF
+	{
+		extern int bif_init(struct net_device *dev);
+		static struct net_device bif_dev = 
+		{
+        		"bif" __PAD3, 0x0, 0x0, 0x0, 0x0, 0, 0, 0, 0, 0, NULL, bif_init 
+        	};
+		register_netdev(&sb1000_dev);
+        }
+#endif
+#ifdef CONFIG_NET_SB1000
+	{
+		extern int sb1000_probe(struct net_device *dev);
+		static struct net_device sb1000_dev = 
+		{
+			"cm0", 0x0, 0x0, 0x0, 0x0, 0, 0, 0, 0, 0, NULL, sb1000_probe 
+		};
+		register_netdev(&sb1000_dev);
+	}
+#endif
+	register_netdev(&loopback_dev);
+}
+
+/*
+ *	Initialise network devices
+ */
+ 
+void __init net_device_init(void)
+{
+	/* Devices supporting the new probing API */
+	network_probe();
+	/* Line disciplines */
+	network_ldisc_init();
+	/* Appletalk */
+	appletalk_device_init();
+	/* Special devices */
+	special_device_init();
+	/* That kicks off the legacy init functions */
+}
+
+	 

FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)