189973f8aSBen Warren /* 289973f8aSBen Warren * (C) Copyright 2008 389973f8aSBen Warren * Benjamin Warren, biggerbadderben@gmail.com 489973f8aSBen Warren * 589973f8aSBen Warren * See file CREDITS for list of people who contributed to this 689973f8aSBen Warren * project. 789973f8aSBen Warren * 889973f8aSBen Warren * This program is free software; you can redistribute it and/or 989973f8aSBen Warren * modify it under the terms of the GNU General Public License as 1089973f8aSBen Warren * published by the Free Software Foundation; either version 2 of 1189973f8aSBen Warren * the License, or (at your option) any later version. 1289973f8aSBen Warren * 1389973f8aSBen Warren * This program is distributed in the hope that it will be useful, 1489973f8aSBen Warren * but WITHOUT ANY WARRANTY; without even the implied warranty of 1589973f8aSBen Warren * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 1689973f8aSBen Warren * GNU General Public License for more details. 1789973f8aSBen Warren * 1889973f8aSBen Warren * You should have received a copy of the GNU General Public License 1989973f8aSBen Warren * along with this program; if not, write to the Free Software 2089973f8aSBen Warren * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 2189973f8aSBen Warren * MA 02111-1307 USA 2289973f8aSBen Warren */ 2389973f8aSBen Warren 2489973f8aSBen Warren /* 2589973f8aSBen Warren * netdev.h - definitions an prototypes for network devices 2689973f8aSBen Warren */ 2789973f8aSBen Warren 2889973f8aSBen Warren #ifndef _NETDEV_H_ 2989973f8aSBen Warren #define _NETDEV_H_ 3089973f8aSBen Warren 3189973f8aSBen Warren /* 3289973f8aSBen Warren * Board and CPU-specific initialization functions 3389973f8aSBen Warren * board_eth_init() has highest priority. cpu_eth_init() only 3489973f8aSBen Warren * gets called if board_eth_init() isn't instantiated or fails. 3589973f8aSBen Warren * Return values: 3689973f8aSBen Warren * 0: success 3789973f8aSBen Warren * -1: failure 3889973f8aSBen Warren */ 3989973f8aSBen Warren 4089973f8aSBen Warren int board_eth_init(bd_t *bis); 4189973f8aSBen Warren int cpu_eth_init(bd_t *bis); 4289973f8aSBen Warren 4389973f8aSBen Warren /* Driver initialization prototypes */ 44c960b13eSThomas Chou int altera_tse_initialize(u8 dev_num, int mac_base, 45*b962ac79SJoachim Foerster int sgdma_rx_base, int sgdma_tx_base, 46*b962ac79SJoachim Foerster u32 sgdma_desc_base, u32 sgdma_desc_size); 47c041e9d2SJens Scharsig int at91emac_register(bd_t *bis, unsigned long iobase); 48bd6ce9d1SWolfgang Denk int au1x00_enet_initialize(bd_t*); 49bd6ce9d1SWolfgang Denk int ax88180_initialize(bd_t *bis); 5089973f8aSBen Warren int bfin_EMAC_initialize(bd_t *bis); 51b1c0eaacSBen Warren int cs8900_initialize(u8 dev_num, int base_addr); 528453587eSBen Warren int davinci_emac_initialize(void); 53bd6ce9d1SWolfgang Denk int dc21x4x_initialize(bd_t *bis); 545b1b1883SVipin KUMAR int designware_initialize(u32 id, ulong base_addr, u32 phy_addr); 55bd6ce9d1SWolfgang Denk int dm9000_initialize(bd_t *bis); 5662cbc408SIlya Yanok int dnet_eth_initialize(int id, void *regs, unsigned int phy_addr); 57ad3381cfSBen Warren int e1000_initialize(bd_t *bis); 5810efa024SBen Warren int eepro100_initialize(bd_t *bis); 59a61a8196SReinhard Meyer int enc28j60_initialize(unsigned int bus, unsigned int cs, 60a61a8196SReinhard Meyer unsigned int max_hz, unsigned int mode); 61594d57d0SMatthias Kaehlcke int ep93xx_eth_initialize(u8 dev_num, int base_addr); 62164846eeSBen Warren int eth_3com_initialize (bd_t * bis); 63bd6ce9d1SWolfgang Denk int ethoc_initialize(u8 dev_num, int base_addr); 643456a148SBen Warren int fec_initialize (bd_t *bis); 650b23fb36SIlya Yanok int fecmxc_initialize(bd_t *bis); 669e27e9dcSMarek Vasut int fecmxc_initialize_multi(bd_t *bis, int dev_id, int phy_id, uint32_t addr); 67b3dbf4a5SMacpaul Lin int ftgmac100_initialize(bd_t *bits); 68750326e5SPo-Yu Chuang int ftmac100_initialize(bd_t *bits); 6989973f8aSBen Warren int greth_initialize(bd_t *bis); 706aca145eSBen Warren void gt6426x_eth_initialize(bd_t *bis); 718218bd2aSBen Warren int inca_switch_initialize(bd_t *bis); 72bd6ce9d1SWolfgang Denk int ks8695_eth_initialize(void); 73b7ad4109SNishanth Menon int lan91c96_initialize(u8 dev_num, int base_addr); 7489973f8aSBen Warren int macb_eth_initialize(int id, void *regs, unsigned int phy_addr); 7589973f8aSBen Warren int mcdmafec_initialize(bd_t *bis); 7689973f8aSBen Warren int mcffec_initialize(bd_t *bis); 77a0aad08fSBen Warren int mpc512x_fec_initialize(bd_t *bis); 78e1d7480bSBen Warren int mpc5xxx_fec_initialize(bd_t *bis); 79a9bec96dSBen Warren int mpc8220_fec_initialize(bd_t *bis); 80ba705b5bSGary Jennejohn int mpc82xx_scc_enet_initialize(bd_t *bis); 81d44265adSAlbert Aribaud int mvgbe_initialize(bd_t *bis); 82b902b8ddSBen Warren int natsemi_initialize(bd_t *bis); 83cc94074eSBen Warren int npe_initialize(bd_t *bis); 8419403633SBen Warren int ns8382x_initialize(bd_t *bis); 85e3090534SBen Warren int pcnet_initialize(bd_t *bis); 864fce2aceSBen Warren int plb2800_eth_initialize(bd_t *bis); 8725a85906SBen Warren int ppc_4xx_eth_initialize (bd_t *bis); 880b252f50SBen Warren int rtl8139_initialize(bd_t *bis); 8902d69891SBen Warren int rtl8169_initialize(bd_t *bis); 909eb79bd8SBen Warren int scc_initialize(bd_t *bis); 91bd6ce9d1SWolfgang Denk int sh_eth_initialize(bd_t *bis); 9289973f8aSBen Warren int skge_initialize(bd_t *bis); 937194ab80SBen Warren int smc91111_initialize(u8 dev_num, int base_addr); 94bd6ce9d1SWolfgang Denk int smc911x_initialize(u8 dev_num, int base_addr); 95ccdd12f8SBen Warren int tsi108_eth_initialize(bd_t *bis); 962b5243fcSWolfgang Denk int uec_standard_init(bd_t *bis); 9789973f8aSBen Warren int uli526x_initialize(bd_t *bis); 9879788bb1SAjay Bhargav int armada100_fec_register(unsigned long base_addr); 994f1ec4c1SMichal Simek int xilinx_axiemac_initialize(bd_t *bis, unsigned long base_addr, 1004f1ec4c1SMichal Simek unsigned long dma_addr); 101c1044a1eSMichal Simek int xilinx_emaclite_initialize(bd_t *bis, unsigned long base_addr, 102c1044a1eSMichal Simek int txpp, int rxpp); 10389973f8aSBen Warren 10489973f8aSBen Warren /* Boards with PCI network controllers can call this from their board_eth_init() 10589973f8aSBen Warren * function to initialize whatever's on board. 10689973f8aSBen Warren * Return value is total # of devices found */ 10789973f8aSBen Warren 10889973f8aSBen Warren static inline int pci_eth_init(bd_t *bis) 10989973f8aSBen Warren { 11089973f8aSBen Warren int num = 0; 111e3090534SBen Warren 11210efa024SBen Warren #ifdef CONFIG_PCI 11310efa024SBen Warren 11410efa024SBen Warren #ifdef CONFIG_EEPRO100 11510efa024SBen Warren num += eepro100_initialize(bis); 11610efa024SBen Warren #endif 1178ca0b3f9SBen Warren #ifdef CONFIG_TULIP 1188ca0b3f9SBen Warren num += dc21x4x_initialize(bis); 1198ca0b3f9SBen Warren #endif 120ad3381cfSBen Warren #ifdef CONFIG_E1000 121ad3381cfSBen Warren num += e1000_initialize(bis); 122ad3381cfSBen Warren #endif 123e3090534SBen Warren #ifdef CONFIG_PCNET 124e3090534SBen Warren num += pcnet_initialize(bis); 125e3090534SBen Warren #endif 126b902b8ddSBen Warren #ifdef CONFIG_NATSEMI 127b902b8ddSBen Warren num += natsemi_initialize(bis); 128b902b8ddSBen Warren #endif 12919403633SBen Warren #ifdef CONFIG_NS8382X 13019403633SBen Warren num += ns8382x_initialize(bis); 13119403633SBen Warren #endif 1320b252f50SBen Warren #if defined(CONFIG_RTL8139) 1330b252f50SBen Warren num += rtl8139_initialize(bis); 1340b252f50SBen Warren #endif 13502d69891SBen Warren #if defined(CONFIG_RTL8169) 13602d69891SBen Warren num += rtl8169_initialize(bis); 13702d69891SBen Warren #endif 138b11f664fSTimur Tabi #if defined(CONFIG_ULI526X) 13989973f8aSBen Warren num += uli526x_initialize(bis); 14089973f8aSBen Warren #endif 14110efa024SBen Warren 14210efa024SBen Warren #endif /* CONFIG_PCI */ 14389973f8aSBen Warren return num; 14489973f8aSBen Warren } 14589973f8aSBen Warren 1466f51deb7SPrafulla Wadaskar /* 1476f51deb7SPrafulla Wadaskar * Boards with mv88e61xx switch can use this by defining 1486f51deb7SPrafulla Wadaskar * CONFIG_MV88E61XX_SWITCH in respective board configheader file 1496f51deb7SPrafulla Wadaskar * the stuct and enums here are used to specify switch configuration params 1506f51deb7SPrafulla Wadaskar */ 1516f51deb7SPrafulla Wadaskar #if defined(CONFIG_MV88E61XX_SWITCH) 1526f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_vlan { 1536f51deb7SPrafulla Wadaskar MV88E61XX_VLANCFG_DEFAULT, 1546f51deb7SPrafulla Wadaskar MV88E61XX_VLANCFG_ROUTER 1556f51deb7SPrafulla Wadaskar }; 1566f51deb7SPrafulla Wadaskar 1576f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_mdip { 1586f51deb7SPrafulla Wadaskar MV88E61XX_MDIP_NOCHANGE, 1596f51deb7SPrafulla Wadaskar MV88E61XX_MDIP_REVERSE 1606f51deb7SPrafulla Wadaskar }; 1616f51deb7SPrafulla Wadaskar 1626f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_ledinit { 1636f51deb7SPrafulla Wadaskar MV88E61XX_LED_INIT_DIS, 1646f51deb7SPrafulla Wadaskar MV88E61XX_LED_INIT_EN 1656f51deb7SPrafulla Wadaskar }; 1666f51deb7SPrafulla Wadaskar 1676f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_rgmiid { 1686f51deb7SPrafulla Wadaskar MV88E61XX_RGMII_DELAY_DIS, 1696f51deb7SPrafulla Wadaskar MV88E61XX_RGMII_DELAY_EN 1706f51deb7SPrafulla Wadaskar }; 1716f51deb7SPrafulla Wadaskar 1726f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_prtstt { 1736f51deb7SPrafulla Wadaskar MV88E61XX_PORTSTT_DISABLED, 1746f51deb7SPrafulla Wadaskar MV88E61XX_PORTSTT_BLOCKING, 1756f51deb7SPrafulla Wadaskar MV88E61XX_PORTSTT_LEARNING, 1766f51deb7SPrafulla Wadaskar MV88E61XX_PORTSTT_FORWARDING 1776f51deb7SPrafulla Wadaskar }; 1786f51deb7SPrafulla Wadaskar 1796f51deb7SPrafulla Wadaskar struct mv88e61xx_config { 1806f51deb7SPrafulla Wadaskar char *name; 1816f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_vlan vlancfg; 1826f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_rgmiid rgmii_delay; 1836f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_prtstt portstate; 1846f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_ledinit led_init; 1856f51deb7SPrafulla Wadaskar enum mv88e61xx_cfg_mdip mdip; 1866f51deb7SPrafulla Wadaskar u32 ports_enabled; 1876f51deb7SPrafulla Wadaskar u8 cpuport; 1886f51deb7SPrafulla Wadaskar }; 1896f51deb7SPrafulla Wadaskar 1906f51deb7SPrafulla Wadaskar int mv88e61xx_switch_initialize(struct mv88e61xx_config *swconfig); 1916f51deb7SPrafulla Wadaskar #endif /* CONFIG_MV88E61XX_SWITCH */ 1926f51deb7SPrafulla Wadaskar 1932e5f4421SMarek Vasut /* 1942e5f4421SMarek Vasut * Allow FEC to fine-tune MII configuration on boards which require this. 1952e5f4421SMarek Vasut */ 1962e5f4421SMarek Vasut int fecmxc_register_mii_postcall(struct eth_device *dev, int (*cb)(int)); 1972e5f4421SMarek Vasut 19889973f8aSBen Warren #endif /* _NETDEV_H_ */ 199