Blame view

include/fm_eth.h 5.54 KB
c916d7c91   Kumar Gala   powerpc/85xx: Add...
1
  /*
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
2
   * Copyright 2009-2012 Freescale Semiconductor, Inc.
c916d7c91   Kumar Gala   powerpc/85xx: Add...
3
   *
1a4596601   Wolfgang Denk   Add GPL-2.0+ SPDX...
4
   * SPDX-License-Identifier:	GPL-2.0+
c916d7c91   Kumar Gala   powerpc/85xx: Add...
5
6
7
8
9
10
   */
  
  #ifndef __FM_ETH_H__
  #define __FM_ETH_H__
  
  #include <common.h>
93f26f130   Claudiu Manoil   net: Merge asm/fs...
11
  #include <phy.h>
c916d7c91   Kumar Gala   powerpc/85xx: Add...
12
  #include <asm/types.h>
c916d7c91   Kumar Gala   powerpc/85xx: Add...
13
14
15
16
17
18
19
  
  enum fm_port {
  	FM1_DTSEC1,
  	FM1_DTSEC2,
  	FM1_DTSEC3,
  	FM1_DTSEC4,
  	FM1_DTSEC5,
9e7587584   York Sun   powerpc/mpc85xx: ...
20
21
22
  	FM1_DTSEC6,
  	FM1_DTSEC9,
  	FM1_DTSEC10,
c916d7c91   Kumar Gala   powerpc/85xx: Add...
23
  	FM1_10GEC1,
9e7587584   York Sun   powerpc/mpc85xx: ...
24
  	FM1_10GEC2,
82a55c1ef   Shengzhou Liu   net/fman: Add sup...
25
26
  	FM1_10GEC3,
  	FM1_10GEC4,
c916d7c91   Kumar Gala   powerpc/85xx: Add...
27
28
29
30
  	FM2_DTSEC1,
  	FM2_DTSEC2,
  	FM2_DTSEC3,
  	FM2_DTSEC4,
99abf7ded   Timur Tabi   powerpc/85xx: add...
31
  	FM2_DTSEC5,
9e7587584   York Sun   powerpc/mpc85xx: ...
32
33
34
  	FM2_DTSEC6,
  	FM2_DTSEC9,
  	FM2_DTSEC10,
c916d7c91   Kumar Gala   powerpc/85xx: Add...
35
  	FM2_10GEC1,
9e7587584   York Sun   powerpc/mpc85xx: ...
36
  	FM2_10GEC2,
c916d7c91   Kumar Gala   powerpc/85xx: Add...
37
38
39
40
41
42
43
  	NUM_FM_PORTS,
  };
  
  enum fm_eth_type {
  	FM_ETH_1G_E,
  	FM_ETH_10G_E,
  };
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
44
45
46
  #ifdef CONFIG_SYS_FMAN_V3
  #define CONFIG_SYS_FM1_DTSEC_MDIO_ADDR	(CONFIG_SYS_FSL_FM1_ADDR + 0xfc000)
  #define CONFIG_SYS_FM1_TGEC_MDIO_ADDR	(CONFIG_SYS_FSL_FM1_ADDR + 0xfd000)
23e1acaf4   Shaohui Xie   net/fm: fix MDIO ...
47
  #if (CONFIG_SYS_NUM_FMAN == 2)
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
48
49
  #define CONFIG_SYS_FM2_DTSEC_MDIO_ADDR	(CONFIG_SYS_FSL_FM2_ADDR + 0xfc000)
  #define CONFIG_SYS_FM2_TGEC_MDIO_ADDR	(CONFIG_SYS_FSL_FM2_ADDR + 0xfd000)
23e1acaf4   Shaohui Xie   net/fm: fix MDIO ...
50
  #endif
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
51
  #else
c916d7c91   Kumar Gala   powerpc/85xx: Add...
52
53
  #define CONFIG_SYS_FM1_DTSEC1_MDIO_ADDR	(CONFIG_SYS_FSL_FM1_ADDR + 0xe1120)
  #define CONFIG_SYS_FM1_TGEC_MDIO_ADDR	(CONFIG_SYS_FSL_FM1_ADDR + 0xf1000)
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
54
  #endif
c916d7c91   Kumar Gala   powerpc/85xx: Add...
55
56
57
58
59
60
61
62
63
  
  #define DEFAULT_FM_MDIO_NAME "FSL_MDIO0"
  #define DEFAULT_FM_TGEC_MDIO_NAME "FM_TGEC_MDIO"
  
  /* Fman ethernet info struct */
  #define FM_ETH_INFO_INITIALIZER(idx, pregs) \
  	.fm		= idx,						\
  	.phy_regs	= (void *)pregs,				\
  	.enet_if	= PHY_INTERFACE_MODE_NONE,			\
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
64
65
66
67
68
69
70
71
72
73
74
75
76
  #ifdef CONFIG_SYS_FMAN_V3
  #define FM_DTSEC_INFO_INITIALIZER(idx, n) \
  {									\
  	FM_ETH_INFO_INITIALIZER(idx, CONFIG_SYS_FM1_DTSEC_MDIO_ADDR)	\
  	.index		= idx,						\
  	.num		= n - 1,					\
  	.type		= FM_ETH_1G_E,					\
  	.port		= FM##idx##_DTSEC##n,				\
  	.rx_port_id	= RX_PORT_1G_BASE + n - 1,			\
  	.tx_port_id	= TX_PORT_1G_BASE + n - 1,			\
  	.compat_offset	= CONFIG_SYS_FSL_FM##idx##_OFFSET +		\
  				offsetof(struct ccsr_fman, memac[n-1]),\
  }
cc19c25e2   Shengzhou Liu   net/fman: update ...
77
78
79
80
81
82
83
84
85
86
87
88
89
90
  #ifdef CONFIG_FSL_FM_10GEC_REGULAR_NOTATION
  #define FM_TGEC_INFO_INITIALIZER(idx, n) \
  {									\
  	FM_ETH_INFO_INITIALIZER(idx, CONFIG_SYS_FM1_TGEC_MDIO_ADDR)	\
  	.index		= idx,						\
  	.num		= n - 1,					\
  	.type		= FM_ETH_10G_E,					\
  	.port		= FM##idx##_10GEC##n,				\
  	.rx_port_id	= RX_PORT_10G_BASE2 + n - 1,			\
  	.tx_port_id	= TX_PORT_10G_BASE2 + n - 1,			\
  	.compat_offset	= CONFIG_SYS_FSL_FM##idx##_OFFSET +		\
  				 offsetof(struct ccsr_fman, memac[n-1]),\
  }
  #else
23e1acaf4   Shaohui Xie   net/fm: fix MDIO ...
91
  #if (CONFIG_SYS_NUM_FMAN == 2)
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
92
93
  #define FM_TGEC_INFO_INITIALIZER(idx, n) \
  {									\
944b6ccf1   Shaohui Xie   Fman/t4240: some ...
94
  	FM_ETH_INFO_INITIALIZER(idx, CONFIG_SYS_FM2_TGEC_MDIO_ADDR)	\
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
95
96
97
98
99
100
101
  	.index		= idx,						\
  	.num		= n - 1,					\
  	.type		= FM_ETH_10G_E,					\
  	.port		= FM##idx##_10GEC##n,				\
  	.rx_port_id	= RX_PORT_10G_BASE + n - 1,			\
  	.tx_port_id	= TX_PORT_10G_BASE + n - 1,			\
  	.compat_offset	= CONFIG_SYS_FSL_FM##idx##_OFFSET +		\
944b6ccf1   Shaohui Xie   Fman/t4240: some ...
102
  				offsetof(struct ccsr_fman, memac[n-1+8]),\
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
103
  }
23e1acaf4   Shaohui Xie   net/fm: fix MDIO ...
104
105
106
107
108
109
110
111
112
113
114
115
116
117
  #else
  #define FM_TGEC_INFO_INITIALIZER(idx, n) \
  {									\
  	FM_ETH_INFO_INITIALIZER(idx, CONFIG_SYS_FM1_TGEC_MDIO_ADDR)	\
  	.index		= idx,						\
  	.num		= n - 1,					\
  	.type		= FM_ETH_10G_E,					\
  	.port		= FM##idx##_10GEC##n,				\
  	.rx_port_id	= RX_PORT_10G_BASE + n - 1,			\
  	.tx_port_id	= TX_PORT_10G_BASE + n - 1,			\
  	.compat_offset	= CONFIG_SYS_FSL_FM##idx##_OFFSET +		\
  				offsetof(struct ccsr_fman, memac[n-1+8]),\
  }
  #endif
cc19c25e2   Shengzhou Liu   net/fman: update ...
118
  #endif
82a55c1ef   Shengzhou Liu   net/fman: Add sup...
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
  
  #if (CONFIG_SYS_NUM_FM1_10GEC >= 3)
  #define FM_TGEC_INFO_INITIALIZER2(idx, n) \
  {									\
  	FM_ETH_INFO_INITIALIZER(idx, CONFIG_SYS_FM1_TGEC_MDIO_ADDR)	\
  	.index		= idx,						\
  	.num		= n - 1,					\
  	.type		= FM_ETH_10G_E,					\
  	.port		= FM##idx##_10GEC##n,				\
  	.rx_port_id	= RX_PORT_10G_BASE2 + n - 3,			\
  	.tx_port_id	= TX_PORT_10G_BASE2 + n - 3,			\
  	.compat_offset	= CONFIG_SYS_FSL_FM##idx##_OFFSET +		\
  				offsetof(struct ccsr_fman, memac[n-1-2]),\
  }
  #endif
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
134
  #else
c916d7c91   Kumar Gala   powerpc/85xx: Add...
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
  #define FM_DTSEC_INFO_INITIALIZER(idx, n) \
  {									\
  	FM_ETH_INFO_INITIALIZER(idx, CONFIG_SYS_FM1_DTSEC1_MDIO_ADDR)	\
  	.index		= idx,						\
  	.num		= n - 1,					\
  	.type		= FM_ETH_1G_E,					\
  	.port		= FM##idx##_DTSEC##n,				\
  	.rx_port_id	= RX_PORT_1G_BASE + n - 1,			\
  	.tx_port_id	= TX_PORT_1G_BASE + n - 1,			\
  	.compat_offset	= CONFIG_SYS_FSL_FM##idx##_OFFSET +		\
  				offsetof(struct ccsr_fman, mac_1g[n-1]),\
  }
  
  #define FM_TGEC_INFO_INITIALIZER(idx, n) \
  {									\
  	FM_ETH_INFO_INITIALIZER(idx, CONFIG_SYS_FM1_TGEC_MDIO_ADDR)	\
  	.index		= idx,						\
  	.num		= n - 1,					\
  	.type		= FM_ETH_10G_E,					\
  	.port		= FM##idx##_10GEC##n,				\
  	.rx_port_id	= RX_PORT_10G_BASE + n - 1,			\
  	.tx_port_id	= TX_PORT_10G_BASE + n - 1,			\
  	.compat_offset	= CONFIG_SYS_FSL_FM##idx##_OFFSET +		\
  				offsetof(struct ccsr_fman, mac_10g[n-1]),\
  }
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
160
  #endif
c916d7c91   Kumar Gala   powerpc/85xx: Add...
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
  struct fm_eth_info {
  	u8 enabled;
  	u8 fm;
  	u8 num;
  	u8 phy_addr;
  	int index;
  	u16 rx_port_id;
  	u16 tx_port_id;
  	enum fm_port port;
  	enum fm_eth_type type;
  	void *phy_regs;
  	phy_interface_t enet_if;
  	u32 compat_offset;
  	struct mii_dev *bus;
  };
  
  struct tgec_mdio_info {
  	struct tgec_mdio_controller *regs;
  	char *name;
  };
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
181
182
183
184
  struct memac_mdio_info {
  	struct memac_mdio_controller *regs;
  	char *name;
  };
c916d7c91   Kumar Gala   powerpc/85xx: Add...
185
  int fm_tgec_mdio_init(bd_t *bis, struct tgec_mdio_info *info);
111fd19e3   Roy Zang   fm/mEMAC: add mEM...
186
  int fm_memac_mdio_init(bd_t *bis, struct memac_mdio_info *info);
c916d7c91   Kumar Gala   powerpc/85xx: Add...
187
188
189
190
191
  int fm_standard_init(bd_t *bis);
  void fman_enet_init(void);
  void fdt_fixup_fman_ethernet(void *fdt);
  phy_interface_t fm_info_get_enet_if(enum fm_port port);
  void fm_info_set_phy_address(enum fm_port port, int address);
ae2291fbe   Timur Tabi   fm-eth: add funct...
192
  int fm_info_get_phy_address(enum fm_port port);
c916d7c91   Kumar Gala   powerpc/85xx: Add...
193
  void fm_info_set_mdio(enum fm_port port, struct mii_dev *bus);
69a852425   Kumar Gala   fm-eth: Add abili...
194
  void fm_disable_port(enum fm_port port);
f51d3b71d   Valentin Longchamp   net/fman: add a f...
195
  void fm_enable_port(enum fm_port port);
ffee1dde3   Zhao Qiang   SGMII:fix PHY add...
196
197
198
199
  void set_sgmii_phy(struct mii_dev *bus, enum fm_port base_port,
  		unsigned int port_num, int phy_base_addr);
  int is_qsgmii_riser_card(struct mii_dev *bus, int phy_base_addr,
  		unsigned int port_num, unsigned regnum);
c916d7c91   Kumar Gala   powerpc/85xx: Add...
200
201
  
  #endif