This source file includes following definitions.
- ethif_probe
- pc_eth_probe
- pc_eth_open
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 #include <linux/config.h>
28 #include <linux/netdevice.h>
29 #include <linux/errno.h>
30
31 #define LOOPBACK
32
33 #define NEXT_DEV NULL
34
35
36
37
38
39
40 extern int ultra_probe(struct device *dev);
41 extern int wd_probe(struct device *dev);
42 extern int el2_probe(struct device *dev);
43 extern int ne_probe(struct device *dev);
44 extern int hp_probe(struct device *dev);
45 extern int hp_plus_probe(struct device *dev);
46 extern int znet_probe(struct device *);
47 extern int express_probe(struct device *);
48 extern int el3_probe(struct device *);
49 extern int at1500_probe(struct device *);
50 extern int at1700_probe(struct device *);
51 extern int depca_probe(struct device *);
52 extern int el1_probe(struct device *);
53 extern int el16_probe(struct device *);
54 extern int elplus_probe(struct device *);
55 extern int ac3200_probe(struct device *);
56 extern int e2100_probe(struct device *);
57 extern int SK_init(struct device *dev);
58
59
60 extern int atp_init(struct device *);
61 extern int de600_probe(struct device *);
62 extern int de620_probe(struct device *);
63
64 static int
65 ethif_probe(struct device *dev)
66 {
67 short base_addr = dev->base_addr;
68
69 if (base_addr < 0 || base_addr == 1)
70 return 1;
71
72 if (1
73 #if defined(CONFIG_ULTRA)
74 && ultra_probe(dev)
75 #endif
76 #if defined(CONFIG_WD80x3) || defined(WD80x3)
77 && wd_probe(dev)
78 #endif
79 #if defined(CONFIG_EL2) || defined(EL2)
80 && el2_probe(dev)
81 #endif
82 #if defined(CONFIG_NE2000) || defined(NE2000)
83 && ne_probe(dev)
84 #endif
85 #if defined(CONFIG_HPLAN) || defined(HPLAN)
86 && hp_probe(dev)
87 #endif
88 #if defined(CONFIG_HPLAN_PLUS)
89 && hp_plus_probe(dev)
90 #endif
91 #ifdef CONFIG_AT1500
92 && at1500_probe(dev)
93 #endif
94 #ifdef CONFIG_AT1700
95 && at1700_probe(dev)
96 #endif
97 #ifdef CONFIG_EL3
98 && el3_probe(dev)
99 #endif
100 #ifdef CONFIG_ZNET
101 && znet_probe(dev)
102 #endif
103 #ifdef CONFIG_EEXPRESS
104 && express_probe(dev)
105 #endif
106 #ifdef CONFIG_DEPCA
107 && depca_probe(dev)
108 #endif
109 #ifdef CONFIG_EL1
110 && el1_probe(dev)
111 #endif
112 #ifdef CONFIG_EL16
113 && el16_probe(dev)
114 #endif
115 #ifdef CONFIG_ELPLUS
116 && elplus_probe(dev)
117 #endif
118 #ifdef CONFIG_AC3200
119 && ac3200_probe(dev)
120 #endif
121 #ifdef CONFIG_E2100
122 && e2100_probe(dev)
123 #endif
124 #ifdef CONFIG_DE600
125 && de600_probe(dev)
126 #endif
127 #ifdef CONFIG_DE620
128 && de620_probe(dev)
129 #endif
130 #if defined(CONFIG_SK_G16)
131 && SK_init(dev)
132 #endif
133 && 1 ) {
134 return 1;
135 }
136 return 0;
137 }
138
139 #ifdef CONFIG_PCMCIA_NET
140 extern int dl_open(struct device *dev);
141 extern int tc589_open(struct device *dev);
142 extern int ibmccae_open(struct device *dev);
143 static int pc_eth_open(struct device *dev);
144
145 static int pc_eth_probe(struct device *dev)
146 {
147 dev->open = &pc_eth_open;
148 dev->set_config = ðer_config;
149 dev->tbusy = 1;
150 return 0;
151 }
152
153 static int pc_eth_open(struct device *dev)
154 {
155 if (1
156 #ifdef CONFIG_DE650
157 && dl_open(dev)
158 #endif
159 #ifdef CONFIG_3C589
160 && tc589_open(dev)
161 #endif
162 #ifdef CONFIG_IBMCCAE
163 && ibmccae_open(dev)
164 #endif
165 && 1)
166 return -ENODEV;
167 else
168 return 0;
169 }
170 #endif
171
172
173
174 #ifdef CONFIG_ATP
175 static struct device atp_dev = {
176 "atp0", 0, 0, 0, 0, 0, 0, 0, 0, 0, NEXT_DEV, atp_init, };
177 # undef NEXT_DEV
178 # define NEXT_DEV (&atp_dev)
179 #endif
180
181 #ifdef CONFIG_PCMCIA_NET
182 static struct device pc_eth1_dev = {
183 "pc_eth1", 0, 0, 0, 0, 0, 0, 0, 0, 0, NEXT_DEV, pc_eth_probe,
184 };
185 static struct device pc_eth0_dev = {
186 "pc_eth0", 0, 0, 0, 0, 0, 0, 0, 0, 0, &pc_eth1_dev, pc_eth_probe,
187 };
188 # undef NEXT_DEV
189 # define NEXT_DEV (&pc_eth0_dev)
190 #endif
191
192
193 #ifndef ETH0_ADDR
194 # define ETH0_ADDR 0
195 #endif
196 #ifndef ETH0_IRQ
197 # define ETH0_IRQ 0
198 #endif
199
200
201
202
203 static struct device eth3_dev = {
204 "eth3", 0,0,0,0,0xffe0 , 0,0,0,0, NEXT_DEV, ethif_probe };
205 static struct device eth2_dev = {
206 "eth2", 0,0,0,0,0xffe0 , 0,0,0,0, ð3_dev, ethif_probe };
207 static struct device eth1_dev = {
208 "eth1", 0,0,0,0,0xffe0 , 0,0,0,0, ð2_dev, ethif_probe };
209
210 static struct device eth0_dev = {
211 "eth0", 0, 0, 0, 0, ETH0_ADDR, ETH0_IRQ, 0, 0, 0, ð1_dev, ethif_probe };
212
213 # undef NEXT_DEV
214 # define NEXT_DEV (ð0_dev)
215
216 #if defined(PLIP) || defined(CONFIG_PLIP)
217 extern int plip_init(struct device *);
218 static struct device plip2_dev = {
219 "plip2", 0, 0, 0, 0, 0x278, 2, 0, 0, 0, NEXT_DEV, plip_init, };
220 static struct device plip1_dev = {
221 "plip1", 0, 0, 0, 0, 0x378, 7, 0, 0, 0, &plip2_dev, plip_init, };
222 static struct device plip0_dev = {
223 "plip0", 0, 0, 0, 0, 0x3BC, 5, 0, 0, 0, &plip1_dev, plip_init, };
224 # undef NEXT_DEV
225 # define NEXT_DEV (&plip0_dev)
226 #endif
227
228 #if defined(SLIP) || defined(CONFIG_SLIP)
229 extern int slip_init(struct device *);
230 static struct device slip3_dev = {
231 "sl3",
232 0x0,
233 0x0,
234 0x0,
235 0x0,
236 0x3,
237 0,
238 0, 0, 0,
239 NEXT_DEV,
240 slip_init
241 };
242 static struct device slip2_dev = {
243 "sl2",
244 0x0,
245 0x0,
246 0x0,
247 0x0,
248 0x2,
249 0,
250 0, 0, 0,
251 &slip3_dev,
252 slip_init
253 };
254 static struct device slip1_dev = {
255 "sl1",
256 0x0,
257 0x0,
258 0x0,
259 0x0,
260 0x1,
261 0,
262 0, 0, 0,
263 &slip2_dev,
264 slip_init
265 };
266 static struct device slip0_dev = {
267 "sl0",
268 0x0,
269 0x0,
270 0x0,
271 0x0,
272 0x0,
273 0,
274 0, 0, 0,
275 &slip1_dev,
276 slip_init
277 };
278 # undef NEXT_DEV
279 # define NEXT_DEV (&slip0_dev)
280 #endif
281
282 #if defined(CONFIG_PPP)
283 extern int ppp_init(struct device *);
284 static struct device ppp3_dev = {
285 "ppp3", 0x0, 0x0, 0x0, 0x0, 3, 0, 0, 0, 0, NEXT_DEV, ppp_init, };
286 static struct device ppp2_dev = {
287 "ppp2", 0x0, 0x0, 0x0, 0x0, 2, 0, 0, 0, 0, &ppp3_dev, ppp_init, };
288 static struct device ppp1_dev = {
289 "ppp1", 0x0, 0x0, 0x0, 0x0, 1, 0, 0, 0, 0, &ppp2_dev, ppp_init, };
290 static struct device ppp0_dev = {
291 "ppp0", 0x0, 0x0, 0x0, 0x0, 0, 0, 0, 0, 0, &ppp1_dev, ppp_init, };
292 #undef NEXT_DEV
293 #define NEXT_DEV (&ppp0_dev)
294 #endif
295
296 #ifdef CONFIG_DUMMY
297 extern int dummy_init(struct device *dev);
298 static struct device dummy_dev = {
299 "dummy", 0x0, 0x0, 0x0, 0x0, 0, 0, 0, 0, 0, NEXT_DEV, dummy_init, };
300 # undef NEXT_DEV
301 # define NEXT_DEV (&dummy_dev)
302 #endif
303
304 #ifdef LOOPBACK
305 extern int loopback_init(struct device *dev);
306 static struct device loopback_dev = {
307 "lo",
308 0x0,
309 0x0,
310 0x0,
311 0x0,
312 0,
313 0,
314 0, 0, 0,
315 NEXT_DEV,
316 loopback_init
317 };
318 # undef NEXT_DEV
319 # define NEXT_DEV (&loopback_dev)
320 #endif
321
322
323 struct device *dev_base = NEXT_DEV;