189973f8aSBen Warren /* 289973f8aSBen Warren * (C) Copyright 2008 389973f8aSBen Warren * Benjamin Warren, biggerbadderben@gmail.com 489973f8aSBen Warren * 51a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 689973f8aSBen Warren */ 789973f8aSBen Warren 889973f8aSBen Warren /* 989973f8aSBen Warren * netdev.h - definitions an prototypes for network devices 1089973f8aSBen Warren */ 1189973f8aSBen Warren 1289973f8aSBen Warren #ifndef _NETDEV_H_ 1389973f8aSBen Warren #define _NETDEV_H_ 1489973f8aSBen Warren 1589973f8aSBen Warren /* 1689973f8aSBen Warren * Board and CPU-specific initialization functions 1789973f8aSBen Warren * board_eth_init() has highest priority. cpu_eth_init() only 1889973f8aSBen Warren * gets called if board_eth_init() isn't instantiated or fails. 1989973f8aSBen Warren * Return values: 2089973f8aSBen Warren * 0: success 2189973f8aSBen Warren * -1: failure 2289973f8aSBen Warren */ 2389973f8aSBen Warren 2489973f8aSBen Warren int board_eth_init(bd_t *bis); 2589973f8aSBen Warren int cpu_eth_init(bd_t *bis); 2689973f8aSBen Warren 2789973f8aSBen Warren /* Driver initialization prototypes */ 28c041e9d2SJens Scharsig int at91emac_register(bd_t *bis, unsigned long iobase); 29bd6ce9d1SWolfgang Denk int au1x00_enet_initialize(bd_t*); 30bd6ce9d1SWolfgang Denk int ax88180_initialize(bd_t *bis); 31799e125cSJiandong Zheng int bcm_sf2_eth_register(bd_t *bis, u8 dev_num); 3289973f8aSBen Warren int bfin_EMAC_initialize(bd_t *bis); 33efdd7319SRob Herring int calxedaxgmac_initialize(u32 id, ulong base_addr); 34b1c0eaacSBen Warren int cs8900_initialize(u8 dev_num, int base_addr); 358453587eSBen Warren int davinci_emac_initialize(void); 36bd6ce9d1SWolfgang Denk int dc21x4x_initialize(bd_t *bis); 3792a190aaSAlexey Brodkin int designware_initialize(ulong base_addr, u32 interface); 38bd6ce9d1SWolfgang Denk int dm9000_initialize(bd_t *bis); 3962cbc408SIlya Yanok int dnet_eth_initialize(int id, void *regs, unsigned int phy_addr); 40ad3381cfSBen Warren int e1000_initialize(bd_t *bis); 4110efa024SBen Warren int eepro100_initialize(bd_t *bis); 42a61a8196SReinhard Meyer int enc28j60_initialize(unsigned int bus, unsigned int cs, 43a61a8196SReinhard Meyer unsigned int max_hz, unsigned int mode); 44594d57d0SMatthias Kaehlcke int ep93xx_eth_initialize(u8 dev_num, int base_addr); 45164846eeSBen Warren int eth_3com_initialize (bd_t * bis); 46bd6ce9d1SWolfgang Denk int ethoc_initialize(u8 dev_num, int base_addr); 473456a148SBen Warren int fec_initialize (bd_t *bis); 480b23fb36SIlya Yanok int fecmxc_initialize(bd_t *bis); 499e27e9dcSMarek Vasut int fecmxc_initialize_multi(bd_t *bis, int dev_id, int phy_id, uint32_t addr); 50b3dbf4a5SMacpaul Lin int ftgmac100_initialize(bd_t *bits); 51750326e5SPo-Yu Chuang int ftmac100_initialize(bd_t *bits); 52c4775476SKuo-Jung Su int ftmac110_initialize(bd_t *bits); 536aca145eSBen Warren void gt6426x_eth_initialize(bd_t *bis); 5445a1693aSRoberto Cerati int ks8851_mll_initialize(u8 dev_num, int base_addr); 55b7ad4109SNishanth Menon int lan91c96_initialize(u8 dev_num, int base_addr); 56ac2916a2SAlbert ARIBAUD \(3ADEV\) int lpc32xx_eth_initialize(bd_t *bis); 5789973f8aSBen Warren int macb_eth_initialize(int id, void *regs, unsigned int phy_addr); 5889973f8aSBen Warren int mcdmafec_initialize(bd_t *bis); 5989973f8aSBen Warren int mcffec_initialize(bd_t *bis); 60d44265adSAlbert Aribaud int mvgbe_initialize(bd_t *bis); 6119fc2eaeSStefan Roese int mvneta_initialize(bd_t *bis, int base_addr, int devnum, int phy_addr); 62b902b8ddSBen Warren int natsemi_initialize(bd_t *bis); 63d0201692SBernhard Kaindl int ne2k_register(void); 64cc94074eSBen Warren int npe_initialize(bd_t *bis); 6519403633SBen Warren int ns8382x_initialize(bd_t *bis); 66e3090534SBen Warren int pcnet_initialize(bd_t *bis); 6725a85906SBen Warren int ppc_4xx_eth_initialize (bd_t *bis); 680b252f50SBen Warren int rtl8139_initialize(bd_t *bis); 6902d69891SBen Warren int rtl8169_initialize(bd_t *bis); 709eb79bd8SBen Warren int scc_initialize(bd_t *bis); 71bd6ce9d1SWolfgang Denk int sh_eth_initialize(bd_t *bis); 7289973f8aSBen Warren int skge_initialize(bd_t *bis); 737194ab80SBen Warren int smc91111_initialize(u8 dev_num, int base_addr); 74bd6ce9d1SWolfgang Denk int smc911x_initialize(u8 dev_num, int base_addr); 75ccdd12f8SBen Warren int tsi108_eth_initialize(bd_t *bis); 762b5243fcSWolfgang Denk int uec_standard_init(bd_t *bis); 7789973f8aSBen Warren int uli526x_initialize(bd_t *bis); 7879788bb1SAjay Bhargav int armada100_fec_register(unsigned long base_addr); 79df482650SStephan Linz int xilinx_ll_temac_eth_init(bd_t *bis, unsigned long base_addr, int flags, 80df482650SStephan Linz unsigned long ctrl_addr); 81df482650SStephan Linz /* 82df482650SStephan Linz * As long as the Xilinx xps_ll_temac ethernet driver has not its own interface 83df482650SStephan Linz * exported by a public hader file, we need a global definition at this point. 84df482650SStephan Linz */ 85df482650SStephan Linz #if defined(CONFIG_XILINX_LL_TEMAC) 86df482650SStephan Linz #define XILINX_LL_TEMAC_M_FIFO 0 /* use FIFO Ctrl */ 87df482650SStephan Linz #define XILINX_LL_TEMAC_M_SDMA_PLB (1 << 0)/* use SDMA Ctrl via PLB */ 88df482650SStephan Linz #define XILINX_LL_TEMAC_M_SDMA_DCR (1 << 1)/* use SDMA Ctrl via DCR */ 89df482650SStephan Linz #endif 9089973f8aSBen Warren 9189973f8aSBen Warren /* Boards with PCI network controllers can call this from their board_eth_init() 9289973f8aSBen Warren * function to initialize whatever's on board. 9389973f8aSBen Warren * Return value is total # of devices found */ 9489973f8aSBen Warren 9589973f8aSBen Warren static inline int pci_eth_init(bd_t *bis) 9689973f8aSBen Warren { 9789973f8aSBen Warren int num = 0; 98e3090534SBen Warren 9910efa024SBen Warren #ifdef CONFIG_PCI 10010efa024SBen Warren 10110efa024SBen Warren #ifdef CONFIG_EEPRO100 10210efa024SBen Warren num += eepro100_initialize(bis); 10310efa024SBen Warren #endif 1048ca0b3f9SBen Warren #ifdef CONFIG_TULIP 1058ca0b3f9SBen Warren num += dc21x4x_initialize(bis); 1068ca0b3f9SBen Warren #endif 107ad3381cfSBen Warren #ifdef CONFIG_E1000 108ad3381cfSBen Warren num += e1000_initialize(bis); 109ad3381cfSBen Warren #endif 110e3090534SBen Warren #ifdef CONFIG_PCNET 111e3090534SBen Warren num += pcnet_initialize(bis); 112e3090534SBen Warren #endif 113b902b8ddSBen Warren #ifdef CONFIG_NATSEMI 114b902b8ddSBen Warren num += natsemi_initialize(bis); 115b902b8ddSBen Warren #endif 11619403633SBen Warren #ifdef CONFIG_NS8382X 11719403633SBen Warren num += ns8382x_initialize(bis); 11819403633SBen Warren #endif 1190b252f50SBen Warren #if defined(CONFIG_RTL8139) 1200b252f50SBen Warren num += rtl8139_initialize(bis); 1210b252f50SBen Warren #endif 12202d69891SBen Warren #if defined(CONFIG_RTL8169) 12302d69891SBen Warren num += rtl8169_initialize(bis); 12402d69891SBen Warren #endif 125b11f664fSTimur Tabi #if defined(CONFIG_ULI526X) 12689973f8aSBen Warren num += uli526x_initialize(bis); 12789973f8aSBen Warren #endif 12810efa024SBen Warren 12910efa024SBen Warren #endif /* CONFIG_PCI */ 13089973f8aSBen Warren return num; 13189973f8aSBen Warren } 13289973f8aSBen Warren 133*cb5761f7SLothar Waßmann #ifdef CONFIG_DM_ETH 134*cb5761f7SLothar Waßmann struct mii_dev *fec_get_miibus(struct udevice *dev, int dev_id); 135*cb5761f7SLothar Waßmann #else 136fe428b90STroy Kisky struct mii_dev *fec_get_miibus(uint32_t base_addr, int dev_id); 137*cb5761f7SLothar Waßmann #endif 138*cb5761f7SLothar Waßmann 139fe428b90STroy Kisky #ifdef CONFIG_PHYLIB 140fe428b90STroy Kisky struct phy_device; 141fe428b90STroy Kisky int fec_probe(bd_t *bd, int dev_id, uint32_t base_addr, 142fe428b90STroy Kisky struct mii_dev *bus, struct phy_device *phydev); 143fe428b90STroy Kisky #else 1442e5f4421SMarek Vasut /* 1452e5f4421SMarek Vasut * Allow FEC to fine-tune MII configuration on boards which require this. 1462e5f4421SMarek Vasut */ 1472e5f4421SMarek Vasut int fecmxc_register_mii_postcall(struct eth_device *dev, int (*cb)(int)); 148fe428b90STroy Kisky #endif 1492e5f4421SMarek Vasut 15089973f8aSBen Warren #endif /* _NETDEV_H_ */ 151