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
- Lines: 372
- Date:
Wed Nov 10 19:55:55 1999
- Orig file:
v2.3.26/linux/drivers/net/setup.c
- Orig date:
Wed Dec 31 16:00:00 1969
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)