Ben Warren | 2f2b6b6 | 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 | 5afb2fe | 2009-02-05 22:18:02 -0500 | [diff] [blame] | 15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
Ben Warren | 2f2b6b6 | 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 | 7bb1b9b | 2010-04-20 12:49:52 +0800 | [diff] [blame] | 44 | int altera_tse_initialize(u8 dev_num, int mac_base, |
Joachim Foerster | cb0ddaf | 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 | dab7cb8 | 2010-01-23 12:03:45 +0100 | [diff] [blame] | 47 | int at91emac_register(bd_t *bis, unsigned long iobase); |
Wolfgang Denk | de02ce9 | 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 | 2f2b6b6 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 50 | int bfin_EMAC_initialize(bd_t *bis); |
Rob Herring | c9830dc | 2011-12-15 11:15:49 +0000 | [diff] [blame] | 51 | int calxedaxgmac_initialize(u32 id, ulong base_addr); |
Ben Warren | 3bf5d83 | 2009-08-25 13:09:37 -0700 | [diff] [blame] | 52 | int cs8900_initialize(u8 dev_num, int base_addr); |
Ben Warren | 5301bbf | 2009-05-26 00:34:07 -0700 | [diff] [blame] | 53 | int davinci_emac_initialize(void); |
Wolfgang Denk | de02ce9 | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 54 | int dc21x4x_initialize(bd_t *bis); |
Vipin Kumar | 7443d60 | 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 | de02ce9 | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 56 | int dm9000_initialize(bd_t *bis); |
Ilya Yanok | 9ba9909 | 2009-02-09 18:45:28 +0100 | [diff] [blame] | 57 | int dnet_eth_initialize(int id, void *regs, unsigned int phy_addr); |
Ben Warren | 050019d | 2008-08-31 10:44:19 -0700 | [diff] [blame] | 58 | int e1000_initialize(bd_t *bis); |
Ben Warren | 052a5ea | 2008-08-31 20:37:00 -0700 | [diff] [blame] | 59 | int eepro100_initialize(bd_t *bis); |
Reinhard Meyer | 3a3a48f | 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 | 3b8d1a4 | 2010-01-31 17:39:49 +0100 | [diff] [blame] | 62 | int ep93xx_eth_initialize(u8 dev_num, int base_addr); |
Ben Warren | 5496501 | 2008-08-31 10:15:26 -0700 | [diff] [blame] | 63 | int eth_3com_initialize (bd_t * bis); |
Wolfgang Denk | de02ce9 | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 64 | int ethoc_initialize(u8 dev_num, int base_addr); |
Ben Warren | 70618a3 | 2008-10-22 23:20:29 -0700 | [diff] [blame] | 65 | int fec_initialize (bd_t *bis); |
Wolfgang Denk | de02ce9 | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 66 | int fecmxc_initialize(bd_t *bis); |
Marek Vasut | edcd6c0 | 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 | 199c625 | 2010-12-21 16:59:46 +0800 | [diff] [blame] | 68 | int ftgmac100_initialize(bd_t *bits); |
Po-Yu Chuang | 50253b8 | 2009-08-10 11:00:00 +0800 | [diff] [blame] | 69 | int ftmac100_initialize(bd_t *bits); |
Ben Warren | 2f2b6b6 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 70 | int greth_initialize(bd_t *bis); |
Ben Warren | 9d48ec2 | 2008-08-31 10:13:34 -0700 | [diff] [blame] | 71 | void gt6426x_eth_initialize(bd_t *bis); |
Ben Warren | d2358c0 | 2008-08-31 10:16:59 -0700 | [diff] [blame] | 72 | int inca_switch_initialize(bd_t *bis); |
Wolfgang Denk | de02ce9 | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 73 | int ks8695_eth_initialize(void); |
Nishanth Menon | f95b93b | 2009-10-16 00:06:35 -0500 | [diff] [blame] | 74 | int lan91c96_initialize(u8 dev_num, int base_addr); |
Ben Warren | 2f2b6b6 | 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 | b664dea | 2008-08-31 10:36:38 -0700 | [diff] [blame] | 78 | int mpc512x_fec_initialize(bd_t *bis); |
Ben Warren | cba8851 | 2008-08-31 10:39:12 -0700 | [diff] [blame] | 79 | int mpc5xxx_fec_initialize(bd_t *bis); |
Gary Jennejohn | 5ebdb1f | 2008-11-20 12:28:38 +0100 | [diff] [blame] | 80 | int mpc82xx_scc_enet_initialize(bd_t *bis); |
Albert Aribaud | e91d7d3 | 2010-07-12 22:24:28 +0200 | [diff] [blame] | 81 | int mvgbe_initialize(bd_t *bis); |
Ben Warren | 8d943c8 | 2008-08-31 10:07:16 -0700 | [diff] [blame] | 82 | int natsemi_initialize(bd_t *bis); |
Bernhard Kaindl | adb18ea | 2011-10-20 10:56:59 +0000 | [diff] [blame] | 83 | int ne2k_register(void); |
Ben Warren | 3ead27f | 2008-09-05 01:55:22 -0400 | [diff] [blame] | 84 | int npe_initialize(bd_t *bis); |
Ben Warren | f2c1acb | 2008-08-31 10:03:22 -0700 | [diff] [blame] | 85 | int ns8382x_initialize(bd_t *bis); |
Ben Warren | b794a93 | 2008-08-31 10:08:43 -0700 | [diff] [blame] | 86 | int pcnet_initialize(bd_t *bis); |
Ben Warren | 5f92942 | 2008-08-31 10:40:51 -0700 | [diff] [blame] | 87 | int plb2800_eth_initialize(bd_t *bis); |
Ben Warren | 9e37c58 | 2008-10-27 23:53:17 -0700 | [diff] [blame] | 88 | int ppc_4xx_eth_initialize (bd_t *bis); |
Ben Warren | 65b8623 | 2008-08-31 21:41:08 -0700 | [diff] [blame] | 89 | int rtl8139_initialize(bd_t *bis); |
Ben Warren | 26425a6 | 2008-08-31 09:49:42 -0700 | [diff] [blame] | 90 | int rtl8169_initialize(bd_t *bis); |
Ben Warren | bbff280 | 2008-10-23 22:02:49 -0700 | [diff] [blame] | 91 | int scc_initialize(bd_t *bis); |
Wolfgang Denk | de02ce9 | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 92 | int sh_eth_initialize(bd_t *bis); |
Ben Warren | 2f2b6b6 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 93 | int skge_initialize(bd_t *bis); |
Ben Warren | 0fd6aae | 2009-10-04 22:37:03 -0700 | [diff] [blame] | 94 | int smc91111_initialize(u8 dev_num, int base_addr); |
Wolfgang Denk | de02ce9 | 2011-09-10 16:59:02 +0200 | [diff] [blame] | 95 | int smc911x_initialize(u8 dev_num, int base_addr); |
Ben Warren | 04e97e0 | 2008-08-31 09:59:33 -0700 | [diff] [blame] | 96 | int tsi108_eth_initialize(bd_t *bis); |
Wolfgang Denk | 3756a3b | 2009-07-18 16:13:18 +0200 | [diff] [blame] | 97 | int uec_standard_init(bd_t *bis); |
Ben Warren | 2f2b6b6 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 98 | int uli526x_initialize(bd_t *bis); |
Ajay Bhargav | e312a36 | 2011-09-13 22:21:58 +0530 | [diff] [blame] | 99 | int armada100_fec_register(unsigned long base_addr); |
Michal Simek | 6fc7c45 | 2011-10-06 20:35:35 +0000 | [diff] [blame] | 100 | int xilinx_axiemac_initialize(bd_t *bis, unsigned long base_addr, |
| 101 | unsigned long dma_addr); |
Michal Simek | a6745b8 | 2011-10-12 23:23:22 +0000 | [diff] [blame] | 102 | int xilinx_emaclite_initialize(bd_t *bis, unsigned long base_addr, |
| 103 | int txpp, int rxpp); |
Stephan Linz | e1fd4be | 2012-02-25 00:48:31 +0000 | [diff] [blame] | 104 | int xilinx_ll_temac_eth_init(bd_t *bis, unsigned long base_addr, int flags, |
| 105 | unsigned long ctrl_addr); |
David Andrey | 73875dc | 2013-04-05 17:24:24 +0200 | [diff] [blame] | 106 | int zynq_gem_initialize(bd_t *bis, int base_addr, int phy_addr, u32 emio); |
Stephan Linz | e1fd4be | 2012-02-25 00:48:31 +0000 | [diff] [blame] | 107 | /* |
| 108 | * As long as the Xilinx xps_ll_temac ethernet driver has not its own interface |
| 109 | * exported by a public hader file, we need a global definition at this point. |
| 110 | */ |
| 111 | #if defined(CONFIG_XILINX_LL_TEMAC) |
| 112 | #define XILINX_LL_TEMAC_M_FIFO 0 /* use FIFO Ctrl */ |
| 113 | #define XILINX_LL_TEMAC_M_SDMA_PLB (1 << 0)/* use SDMA Ctrl via PLB */ |
| 114 | #define XILINX_LL_TEMAC_M_SDMA_DCR (1 << 1)/* use SDMA Ctrl via DCR */ |
| 115 | #endif |
Ben Warren | 2f2b6b6 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 116 | |
| 117 | /* Boards with PCI network controllers can call this from their board_eth_init() |
| 118 | * function to initialize whatever's on board. |
| 119 | * Return value is total # of devices found */ |
| 120 | |
| 121 | static inline int pci_eth_init(bd_t *bis) |
| 122 | { |
| 123 | int num = 0; |
Ben Warren | b794a93 | 2008-08-31 10:08:43 -0700 | [diff] [blame] | 124 | |
Ben Warren | 052a5ea | 2008-08-31 20:37:00 -0700 | [diff] [blame] | 125 | #ifdef CONFIG_PCI |
| 126 | |
| 127 | #ifdef CONFIG_EEPRO100 |
| 128 | num += eepro100_initialize(bis); |
| 129 | #endif |
Ben Warren | 840f8a5 | 2008-08-31 10:45:44 -0700 | [diff] [blame] | 130 | #ifdef CONFIG_TULIP |
| 131 | num += dc21x4x_initialize(bis); |
| 132 | #endif |
Ben Warren | 050019d | 2008-08-31 10:44:19 -0700 | [diff] [blame] | 133 | #ifdef CONFIG_E1000 |
| 134 | num += e1000_initialize(bis); |
| 135 | #endif |
Ben Warren | b794a93 | 2008-08-31 10:08:43 -0700 | [diff] [blame] | 136 | #ifdef CONFIG_PCNET |
| 137 | num += pcnet_initialize(bis); |
| 138 | #endif |
Ben Warren | 8d943c8 | 2008-08-31 10:07:16 -0700 | [diff] [blame] | 139 | #ifdef CONFIG_NATSEMI |
| 140 | num += natsemi_initialize(bis); |
| 141 | #endif |
Ben Warren | f2c1acb | 2008-08-31 10:03:22 -0700 | [diff] [blame] | 142 | #ifdef CONFIG_NS8382X |
| 143 | num += ns8382x_initialize(bis); |
| 144 | #endif |
Ben Warren | 65b8623 | 2008-08-31 21:41:08 -0700 | [diff] [blame] | 145 | #if defined(CONFIG_RTL8139) |
| 146 | num += rtl8139_initialize(bis); |
| 147 | #endif |
Ben Warren | 26425a6 | 2008-08-31 09:49:42 -0700 | [diff] [blame] | 148 | #if defined(CONFIG_RTL8169) |
| 149 | num += rtl8169_initialize(bis); |
| 150 | #endif |
Timur Tabi | c9174dc | 2009-04-09 10:27:05 -0500 | [diff] [blame] | 151 | #if defined(CONFIG_ULI526X) |
Ben Warren | 2f2b6b6 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 152 | num += uli526x_initialize(bis); |
| 153 | #endif |
Ben Warren | 052a5ea | 2008-08-31 20:37:00 -0700 | [diff] [blame] | 154 | |
| 155 | #endif /* CONFIG_PCI */ |
Ben Warren | 2f2b6b6 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 156 | return num; |
| 157 | } |
| 158 | |
Prafulla Wadaskar | a055ce0 | 2009-05-19 01:40:16 +0530 | [diff] [blame] | 159 | /* |
| 160 | * Boards with mv88e61xx switch can use this by defining |
| 161 | * CONFIG_MV88E61XX_SWITCH in respective board configheader file |
| 162 | * the stuct and enums here are used to specify switch configuration params |
| 163 | */ |
| 164 | #if defined(CONFIG_MV88E61XX_SWITCH) |
Albert ARIBAUD | 1368b08 | 2012-11-26 11:27:35 +0000 | [diff] [blame] | 165 | |
| 166 | /* constants for any 88E61xx switch */ |
| 167 | #define MV88E61XX_MAX_PORTS_NUM 6 |
Prafulla Wadaskar | a055ce0 | 2009-05-19 01:40:16 +0530 | [diff] [blame] | 168 | |
| 169 | enum mv88e61xx_cfg_mdip { |
| 170 | MV88E61XX_MDIP_NOCHANGE, |
| 171 | MV88E61XX_MDIP_REVERSE |
| 172 | }; |
| 173 | |
| 174 | enum mv88e61xx_cfg_ledinit { |
| 175 | MV88E61XX_LED_INIT_DIS, |
| 176 | MV88E61XX_LED_INIT_EN |
| 177 | }; |
| 178 | |
| 179 | enum mv88e61xx_cfg_rgmiid { |
| 180 | MV88E61XX_RGMII_DELAY_DIS, |
| 181 | MV88E61XX_RGMII_DELAY_EN |
| 182 | }; |
| 183 | |
| 184 | enum mv88e61xx_cfg_prtstt { |
| 185 | MV88E61XX_PORTSTT_DISABLED, |
| 186 | MV88E61XX_PORTSTT_BLOCKING, |
| 187 | MV88E61XX_PORTSTT_LEARNING, |
| 188 | MV88E61XX_PORTSTT_FORWARDING |
| 189 | }; |
| 190 | |
| 191 | struct mv88e61xx_config { |
| 192 | char *name; |
Albert ARIBAUD | 1368b08 | 2012-11-26 11:27:35 +0000 | [diff] [blame] | 193 | u8 vlancfg[MV88E61XX_MAX_PORTS_NUM]; |
Prafulla Wadaskar | a055ce0 | 2009-05-19 01:40:16 +0530 | [diff] [blame] | 194 | enum mv88e61xx_cfg_rgmiid rgmii_delay; |
| 195 | enum mv88e61xx_cfg_prtstt portstate; |
| 196 | enum mv88e61xx_cfg_ledinit led_init; |
| 197 | enum mv88e61xx_cfg_mdip mdip; |
| 198 | u32 ports_enabled; |
| 199 | u8 cpuport; |
| 200 | }; |
| 201 | |
Albert ARIBAUD | 1368b08 | 2012-11-26 11:27:35 +0000 | [diff] [blame] | 202 | /* |
| 203 | * Common mappings for Internal VLANs |
| 204 | * These mappings consider that all ports are useable; the driver |
| 205 | * will mask inexistent/unused ports. |
| 206 | */ |
| 207 | |
| 208 | /* Switch mode : routes any port to any port */ |
| 209 | #define MV88E61XX_VLANCFG_SWITCH { 0x3F, 0x3F, 0x3F, 0x3F, 0x3F, 0x3F } |
| 210 | |
| 211 | /* Router mode: routes only CPU port 5 to/from non-CPU ports 0-4 */ |
| 212 | #define MV88E61XX_VLANCFG_ROUTER { 0x20, 0x20, 0x20, 0x20, 0x20, 0x1F } |
| 213 | |
Prafulla Wadaskar | a055ce0 | 2009-05-19 01:40:16 +0530 | [diff] [blame] | 214 | int mv88e61xx_switch_initialize(struct mv88e61xx_config *swconfig); |
| 215 | #endif /* CONFIG_MV88E61XX_SWITCH */ |
| 216 | |
Troy Kisky | dce4def | 2012-10-22 16:40:46 +0000 | [diff] [blame] | 217 | struct mii_dev *fec_get_miibus(uint32_t base_addr, int dev_id); |
| 218 | #ifdef CONFIG_PHYLIB |
| 219 | struct phy_device; |
| 220 | int fec_probe(bd_t *bd, int dev_id, uint32_t base_addr, |
| 221 | struct mii_dev *bus, struct phy_device *phydev); |
| 222 | #else |
Marek Vasut | 539ecee | 2011-09-11 18:05:36 +0000 | [diff] [blame] | 223 | /* |
| 224 | * Allow FEC to fine-tune MII configuration on boards which require this. |
| 225 | */ |
| 226 | int fecmxc_register_mii_postcall(struct eth_device *dev, int (*cb)(int)); |
Troy Kisky | dce4def | 2012-10-22 16:40:46 +0000 | [diff] [blame] | 227 | #endif |
Marek Vasut | 539ecee | 2011-09-11 18:05:36 +0000 | [diff] [blame] | 228 | |
Ben Warren | 2f2b6b6 | 2008-08-31 22:22:04 -0700 | [diff] [blame] | 229 | #endif /* _NETDEV_H_ */ |