Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 1 | /* |
| 2 | * (C) Copyright 2008 |
| 3 | * Benjamin Warren, biggerbadderben@gmail.com |
| 4 | * |
| 5 | * See file CREDITS for list of people who contributed to this |
| 6 | * project. |
| 7 | * |
| 8 | * This program is free software; you can redistribute it and/or |
| 9 | * modify it under the terms of the GNU General Public License as |
| 10 | * published by the Free Software Foundation; either version 2 of |
| 11 | * the License, or (at your option) any later version. |
| 12 | * |
| 13 | * This program is distributed in the hope that it will be useful, |
| 14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
Jerry Van Baren | ae0b05d | 2009-02-05 22:18:02 -0500 | [diff] [blame] | 15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 16 | * GNU General Public License for more details. |
| 17 | * |
| 18 | * You should have received a copy of the GNU General Public License |
| 19 | * along with this program; if not, write to the Free Software |
| 20 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, |
| 21 | * MA 02111-1307 USA |
| 22 | */ |
| 23 | |
| 24 | /* |
| 25 | * netdev.h - definitions an prototypes for network devices |
| 26 | */ |
| 27 | |
| 28 | #ifndef _NETDEV_H_ |
| 29 | #define _NETDEV_H_ |
| 30 | |
| 31 | /* |
| 32 | * Board and CPU-specific initialization functions |
| 33 | * board_eth_init() has highest priority. cpu_eth_init() only |
| 34 | * gets called if board_eth_init() isn't instantiated or fails. |
| 35 | * Return values: |
| 36 | * 0: success |
| 37 | * -1: failure |
| 38 | */ |
| 39 | |
| 40 | int board_eth_init(bd_t *bis); |
| 41 | int cpu_eth_init(bd_t *bis); |
| 42 | |
| 43 | /* Driver initialization prototypes */ |
Thomas Chou | c960b13 | 2010-04-20 12:49:52 +0800 | [diff] [blame] | 44 | int altera_tse_initialize(u8 dev_num, int mac_base, |
Joachim Foerster | b962ac7 | 2011-10-17 05:24:44 +0000 | [diff] [blame] | 45 | int sgdma_rx_base, int sgdma_tx_base, |
| 46 | u32 sgdma_desc_base, u32 sgdma_desc_size); |
Jens Scharsig | c041e9d | 2010-01-23 12:03:45 +0100 | [diff] [blame] | 47 | int at91emac_register(bd_t *bis, unsigned long iobase); |
Wolfgang Denk | bd6ce9d | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 48 | int au1x00_enet_initialize(bd_t*); |
| 49 | int ax88180_initialize(bd_t *bis); |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 50 | int bfin_EMAC_initialize(bd_t *bis); |
Rob Herring | efdd731 | 2011-12-15 11:15:49 +0000 | [diff] [blame] | 51 | int calxedaxgmac_initialize(u32 id, ulong base_addr); |
Ben Warren | b1c0eaa | 2009-08-25 13:09:37 -0700 | [diff] [blame] | 52 | int cs8900_initialize(u8 dev_num, int base_addr); |
Ben Warren | 8453587 | 2009-05-26 00:34:07 -0700 | [diff] [blame] | 53 | int davinci_emac_initialize(void); |
Wolfgang Denk | bd6ce9d | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 54 | int dc21x4x_initialize(bd_t *bis); |
Vipin Kumar | 9afc1af | 2012-05-07 13:06:44 +0530 | [diff] [blame] | 55 | int designware_initialize(u32 id, ulong base_addr, u32 phy_addr, u32 interface); |
Wolfgang Denk | bd6ce9d | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 56 | int dm9000_initialize(bd_t *bis); |
Ilya Yanok | 62cbc40 | 2009-02-09 18:45:28 +0100 | [diff] [blame] | 57 | int dnet_eth_initialize(int id, void *regs, unsigned int phy_addr); |
Ben Warren | ad3381c | 2008-08-31 10:44:19 -0700 | [diff] [blame] | 58 | int e1000_initialize(bd_t *bis); |
Ben Warren | 10efa02 | 2008-08-31 20:37:00 -0700 | [diff] [blame] | 59 | int eepro100_initialize(bd_t *bis); |
Reinhard Meyer | a61a819 | 2010-09-12 16:23:49 +0200 | [diff] [blame] | 60 | int enc28j60_initialize(unsigned int bus, unsigned int cs, |
| 61 | unsigned int max_hz, unsigned int mode); |
Matthias Kaehlcke | 594d57d | 2010-01-31 17:39:49 +0100 | [diff] [blame] | 62 | int ep93xx_eth_initialize(u8 dev_num, int base_addr); |
Ben Warren | 164846e | 2008-08-31 10:15:26 -0700 | [diff] [blame] | 63 | int eth_3com_initialize (bd_t * bis); |
Wolfgang Denk | bd6ce9d | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 64 | int ethoc_initialize(u8 dev_num, int base_addr); |
Ben Warren | 3456a14 | 2008-10-22 23:20:29 -0700 | [diff] [blame] | 65 | int fec_initialize (bd_t *bis); |
Wolfgang Denk | bd6ce9d | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 66 | int fecmxc_initialize(bd_t *bis); |
Marek Vasut | 9e27e9d | 2011-09-16 01:13:47 +0200 | [diff] [blame] | 67 | int fecmxc_initialize_multi(bd_t *bis, int dev_id, int phy_id, uint32_t addr); |
Macpaul Lin | b3dbf4a5 | 2010-12-21 16:59:46 +0800 | [diff] [blame] | 68 | int ftgmac100_initialize(bd_t *bits); |
Po-Yu Chuang | 750326e | 2009-08-10 11:00:00 +0800 | [diff] [blame] | 69 | int ftmac100_initialize(bd_t *bits); |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 70 | int greth_initialize(bd_t *bis); |
Ben Warren | 6aca145 | 2008-08-31 10:13:34 -0700 | [diff] [blame] | 71 | void gt6426x_eth_initialize(bd_t *bis); |
Ben Warren | 8218bd2 | 2008-08-31 10:16:59 -0700 | [diff] [blame] | 72 | int inca_switch_initialize(bd_t *bis); |
Wolfgang Denk | bd6ce9d | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 73 | int ks8695_eth_initialize(void); |
Nishanth Menon | b7ad410 | 2009-10-16 00:06:35 -0500 | [diff] [blame] | 74 | int lan91c96_initialize(u8 dev_num, int base_addr); |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 75 | int macb_eth_initialize(int id, void *regs, unsigned int phy_addr); |
| 76 | int mcdmafec_initialize(bd_t *bis); |
| 77 | int mcffec_initialize(bd_t *bis); |
Ben Warren | a0aad08 | 2008-08-31 10:36:38 -0700 | [diff] [blame] | 78 | int mpc512x_fec_initialize(bd_t *bis); |
Ben Warren | e1d7480 | 2008-08-31 10:39:12 -0700 | [diff] [blame] | 79 | int mpc5xxx_fec_initialize(bd_t *bis); |
Gary Jennejohn | ba705b5 | 2008-11-20 12:28:38 +0100 | [diff] [blame] | 80 | int mpc82xx_scc_enet_initialize(bd_t *bis); |
Albert Aribaud | d44265a | 2010-07-12 22:24:28 +0200 | [diff] [blame] | 81 | int mvgbe_initialize(bd_t *bis); |
Ben Warren | b902b8d | 2008-08-31 10:07:16 -0700 | [diff] [blame] | 82 | int natsemi_initialize(bd_t *bis); |
Bernhard Kaindl | d020169 | 2011-10-20 10:56:59 +0000 | [diff] [blame] | 83 | int ne2k_register(void); |
Ben Warren | cc94074 | 2008-09-05 01:55:22 -0400 | [diff] [blame] | 84 | int npe_initialize(bd_t *bis); |
Ben Warren | 1940363 | 2008-08-31 10:03:22 -0700 | [diff] [blame] | 85 | int ns8382x_initialize(bd_t *bis); |
Ben Warren | e309053 | 2008-08-31 10:08:43 -0700 | [diff] [blame] | 86 | int pcnet_initialize(bd_t *bis); |
Ben Warren | 4fce2ac | 2008-08-31 10:40:51 -0700 | [diff] [blame] | 87 | int plb2800_eth_initialize(bd_t *bis); |
Ben Warren | 25a8590 | 2008-10-27 23:53:17 -0700 | [diff] [blame] | 88 | int ppc_4xx_eth_initialize (bd_t *bis); |
Ben Warren | 0b252f5 | 2008-08-31 21:41:08 -0700 | [diff] [blame] | 89 | int rtl8139_initialize(bd_t *bis); |
Ben Warren | 02d6989 | 2008-08-31 09:49:42 -0700 | [diff] [blame] | 90 | int rtl8169_initialize(bd_t *bis); |
Ben Warren | 9eb79bd | 2008-10-23 22:02:49 -0700 | [diff] [blame] | 91 | int scc_initialize(bd_t *bis); |
Wolfgang Denk | bd6ce9d | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 92 | int sh_eth_initialize(bd_t *bis); |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 93 | int skge_initialize(bd_t *bis); |
Ben Warren | 7194ab8 | 2009-10-04 22:37:03 -0700 | [diff] [blame] | 94 | int smc91111_initialize(u8 dev_num, int base_addr); |
Wolfgang Denk | bd6ce9d | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 95 | int smc911x_initialize(u8 dev_num, int base_addr); |
Henrik Nordström | 518ce47 | 2012-11-25 12:41:36 +0100 | [diff] [blame] | 96 | int sunxi_wemac_initialize(bd_t *bis); |
Ben Warren | ccdd12f | 2008-08-31 09:59:33 -0700 | [diff] [blame] | 97 | int tsi108_eth_initialize(bd_t *bis); |
Wolfgang Denk | 2b5243f | 2009-07-18 16:13:18 +0200 | [diff] [blame] | 98 | int uec_standard_init(bd_t *bis); |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 99 | int uli526x_initialize(bd_t *bis); |
Ajay Bhargav | 79788bb | 2011-09-13 22:21:58 +0530 | [diff] [blame] | 100 | int armada100_fec_register(unsigned long base_addr); |
Michal Simek | 4f1ec4c | 2011-10-06 20:35:35 +0000 | [diff] [blame] | 101 | int xilinx_axiemac_initialize(bd_t *bis, unsigned long base_addr, |
| 102 | unsigned long dma_addr); |
Michal Simek | c1044a1 | 2011-10-12 23:23:22 +0000 | [diff] [blame] | 103 | int xilinx_emaclite_initialize(bd_t *bis, unsigned long base_addr, |
| 104 | int txpp, int rxpp); |
Stephan Linz | df48265 | 2012-02-25 00:48:31 +0000 | [diff] [blame] | 105 | int xilinx_ll_temac_eth_init(bd_t *bis, unsigned long base_addr, int flags, |
| 106 | unsigned long ctrl_addr); |
David Andrey | 01fbf31 | 2013-04-05 17:24:24 +0200 | [diff] [blame] | 107 | int zynq_gem_initialize(bd_t *bis, int base_addr, int phy_addr, u32 emio); |
Stephan Linz | df48265 | 2012-02-25 00:48:31 +0000 | [diff] [blame] | 108 | /* |
| 109 | * As long as the Xilinx xps_ll_temac ethernet driver has not its own interface |
| 110 | * exported by a public hader file, we need a global definition at this point. |
| 111 | */ |
| 112 | #if defined(CONFIG_XILINX_LL_TEMAC) |
| 113 | #define XILINX_LL_TEMAC_M_FIFO 0 /* use FIFO Ctrl */ |
| 114 | #define XILINX_LL_TEMAC_M_SDMA_PLB (1 << 0)/* use SDMA Ctrl via PLB */ |
| 115 | #define XILINX_LL_TEMAC_M_SDMA_DCR (1 << 1)/* use SDMA Ctrl via DCR */ |
| 116 | #endif |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 117 | |
| 118 | /* Boards with PCI network controllers can call this from their board_eth_init() |
| 119 | * function to initialize whatever's on board. |
| 120 | * Return value is total # of devices found */ |
| 121 | |
| 122 | static inline int pci_eth_init(bd_t *bis) |
| 123 | { |
| 124 | int num = 0; |
Ben Warren | e309053 | 2008-08-31 10:08:43 -0700 | [diff] [blame] | 125 | |
Ben Warren | 10efa02 | 2008-08-31 20:37:00 -0700 | [diff] [blame] | 126 | #ifdef CONFIG_PCI |
| 127 | |
| 128 | #ifdef CONFIG_EEPRO100 |
| 129 | num += eepro100_initialize(bis); |
| 130 | #endif |
Ben Warren | 8ca0b3f | 2008-08-31 10:45:44 -0700 | [diff] [blame] | 131 | #ifdef CONFIG_TULIP |
| 132 | num += dc21x4x_initialize(bis); |
| 133 | #endif |
Ben Warren | ad3381c | 2008-08-31 10:44:19 -0700 | [diff] [blame] | 134 | #ifdef CONFIG_E1000 |
| 135 | num += e1000_initialize(bis); |
| 136 | #endif |
Ben Warren | e309053 | 2008-08-31 10:08:43 -0700 | [diff] [blame] | 137 | #ifdef CONFIG_PCNET |
| 138 | num += pcnet_initialize(bis); |
| 139 | #endif |
Ben Warren | b902b8d | 2008-08-31 10:07:16 -0700 | [diff] [blame] | 140 | #ifdef CONFIG_NATSEMI |
| 141 | num += natsemi_initialize(bis); |
| 142 | #endif |
Ben Warren | 1940363 | 2008-08-31 10:03:22 -0700 | [diff] [blame] | 143 | #ifdef CONFIG_NS8382X |
| 144 | num += ns8382x_initialize(bis); |
| 145 | #endif |
Ben Warren | 0b252f5 | 2008-08-31 21:41:08 -0700 | [diff] [blame] | 146 | #if defined(CONFIG_RTL8139) |
| 147 | num += rtl8139_initialize(bis); |
| 148 | #endif |
Ben Warren | 02d6989 | 2008-08-31 09:49:42 -0700 | [diff] [blame] | 149 | #if defined(CONFIG_RTL8169) |
| 150 | num += rtl8169_initialize(bis); |
| 151 | #endif |
Timur Tabi | b11f664 | 2009-04-09 10:27:05 -0500 | [diff] [blame] | 152 | #if defined(CONFIG_ULI526X) |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 153 | num += uli526x_initialize(bis); |
| 154 | #endif |
Ben Warren | 10efa02 | 2008-08-31 20:37:00 -0700 | [diff] [blame] | 155 | |
| 156 | #endif /* CONFIG_PCI */ |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 157 | return num; |
| 158 | } |
| 159 | |
Prafulla Wadaskar | 6f51deb | 2009-05-19 01:40:16 +0530 | [diff] [blame] | 160 | /* |
| 161 | * Boards with mv88e61xx switch can use this by defining |
| 162 | * CONFIG_MV88E61XX_SWITCH in respective board configheader file |
| 163 | * the stuct and enums here are used to specify switch configuration params |
| 164 | */ |
| 165 | #if defined(CONFIG_MV88E61XX_SWITCH) |
Albert ARIBAUD | 0a16ea5 | 2012-11-26 11:27:35 +0000 | [diff] [blame] | 166 | |
| 167 | /* constants for any 88E61xx switch */ |
| 168 | #define MV88E61XX_MAX_PORTS_NUM 6 |
Prafulla Wadaskar | 6f51deb | 2009-05-19 01:40:16 +0530 | [diff] [blame] | 169 | |
| 170 | enum mv88e61xx_cfg_mdip { |
| 171 | MV88E61XX_MDIP_NOCHANGE, |
| 172 | MV88E61XX_MDIP_REVERSE |
| 173 | }; |
| 174 | |
| 175 | enum mv88e61xx_cfg_ledinit { |
| 176 | MV88E61XX_LED_INIT_DIS, |
| 177 | MV88E61XX_LED_INIT_EN |
| 178 | }; |
| 179 | |
| 180 | enum mv88e61xx_cfg_rgmiid { |
| 181 | MV88E61XX_RGMII_DELAY_DIS, |
| 182 | MV88E61XX_RGMII_DELAY_EN |
| 183 | }; |
| 184 | |
| 185 | enum mv88e61xx_cfg_prtstt { |
| 186 | MV88E61XX_PORTSTT_DISABLED, |
| 187 | MV88E61XX_PORTSTT_BLOCKING, |
| 188 | MV88E61XX_PORTSTT_LEARNING, |
| 189 | MV88E61XX_PORTSTT_FORWARDING |
| 190 | }; |
| 191 | |
| 192 | struct mv88e61xx_config { |
| 193 | char *name; |
Albert ARIBAUD | 0a16ea5 | 2012-11-26 11:27:35 +0000 | [diff] [blame] | 194 | u8 vlancfg[MV88E61XX_MAX_PORTS_NUM]; |
Prafulla Wadaskar | 6f51deb | 2009-05-19 01:40:16 +0530 | [diff] [blame] | 195 | enum mv88e61xx_cfg_rgmiid rgmii_delay; |
| 196 | enum mv88e61xx_cfg_prtstt portstate; |
| 197 | enum mv88e61xx_cfg_ledinit led_init; |
| 198 | enum mv88e61xx_cfg_mdip mdip; |
| 199 | u32 ports_enabled; |
| 200 | u8 cpuport; |
| 201 | }; |
| 202 | |
Albert ARIBAUD | 0a16ea5 | 2012-11-26 11:27:35 +0000 | [diff] [blame] | 203 | /* |
| 204 | * Common mappings for Internal VLANs |
| 205 | * These mappings consider that all ports are useable; the driver |
| 206 | * will mask inexistent/unused ports. |
| 207 | */ |
| 208 | |
| 209 | /* Switch mode : routes any port to any port */ |
| 210 | #define MV88E61XX_VLANCFG_SWITCH { 0x3F, 0x3F, 0x3F, 0x3F, 0x3F, 0x3F } |
| 211 | |
| 212 | /* Router mode: routes only CPU port 5 to/from non-CPU ports 0-4 */ |
| 213 | #define MV88E61XX_VLANCFG_ROUTER { 0x20, 0x20, 0x20, 0x20, 0x20, 0x1F } |
| 214 | |
Prafulla Wadaskar | 6f51deb | 2009-05-19 01:40:16 +0530 | [diff] [blame] | 215 | int mv88e61xx_switch_initialize(struct mv88e61xx_config *swconfig); |
| 216 | #endif /* CONFIG_MV88E61XX_SWITCH */ |
| 217 | |
Troy Kisky | fe428b9 | 2012-10-22 16:40:46 +0000 | [diff] [blame] | 218 | struct mii_dev *fec_get_miibus(uint32_t base_addr, int dev_id); |
| 219 | #ifdef CONFIG_PHYLIB |
| 220 | struct phy_device; |
| 221 | int fec_probe(bd_t *bd, int dev_id, uint32_t base_addr, |
| 222 | struct mii_dev *bus, struct phy_device *phydev); |
| 223 | #else |
Marek Vasut | 2e5f442 | 2011-09-11 18:05:36 +0000 | [diff] [blame] | 224 | /* |
| 225 | * Allow FEC to fine-tune MII configuration on boards which require this. |
| 226 | */ |
| 227 | int fecmxc_register_mii_postcall(struct eth_device *dev, int (*cb)(int)); |
Troy Kisky | fe428b9 | 2012-10-22 16:40:46 +0000 | [diff] [blame] | 228 | #endif |
Marek Vasut | 2e5f442 | 2011-09-11 18:05:36 +0000 | [diff] [blame] | 229 | |
Ben Warren | 89973f8 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 230 | #endif /* _NETDEV_H_ */ |