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