1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3 A Davicom DM9102/DM9102A/DM9102A+DM9801/DM9102A+DM9802 NIC fast
4 ethernet driver for Linux.
5 Copyright (C) 1997 Sten Wang
6
7
8 DAVICOM Web-Site: www.davicom.com.tw
9
10 Author: Sten Wang, 886-3-5798797-8517, E-mail: sten_wang@davicom.com.tw
11 Maintainer: Tobias Ringstrom <tori@unhappy.mine.nu>
12
13 (C)Copyright 1997-1998 DAVICOM Semiconductor,Inc. All Rights Reserved.
14
15 Marcelo Tosatti <marcelo@conectiva.com.br> :
16 Made it compile in 2.3 (device to net_device)
17
18 Alan Cox <alan@lxorguk.ukuu.org.uk> :
19 Cleaned up for kernel merge.
20 Removed the back compatibility support
21 Reformatted, fixing spelling etc as I went
22 Removed IRQ 0-15 assumption
23
24 Jeff Garzik <jgarzik@pobox.com> :
25 Updated to use new PCI driver API.
26 Resource usage cleanups.
27 Report driver version to user.
28
29 Tobias Ringstrom <tori@unhappy.mine.nu> :
30 Cleaned up and added SMP safety. Thanks go to Jeff Garzik,
31 Andrew Morton and Frank Davis for the SMP safety fixes.
32
33 Vojtech Pavlik <vojtech@suse.cz> :
34 Cleaned up pointer arithmetics.
35 Fixed a lot of 64bit issues.
36 Cleaned up printk()s a bit.
37 Fixed some obvious big endian problems.
38
39 Tobias Ringstrom <tori@unhappy.mine.nu> :
40 Use time_after for jiffies calculation. Added ethtool
41 support. Updated PCI resource allocation. Do not
42 forget to unmap PCI mapped skbs.
43
44 Alan Cox <alan@lxorguk.ukuu.org.uk>
45 Added new PCI identifiers provided by Clear Zhang at ALi
46 for their 1563 ethernet device.
47
48 TODO
49
50 Check on 64 bit boxes.
51 Check and fix on big endian boxes.
52
53 Test and make sure PCI latency is now correct for all cases.
54 */
55
56 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
57
58 #define DRV_NAME "dmfe"
59 #define DRV_VERSION "1.36.4"
60 #define DRV_RELDATE "2002-01-17"
61
62 #include <linux/module.h>
63 #include <linux/kernel.h>
64 #include <linux/string.h>
65 #include <linux/timer.h>
66 #include <linux/ptrace.h>
67 #include <linux/errno.h>
68 #include <linux/ioport.h>
69 #include <linux/interrupt.h>
70 #include <linux/pci.h>
71 #include <linux/dma-mapping.h>
72 #include <linux/init.h>
73 #include <linux/netdevice.h>
74 #include <linux/etherdevice.h>
75 #include <linux/ethtool.h>
76 #include <linux/skbuff.h>
77 #include <linux/delay.h>
78 #include <linux/spinlock.h>
79 #include <linux/crc32.h>
80 #include <linux/bitops.h>
81
82 #include <asm/processor.h>
83 #include <asm/io.h>
84 #include <asm/dma.h>
85 #include <linux/uaccess.h>
86 #include <asm/irq.h>
87
88 #ifdef CONFIG_TULIP_DM910X
89 #include <linux/of.h>
90 #endif
91
92
93 /* Board/System/Debug information/definition ---------------- */
94 #define PCI_DM9132_ID 0x91321282 /* Davicom DM9132 ID */
95 #define PCI_DM9102_ID 0x91021282 /* Davicom DM9102 ID */
96 #define PCI_DM9100_ID 0x91001282 /* Davicom DM9100 ID */
97 #define PCI_DM9009_ID 0x90091282 /* Davicom DM9009 ID */
98
99 #define DM9102_IO_SIZE 0x80
100 #define DM9102A_IO_SIZE 0x100
101 #define TX_MAX_SEND_CNT 0x1 /* Maximum tx packet per time */
102 #define TX_DESC_CNT 0x10 /* Allocated Tx descriptors */
103 #define RX_DESC_CNT 0x20 /* Allocated Rx descriptors */
104 #define TX_FREE_DESC_CNT (TX_DESC_CNT - 2) /* Max TX packet count */
105 #define TX_WAKE_DESC_CNT (TX_DESC_CNT - 3) /* TX wakeup count */
106 #define DESC_ALL_CNT (TX_DESC_CNT + RX_DESC_CNT)
107 #define TX_BUF_ALLOC 0x600
108 #define RX_ALLOC_SIZE 0x620
109 #define DM910X_RESET 1
110 #define CR0_DEFAULT 0x00E00000 /* TX & RX burst mode */
111 #define CR6_DEFAULT 0x00080000 /* HD */
112 #define CR7_DEFAULT 0x180c1
113 #define CR15_DEFAULT 0x06 /* TxJabber RxWatchdog */
114 #define TDES0_ERR_MASK 0x4302 /* TXJT, LC, EC, FUE */
115 #define MAX_PACKET_SIZE 1514
116 #define DMFE_MAX_MULTICAST 14
117 #define RX_COPY_SIZE 100
118 #define MAX_CHECK_PACKET 0x8000
119 #define DM9801_NOISE_FLOOR 8
120 #define DM9802_NOISE_FLOOR 5
121
122 #define DMFE_WOL_LINKCHANGE 0x20000000
123 #define DMFE_WOL_SAMPLEPACKET 0x10000000
124 #define DMFE_WOL_MAGICPACKET 0x08000000
125
126
127 #define DMFE_10MHF 0
128 #define DMFE_100MHF 1
129 #define DMFE_10MFD 4
130 #define DMFE_100MFD 5
131 #define DMFE_AUTO 8
132 #define DMFE_1M_HPNA 0x10
133
134 #define DMFE_TXTH_72 0x400000 /* TX TH 72 byte */
135 #define DMFE_TXTH_96 0x404000 /* TX TH 96 byte */
136 #define DMFE_TXTH_128 0x0000 /* TX TH 128 byte */
137 #define DMFE_TXTH_256 0x4000 /* TX TH 256 byte */
138 #define DMFE_TXTH_512 0x8000 /* TX TH 512 byte */
139 #define DMFE_TXTH_1K 0xC000 /* TX TH 1K byte */
140
141 #define DMFE_TIMER_WUT (jiffies + HZ * 1)/* timer wakeup time : 1 second */
142 #define DMFE_TX_TIMEOUT ((3*HZ)/2) /* tx packet time-out time 1.5 s" */
143 #define DMFE_TX_KICK (HZ/2) /* tx packet Kick-out time 0.5 s" */
144
145 #define dw32(reg, val) iowrite32(val, ioaddr + (reg))
146 #define dw16(reg, val) iowrite16(val, ioaddr + (reg))
147 #define dr32(reg) ioread32(ioaddr + (reg))
148 #define dr16(reg) ioread16(ioaddr + (reg))
149 #define dr8(reg) ioread8(ioaddr + (reg))
150
151 #define DMFE_DBUG(dbug_now, msg, value) \
152 do { \
153 if (dmfe_debug || (dbug_now)) \
154 pr_err("%s %lx\n", \
155 (msg), (long) (value)); \
156 } while (0)
157
158 #define SHOW_MEDIA_TYPE(mode) \
159 pr_info("Change Speed to %sMhz %s duplex\n" , \
160 (mode & 1) ? "100":"10", \
161 (mode & 4) ? "full":"half");
162
163
164 /* CR9 definition: SROM/MII */
165 #define CR9_SROM_READ 0x4800
166 #define CR9_SRCS 0x1
167 #define CR9_SRCLK 0x2
168 #define CR9_CRDOUT 0x8
169 #define SROM_DATA_0 0x0
170 #define SROM_DATA_1 0x4
171 #define PHY_DATA_1 0x20000
172 #define PHY_DATA_0 0x00000
173 #define MDCLKH 0x10000
174
175 #define PHY_POWER_DOWN 0x800
176
177 #define SROM_V41_CODE 0x14
178
179 #define __CHK_IO_SIZE(pci_id, dev_rev) \
180 (( ((pci_id)==PCI_DM9132_ID) || ((dev_rev) >= 0x30) ) ? \
181 DM9102A_IO_SIZE: DM9102_IO_SIZE)
182
183 #define CHK_IO_SIZE(pci_dev) \
184 (__CHK_IO_SIZE(((pci_dev)->device << 16) | (pci_dev)->vendor, \
185 (pci_dev)->revision))
186
187 /* Structure/enum declaration ------------------------------- */
188 struct tx_desc {
189 __le32 tdes0, tdes1, tdes2, tdes3; /* Data for the card */
190 char *tx_buf_ptr; /* Data for us */
191 struct tx_desc *next_tx_desc;
192 } __attribute__(( aligned(32) ));
193
194 struct rx_desc {
195 __le32 rdes0, rdes1, rdes2, rdes3; /* Data for the card */
196 struct sk_buff *rx_skb_ptr; /* Data for us */
197 struct rx_desc *next_rx_desc;
198 } __attribute__(( aligned(32) ));
199
200 struct dmfe_board_info {
201 u32 chip_id; /* Chip vendor/Device ID */
202 u8 chip_revision; /* Chip revision */
203 struct net_device *next_dev; /* next device */
204 struct pci_dev *pdev; /* PCI device */
205 spinlock_t lock;
206
207 void __iomem *ioaddr; /* I/O base address */
208 u32 cr0_data;
209 u32 cr5_data;
210 u32 cr6_data;
211 u32 cr7_data;
212 u32 cr15_data;
213
214 /* pointer for memory physical address */
215 dma_addr_t buf_pool_dma_ptr; /* Tx buffer pool memory */
216 dma_addr_t buf_pool_dma_start; /* Tx buffer pool align dword */
217 dma_addr_t desc_pool_dma_ptr; /* descriptor pool memory */
218 dma_addr_t first_tx_desc_dma;
219 dma_addr_t first_rx_desc_dma;
220
221 /* descriptor pointer */
222 unsigned char *buf_pool_ptr; /* Tx buffer pool memory */
223 unsigned char *buf_pool_start; /* Tx buffer pool align dword */
224 unsigned char *desc_pool_ptr; /* descriptor pool memory */
225 struct tx_desc *first_tx_desc;
226 struct tx_desc *tx_insert_ptr;
227 struct tx_desc *tx_remove_ptr;
228 struct rx_desc *first_rx_desc;
229 struct rx_desc *rx_insert_ptr;
230 struct rx_desc *rx_ready_ptr; /* packet come pointer */
231 unsigned long tx_packet_cnt; /* transmitted packet count */
232 unsigned long tx_queue_cnt; /* wait to send packet count */
233 unsigned long rx_avail_cnt; /* available rx descriptor count */
234 unsigned long interval_rx_cnt; /* rx packet count a callback time */
235
236 u16 HPNA_command; /* For HPNA register 16 */
237 u16 HPNA_timer; /* For HPNA remote device check */
238 u16 dbug_cnt;
239 u16 NIC_capability; /* NIC media capability */
240 u16 PHY_reg4; /* Saved Phyxcer register 4 value */
241
242 u8 HPNA_present; /* 0:none, 1:DM9801, 2:DM9802 */
243 u8 chip_type; /* Keep DM9102A chip type */
244 u8 media_mode; /* user specify media mode */
245 u8 op_mode; /* real work media mode */
246 u8 phy_addr;
247 u8 wait_reset; /* Hardware failed, need to reset */
248 u8 dm910x_chk_mode; /* Operating mode check */
249 u8 first_in_callback; /* Flag to record state */
250 u8 wol_mode; /* user WOL settings */
251 struct timer_list timer;
252
253 /* Driver defined statistic counter */
254 unsigned long tx_fifo_underrun;
255 unsigned long tx_loss_carrier;
256 unsigned long tx_no_carrier;
257 unsigned long tx_late_collision;
258 unsigned long tx_excessive_collision;
259 unsigned long tx_jabber_timeout;
260 unsigned long reset_count;
261 unsigned long reset_cr8;
262 unsigned long reset_fatal;
263 unsigned long reset_TXtimeout;
264
265 /* NIC SROM data */
266 unsigned char srom[128];
267 };
268
269 enum dmfe_offsets {
270 DCR0 = 0x00, DCR1 = 0x08, DCR2 = 0x10, DCR3 = 0x18, DCR4 = 0x20,
271 DCR5 = 0x28, DCR6 = 0x30, DCR7 = 0x38, DCR8 = 0x40, DCR9 = 0x48,
272 DCR10 = 0x50, DCR11 = 0x58, DCR12 = 0x60, DCR13 = 0x68, DCR14 = 0x70,
273 DCR15 = 0x78
274 };
275
276 enum dmfe_CR6_bits {
277 CR6_RXSC = 0x2, CR6_PBF = 0x8, CR6_PM = 0x40, CR6_PAM = 0x80,
278 CR6_FDM = 0x200, CR6_TXSC = 0x2000, CR6_STI = 0x100000,
279 CR6_SFT = 0x200000, CR6_RXA = 0x40000000, CR6_NO_PURGE = 0x20000000
280 };
281
282 /* Global variable declaration ----------------------------- */
283 static int printed_version;
284 static const char version[] =
285 "Davicom DM9xxx net driver, version " DRV_VERSION " (" DRV_RELDATE ")";
286
287 static int dmfe_debug;
288 static unsigned char dmfe_media_mode = DMFE_AUTO;
289 static u32 dmfe_cr6_user_set;
290
291 /* For module input parameter */
292 static int debug;
293 static u32 cr6set;
294 static unsigned char mode = 8;
295 static u8 chkmode = 1;
296 static u8 HPNA_mode; /* Default: Low Power/High Speed */
297 static u8 HPNA_rx_cmd; /* Default: Disable Rx remote command */
298 static u8 HPNA_tx_cmd; /* Default: Don't issue remote command */
299 static u8 HPNA_NoiseFloor; /* Default: HPNA NoiseFloor */
300 static u8 SF_mode; /* Special Function: 1:VLAN, 2:RX Flow Control
301 4: TX pause packet */
302
303
304 /* function declaration ------------------------------------- */
305 static int dmfe_open(struct net_device *);
306 static netdev_tx_t dmfe_start_xmit(struct sk_buff *, struct net_device *);
307 static int dmfe_stop(struct net_device *);
308 static void dmfe_set_filter_mode(struct net_device *);
309 static const struct ethtool_ops netdev_ethtool_ops;
310 static u16 read_srom_word(void __iomem *, int);
311 static irqreturn_t dmfe_interrupt(int , void *);
312 #ifdef CONFIG_NET_POLL_CONTROLLER
313 static void poll_dmfe (struct net_device *dev);
314 #endif
315 static void dmfe_descriptor_init(struct net_device *);
316 static void allocate_rx_buffer(struct net_device *);
317 static void update_cr6(u32, void __iomem *);
318 static void send_filter_frame(struct net_device *);
319 static void dm9132_id_table(struct net_device *);
320 static u16 dmfe_phy_read(void __iomem *, u8, u8, u32);
321 static void dmfe_phy_write(void __iomem *, u8, u8, u16, u32);
322 static void dmfe_phy_write_1bit(void __iomem *, u32);
323 static u16 dmfe_phy_read_1bit(void __iomem *);
324 static u8 dmfe_sense_speed(struct dmfe_board_info *);
325 static void dmfe_process_mode(struct dmfe_board_info *);
326 static void dmfe_timer(struct timer_list *);
327 static inline u32 cal_CRC(unsigned char *, unsigned int, u8);
328 static void dmfe_rx_packet(struct net_device *, struct dmfe_board_info *);
329 static void dmfe_free_tx_pkt(struct net_device *, struct dmfe_board_info *);
330 static void dmfe_reuse_skb(struct dmfe_board_info *, struct sk_buff *);
331 static void dmfe_dynamic_reset(struct net_device *);
332 static void dmfe_free_rxbuffer(struct dmfe_board_info *);
333 static void dmfe_init_dm910x(struct net_device *);
334 static void dmfe_parse_srom(struct dmfe_board_info *);
335 static void dmfe_program_DM9801(struct dmfe_board_info *, int);
336 static void dmfe_program_DM9802(struct dmfe_board_info *);
337 static void dmfe_HPNA_remote_cmd_chk(struct dmfe_board_info * );
338 static void dmfe_set_phyxcer(struct dmfe_board_info *);
339
340 /* DM910X network board routine ---------------------------- */
341
342 static const struct net_device_ops netdev_ops = {
343 .ndo_open = dmfe_open,
344 .ndo_stop = dmfe_stop,
345 .ndo_start_xmit = dmfe_start_xmit,
346 .ndo_set_rx_mode = dmfe_set_filter_mode,
347 .ndo_set_mac_address = eth_mac_addr,
348 .ndo_validate_addr = eth_validate_addr,
349 #ifdef CONFIG_NET_POLL_CONTROLLER
350 .ndo_poll_controller = poll_dmfe,
351 #endif
352 };
353
354 /*
355 * Search DM910X board ,allocate space and register it
356 */
357
dmfe_init_one(struct pci_dev * pdev,const struct pci_device_id * ent)358 static int dmfe_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
359 {
360 struct dmfe_board_info *db; /* board information structure */
361 struct net_device *dev;
362 u32 pci_pmr;
363 int i, err;
364
365 DMFE_DBUG(0, "dmfe_init_one()", 0);
366
367 if (!printed_version++)
368 pr_info("%s\n", version);
369
370 /*
371 * SPARC on-board DM910x chips should be handled by the main
372 * tulip driver, except for early DM9100s.
373 */
374 #ifdef CONFIG_TULIP_DM910X
375 if ((ent->driver_data == PCI_DM9100_ID && pdev->revision >= 0x30) ||
376 ent->driver_data == PCI_DM9102_ID) {
377 struct device_node *dp = pci_device_to_OF_node(pdev);
378
379 if (dp && of_get_property(dp, "local-mac-address", NULL)) {
380 pr_info("skipping on-board DM910x (use tulip)\n");
381 return -ENODEV;
382 }
383 }
384 #endif
385
386 /* Init network device */
387 dev = alloc_etherdev(sizeof(*db));
388 if (dev == NULL)
389 return -ENOMEM;
390 SET_NETDEV_DEV(dev, &pdev->dev);
391
392 if (pci_set_dma_mask(pdev, DMA_BIT_MASK(32))) {
393 pr_warn("32-bit PCI DMA not available\n");
394 err = -ENODEV;
395 goto err_out_free;
396 }
397
398 /* Enable Master/IO access, Disable memory access */
399 err = pci_enable_device(pdev);
400 if (err)
401 goto err_out_free;
402
403 if (!pci_resource_start(pdev, 0)) {
404 pr_err("I/O base is zero\n");
405 err = -ENODEV;
406 goto err_out_disable;
407 }
408
409 if (pci_resource_len(pdev, 0) < (CHK_IO_SIZE(pdev)) ) {
410 pr_err("Allocated I/O size too small\n");
411 err = -ENODEV;
412 goto err_out_disable;
413 }
414
415 #if 0 /* pci_{enable_device,set_master} sets minimum latency for us now */
416
417 /* Set Latency Timer 80h */
418 /* FIXME: setting values > 32 breaks some SiS 559x stuff.
419 Need a PCI quirk.. */
420
421 pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 0x80);
422 #endif
423
424 if (pci_request_regions(pdev, DRV_NAME)) {
425 pr_err("Failed to request PCI regions\n");
426 err = -ENODEV;
427 goto err_out_disable;
428 }
429
430 /* Init system & device */
431 db = netdev_priv(dev);
432
433 /* Allocate Tx/Rx descriptor memory */
434 db->desc_pool_ptr = pci_alloc_consistent(pdev, sizeof(struct tx_desc) *
435 DESC_ALL_CNT + 0x20, &db->desc_pool_dma_ptr);
436 if (!db->desc_pool_ptr) {
437 err = -ENOMEM;
438 goto err_out_res;
439 }
440
441 db->buf_pool_ptr = pci_alloc_consistent(pdev, TX_BUF_ALLOC *
442 TX_DESC_CNT + 4, &db->buf_pool_dma_ptr);
443 if (!db->buf_pool_ptr) {
444 err = -ENOMEM;
445 goto err_out_free_desc;
446 }
447
448 db->first_tx_desc = (struct tx_desc *) db->desc_pool_ptr;
449 db->first_tx_desc_dma = db->desc_pool_dma_ptr;
450 db->buf_pool_start = db->buf_pool_ptr;
451 db->buf_pool_dma_start = db->buf_pool_dma_ptr;
452
453 db->chip_id = ent->driver_data;
454 /* IO type range. */
455 db->ioaddr = pci_iomap(pdev, 0, 0);
456 if (!db->ioaddr) {
457 err = -ENOMEM;
458 goto err_out_free_buf;
459 }
460
461 db->chip_revision = pdev->revision;
462 db->wol_mode = 0;
463
464 db->pdev = pdev;
465
466 pci_set_drvdata(pdev, dev);
467 dev->netdev_ops = &netdev_ops;
468 dev->ethtool_ops = &netdev_ethtool_ops;
469 netif_carrier_off(dev);
470 spin_lock_init(&db->lock);
471
472 pci_read_config_dword(pdev, 0x50, &pci_pmr);
473 pci_pmr &= 0x70000;
474 if ( (pci_pmr == 0x10000) && (db->chip_revision == 0x31) )
475 db->chip_type = 1; /* DM9102A E3 */
476 else
477 db->chip_type = 0;
478
479 /* read 64 word srom data */
480 for (i = 0; i < 64; i++) {
481 ((__le16 *) db->srom)[i] =
482 cpu_to_le16(read_srom_word(db->ioaddr, i));
483 }
484
485 /* Set Node address */
486 for (i = 0; i < 6; i++)
487 dev->dev_addr[i] = db->srom[20 + i];
488
489 err = register_netdev (dev);
490 if (err)
491 goto err_out_unmap;
492
493 dev_info(&dev->dev, "Davicom DM%04lx at pci%s, %pM, irq %d\n",
494 ent->driver_data >> 16,
495 pci_name(pdev), dev->dev_addr, pdev->irq);
496
497 pci_set_master(pdev);
498
499 return 0;
500
501 err_out_unmap:
502 pci_iounmap(pdev, db->ioaddr);
503 err_out_free_buf:
504 pci_free_consistent(pdev, TX_BUF_ALLOC * TX_DESC_CNT + 4,
505 db->buf_pool_ptr, db->buf_pool_dma_ptr);
506 err_out_free_desc:
507 pci_free_consistent(pdev, sizeof(struct tx_desc) * DESC_ALL_CNT + 0x20,
508 db->desc_pool_ptr, db->desc_pool_dma_ptr);
509 err_out_res:
510 pci_release_regions(pdev);
511 err_out_disable:
512 pci_disable_device(pdev);
513 err_out_free:
514 free_netdev(dev);
515
516 return err;
517 }
518
519
dmfe_remove_one(struct pci_dev * pdev)520 static void dmfe_remove_one(struct pci_dev *pdev)
521 {
522 struct net_device *dev = pci_get_drvdata(pdev);
523 struct dmfe_board_info *db = netdev_priv(dev);
524
525 DMFE_DBUG(0, "dmfe_remove_one()", 0);
526
527 if (dev) {
528
529 unregister_netdev(dev);
530 pci_iounmap(db->pdev, db->ioaddr);
531 pci_free_consistent(db->pdev, sizeof(struct tx_desc) *
532 DESC_ALL_CNT + 0x20, db->desc_pool_ptr,
533 db->desc_pool_dma_ptr);
534 pci_free_consistent(db->pdev, TX_BUF_ALLOC * TX_DESC_CNT + 4,
535 db->buf_pool_ptr, db->buf_pool_dma_ptr);
536 pci_release_regions(pdev);
537 free_netdev(dev); /* free board information */
538 }
539
540 DMFE_DBUG(0, "dmfe_remove_one() exit", 0);
541 }
542
543
544 /*
545 * Open the interface.
546 * The interface is opened whenever "ifconfig" actives it.
547 */
548
dmfe_open(struct net_device * dev)549 static int dmfe_open(struct net_device *dev)
550 {
551 struct dmfe_board_info *db = netdev_priv(dev);
552 const int irq = db->pdev->irq;
553 int ret;
554
555 DMFE_DBUG(0, "dmfe_open", 0);
556
557 ret = request_irq(irq, dmfe_interrupt, IRQF_SHARED, dev->name, dev);
558 if (ret)
559 return ret;
560
561 /* system variable init */
562 db->cr6_data = CR6_DEFAULT | dmfe_cr6_user_set;
563 db->tx_packet_cnt = 0;
564 db->tx_queue_cnt = 0;
565 db->rx_avail_cnt = 0;
566 db->wait_reset = 0;
567
568 db->first_in_callback = 0;
569 db->NIC_capability = 0xf; /* All capability*/
570 db->PHY_reg4 = 0x1e0;
571
572 /* CR6 operation mode decision */
573 if ( !chkmode || (db->chip_id == PCI_DM9132_ID) ||
574 (db->chip_revision >= 0x30) ) {
575 db->cr6_data |= DMFE_TXTH_256;
576 db->cr0_data = CR0_DEFAULT;
577 db->dm910x_chk_mode=4; /* Enter the normal mode */
578 } else {
579 db->cr6_data |= CR6_SFT; /* Store & Forward mode */
580 db->cr0_data = 0;
581 db->dm910x_chk_mode = 1; /* Enter the check mode */
582 }
583
584 /* Initialize DM910X board */
585 dmfe_init_dm910x(dev);
586
587 /* Active System Interface */
588 netif_wake_queue(dev);
589
590 /* set and active a timer process */
591 timer_setup(&db->timer, dmfe_timer, 0);
592 db->timer.expires = DMFE_TIMER_WUT + HZ * 2;
593 add_timer(&db->timer);
594
595 return 0;
596 }
597
598
599 /* Initialize DM910X board
600 * Reset DM910X board
601 * Initialize TX/Rx descriptor chain structure
602 * Send the set-up frame
603 * Enable Tx/Rx machine
604 */
605
dmfe_init_dm910x(struct net_device * dev)606 static void dmfe_init_dm910x(struct net_device *dev)
607 {
608 struct dmfe_board_info *db = netdev_priv(dev);
609 void __iomem *ioaddr = db->ioaddr;
610
611 DMFE_DBUG(0, "dmfe_init_dm910x()", 0);
612
613 /* Reset DM910x MAC controller */
614 dw32(DCR0, DM910X_RESET); /* RESET MAC */
615 udelay(100);
616 dw32(DCR0, db->cr0_data);
617 udelay(5);
618
619 /* Phy addr : DM910(A)2/DM9132/9801, phy address = 1 */
620 db->phy_addr = 1;
621
622 /* Parser SROM and media mode */
623 dmfe_parse_srom(db);
624 db->media_mode = dmfe_media_mode;
625
626 /* RESET Phyxcer Chip by GPR port bit 7 */
627 dw32(DCR12, 0x180); /* Let bit 7 output port */
628 if (db->chip_id == PCI_DM9009_ID) {
629 dw32(DCR12, 0x80); /* Issue RESET signal */
630 mdelay(300); /* Delay 300 ms */
631 }
632 dw32(DCR12, 0x0); /* Clear RESET signal */
633
634 /* Process Phyxcer Media Mode */
635 if ( !(db->media_mode & 0x10) ) /* Force 1M mode */
636 dmfe_set_phyxcer(db);
637
638 /* Media Mode Process */
639 if ( !(db->media_mode & DMFE_AUTO) )
640 db->op_mode = db->media_mode; /* Force Mode */
641
642 /* Initialize Transmit/Receive descriptor and CR3/4 */
643 dmfe_descriptor_init(dev);
644
645 /* Init CR6 to program DM910x operation */
646 update_cr6(db->cr6_data, ioaddr);
647
648 /* Send setup frame */
649 if (db->chip_id == PCI_DM9132_ID)
650 dm9132_id_table(dev); /* DM9132 */
651 else
652 send_filter_frame(dev); /* DM9102/DM9102A */
653
654 /* Init CR7, interrupt active bit */
655 db->cr7_data = CR7_DEFAULT;
656 dw32(DCR7, db->cr7_data);
657
658 /* Init CR15, Tx jabber and Rx watchdog timer */
659 dw32(DCR15, db->cr15_data);
660
661 /* Enable DM910X Tx/Rx function */
662 db->cr6_data |= CR6_RXSC | CR6_TXSC | 0x40000;
663 update_cr6(db->cr6_data, ioaddr);
664 }
665
666
667 /*
668 * Hardware start transmission.
669 * Send a packet to media from the upper layer.
670 */
671
dmfe_start_xmit(struct sk_buff * skb,struct net_device * dev)672 static netdev_tx_t dmfe_start_xmit(struct sk_buff *skb,
673 struct net_device *dev)
674 {
675 struct dmfe_board_info *db = netdev_priv(dev);
676 void __iomem *ioaddr = db->ioaddr;
677 struct tx_desc *txptr;
678 unsigned long flags;
679
680 DMFE_DBUG(0, "dmfe_start_xmit", 0);
681
682 /* Too large packet check */
683 if (skb->len > MAX_PACKET_SIZE) {
684 pr_err("big packet = %d\n", (u16)skb->len);
685 dev_kfree_skb_any(skb);
686 return NETDEV_TX_OK;
687 }
688
689 /* Resource flag check */
690 netif_stop_queue(dev);
691
692 spin_lock_irqsave(&db->lock, flags);
693
694 /* No Tx resource check, it never happen nromally */
695 if (db->tx_queue_cnt >= TX_FREE_DESC_CNT) {
696 spin_unlock_irqrestore(&db->lock, flags);
697 pr_err("No Tx resource %ld\n", db->tx_queue_cnt);
698 return NETDEV_TX_BUSY;
699 }
700
701 /* Disable NIC interrupt */
702 dw32(DCR7, 0);
703
704 /* transmit this packet */
705 txptr = db->tx_insert_ptr;
706 skb_copy_from_linear_data(skb, txptr->tx_buf_ptr, skb->len);
707 txptr->tdes1 = cpu_to_le32(0xe1000000 | skb->len);
708
709 /* Point to next transmit free descriptor */
710 db->tx_insert_ptr = txptr->next_tx_desc;
711
712 /* Transmit Packet Process */
713 if ( (!db->tx_queue_cnt) && (db->tx_packet_cnt < TX_MAX_SEND_CNT) ) {
714 txptr->tdes0 = cpu_to_le32(0x80000000); /* Set owner bit */
715 db->tx_packet_cnt++; /* Ready to send */
716 dw32(DCR1, 0x1); /* Issue Tx polling */
717 netif_trans_update(dev); /* saved time stamp */
718 } else {
719 db->tx_queue_cnt++; /* queue TX packet */
720 dw32(DCR1, 0x1); /* Issue Tx polling */
721 }
722
723 /* Tx resource check */
724 if ( db->tx_queue_cnt < TX_FREE_DESC_CNT )
725 netif_wake_queue(dev);
726
727 /* Restore CR7 to enable interrupt */
728 spin_unlock_irqrestore(&db->lock, flags);
729 dw32(DCR7, db->cr7_data);
730
731 /* free this SKB */
732 dev_consume_skb_any(skb);
733
734 return NETDEV_TX_OK;
735 }
736
737
738 /*
739 * Stop the interface.
740 * The interface is stopped when it is brought.
741 */
742
dmfe_stop(struct net_device * dev)743 static int dmfe_stop(struct net_device *dev)
744 {
745 struct dmfe_board_info *db = netdev_priv(dev);
746 void __iomem *ioaddr = db->ioaddr;
747
748 DMFE_DBUG(0, "dmfe_stop", 0);
749
750 /* disable system */
751 netif_stop_queue(dev);
752
753 /* deleted timer */
754 del_timer_sync(&db->timer);
755
756 /* Reset & stop DM910X board */
757 dw32(DCR0, DM910X_RESET);
758 udelay(100);
759 dmfe_phy_write(ioaddr, db->phy_addr, 0, 0x8000, db->chip_id);
760
761 /* free interrupt */
762 free_irq(db->pdev->irq, dev);
763
764 /* free allocated rx buffer */
765 dmfe_free_rxbuffer(db);
766
767 #if 0
768 /* show statistic counter */
769 printk("FU:%lx EC:%lx LC:%lx NC:%lx LOC:%lx TXJT:%lx RESET:%lx RCR8:%lx FAL:%lx TT:%lx\n",
770 db->tx_fifo_underrun, db->tx_excessive_collision,
771 db->tx_late_collision, db->tx_no_carrier, db->tx_loss_carrier,
772 db->tx_jabber_timeout, db->reset_count, db->reset_cr8,
773 db->reset_fatal, db->reset_TXtimeout);
774 #endif
775
776 return 0;
777 }
778
779
780 /*
781 * DM9102 insterrupt handler
782 * receive the packet to upper layer, free the transmitted packet
783 */
784
dmfe_interrupt(int irq,void * dev_id)785 static irqreturn_t dmfe_interrupt(int irq, void *dev_id)
786 {
787 struct net_device *dev = dev_id;
788 struct dmfe_board_info *db = netdev_priv(dev);
789 void __iomem *ioaddr = db->ioaddr;
790 unsigned long flags;
791
792 DMFE_DBUG(0, "dmfe_interrupt()", 0);
793
794 spin_lock_irqsave(&db->lock, flags);
795
796 /* Got DM910X status */
797 db->cr5_data = dr32(DCR5);
798 dw32(DCR5, db->cr5_data);
799 if ( !(db->cr5_data & 0xc1) ) {
800 spin_unlock_irqrestore(&db->lock, flags);
801 return IRQ_HANDLED;
802 }
803
804 /* Disable all interrupt in CR7 to solve the interrupt edge problem */
805 dw32(DCR7, 0);
806
807 /* Check system status */
808 if (db->cr5_data & 0x2000) {
809 /* system bus error happen */
810 DMFE_DBUG(1, "System bus error happen. CR5=", db->cr5_data);
811 db->reset_fatal++;
812 db->wait_reset = 1; /* Need to RESET */
813 spin_unlock_irqrestore(&db->lock, flags);
814 return IRQ_HANDLED;
815 }
816
817 /* Received the coming packet */
818 if ( (db->cr5_data & 0x40) && db->rx_avail_cnt )
819 dmfe_rx_packet(dev, db);
820
821 /* reallocate rx descriptor buffer */
822 if (db->rx_avail_cnt<RX_DESC_CNT)
823 allocate_rx_buffer(dev);
824
825 /* Free the transmitted descriptor */
826 if ( db->cr5_data & 0x01)
827 dmfe_free_tx_pkt(dev, db);
828
829 /* Mode Check */
830 if (db->dm910x_chk_mode & 0x2) {
831 db->dm910x_chk_mode = 0x4;
832 db->cr6_data |= 0x100;
833 update_cr6(db->cr6_data, ioaddr);
834 }
835
836 /* Restore CR7 to enable interrupt mask */
837 dw32(DCR7, db->cr7_data);
838
839 spin_unlock_irqrestore(&db->lock, flags);
840 return IRQ_HANDLED;
841 }
842
843
844 #ifdef CONFIG_NET_POLL_CONTROLLER
845 /*
846 * Polling 'interrupt' - used by things like netconsole to send skbs
847 * without having to re-enable interrupts. It's not called while
848 * the interrupt routine is executing.
849 */
850
poll_dmfe(struct net_device * dev)851 static void poll_dmfe (struct net_device *dev)
852 {
853 struct dmfe_board_info *db = netdev_priv(dev);
854 const int irq = db->pdev->irq;
855
856 /* disable_irq here is not very nice, but with the lockless
857 interrupt handler we have no other choice. */
858 disable_irq(irq);
859 dmfe_interrupt (irq, dev);
860 enable_irq(irq);
861 }
862 #endif
863
864 /*
865 * Free TX resource after TX complete
866 */
867
dmfe_free_tx_pkt(struct net_device * dev,struct dmfe_board_info * db)868 static void dmfe_free_tx_pkt(struct net_device *dev, struct dmfe_board_info *db)
869 {
870 struct tx_desc *txptr;
871 void __iomem *ioaddr = db->ioaddr;
872 u32 tdes0;
873
874 txptr = db->tx_remove_ptr;
875 while(db->tx_packet_cnt) {
876 tdes0 = le32_to_cpu(txptr->tdes0);
877 if (tdes0 & 0x80000000)
878 break;
879
880 /* A packet sent completed */
881 db->tx_packet_cnt--;
882 dev->stats.tx_packets++;
883
884 /* Transmit statistic counter */
885 if ( tdes0 != 0x7fffffff ) {
886 dev->stats.collisions += (tdes0 >> 3) & 0xf;
887 dev->stats.tx_bytes += le32_to_cpu(txptr->tdes1) & 0x7ff;
888 if (tdes0 & TDES0_ERR_MASK) {
889 dev->stats.tx_errors++;
890
891 if (tdes0 & 0x0002) { /* UnderRun */
892 db->tx_fifo_underrun++;
893 if ( !(db->cr6_data & CR6_SFT) ) {
894 db->cr6_data = db->cr6_data | CR6_SFT;
895 update_cr6(db->cr6_data, ioaddr);
896 }
897 }
898 if (tdes0 & 0x0100)
899 db->tx_excessive_collision++;
900 if (tdes0 & 0x0200)
901 db->tx_late_collision++;
902 if (tdes0 & 0x0400)
903 db->tx_no_carrier++;
904 if (tdes0 & 0x0800)
905 db->tx_loss_carrier++;
906 if (tdes0 & 0x4000)
907 db->tx_jabber_timeout++;
908 }
909 }
910
911 txptr = txptr->next_tx_desc;
912 }/* End of while */
913
914 /* Update TX remove pointer to next */
915 db->tx_remove_ptr = txptr;
916
917 /* Send the Tx packet in queue */
918 if ( (db->tx_packet_cnt < TX_MAX_SEND_CNT) && db->tx_queue_cnt ) {
919 txptr->tdes0 = cpu_to_le32(0x80000000); /* Set owner bit */
920 db->tx_packet_cnt++; /* Ready to send */
921 db->tx_queue_cnt--;
922 dw32(DCR1, 0x1); /* Issue Tx polling */
923 netif_trans_update(dev); /* saved time stamp */
924 }
925
926 /* Resource available check */
927 if ( db->tx_queue_cnt < TX_WAKE_DESC_CNT )
928 netif_wake_queue(dev); /* Active upper layer, send again */
929 }
930
931
932 /*
933 * Calculate the CRC valude of the Rx packet
934 * flag = 1 : return the reverse CRC (for the received packet CRC)
935 * 0 : return the normal CRC (for Hash Table index)
936 */
937
cal_CRC(unsigned char * Data,unsigned int Len,u8 flag)938 static inline u32 cal_CRC(unsigned char * Data, unsigned int Len, u8 flag)
939 {
940 u32 crc = crc32(~0, Data, Len);
941 if (flag) crc = ~crc;
942 return crc;
943 }
944
945
946 /*
947 * Receive the come packet and pass to upper layer
948 */
949
dmfe_rx_packet(struct net_device * dev,struct dmfe_board_info * db)950 static void dmfe_rx_packet(struct net_device *dev, struct dmfe_board_info *db)
951 {
952 struct rx_desc *rxptr;
953 struct sk_buff *skb, *newskb;
954 int rxlen;
955 u32 rdes0;
956
957 rxptr = db->rx_ready_ptr;
958
959 while(db->rx_avail_cnt) {
960 rdes0 = le32_to_cpu(rxptr->rdes0);
961 if (rdes0 & 0x80000000) /* packet owner check */
962 break;
963
964 db->rx_avail_cnt--;
965 db->interval_rx_cnt++;
966
967 pci_unmap_single(db->pdev, le32_to_cpu(rxptr->rdes2),
968 RX_ALLOC_SIZE, PCI_DMA_FROMDEVICE);
969
970 if ( (rdes0 & 0x300) != 0x300) {
971 /* A packet without First/Last flag */
972 /* reuse this SKB */
973 DMFE_DBUG(0, "Reuse SK buffer, rdes0", rdes0);
974 dmfe_reuse_skb(db, rxptr->rx_skb_ptr);
975 } else {
976 /* A packet with First/Last flag */
977 rxlen = ( (rdes0 >> 16) & 0x3fff) - 4;
978
979 /* error summary bit check */
980 if (rdes0 & 0x8000) {
981 /* This is a error packet */
982 dev->stats.rx_errors++;
983 if (rdes0 & 1)
984 dev->stats.rx_fifo_errors++;
985 if (rdes0 & 2)
986 dev->stats.rx_crc_errors++;
987 if (rdes0 & 0x80)
988 dev->stats.rx_length_errors++;
989 }
990
991 if ( !(rdes0 & 0x8000) ||
992 ((db->cr6_data & CR6_PM) && (rxlen>6)) ) {
993 skb = rxptr->rx_skb_ptr;
994
995 /* Received Packet CRC check need or not */
996 if ( (db->dm910x_chk_mode & 1) &&
997 (cal_CRC(skb->data, rxlen, 1) !=
998 (*(u32 *) (skb->data+rxlen) ))) { /* FIXME (?) */
999 /* Found a error received packet */
1000 dmfe_reuse_skb(db, rxptr->rx_skb_ptr);
1001 db->dm910x_chk_mode = 3;
1002 } else {
1003 /* Good packet, send to upper layer */
1004 /* Shorst packet used new SKB */
1005 if ((rxlen < RX_COPY_SIZE) &&
1006 ((newskb = netdev_alloc_skb(dev, rxlen + 2))
1007 != NULL)) {
1008
1009 skb = newskb;
1010 /* size less than COPY_SIZE, allocate a rxlen SKB */
1011 skb_reserve(skb, 2); /* 16byte align */
1012 skb_copy_from_linear_data(rxptr->rx_skb_ptr,
1013 skb_put(skb, rxlen),
1014 rxlen);
1015 dmfe_reuse_skb(db, rxptr->rx_skb_ptr);
1016 } else
1017 skb_put(skb, rxlen);
1018
1019 skb->protocol = eth_type_trans(skb, dev);
1020 netif_rx(skb);
1021 dev->stats.rx_packets++;
1022 dev->stats.rx_bytes += rxlen;
1023 }
1024 } else {
1025 /* Reuse SKB buffer when the packet is error */
1026 DMFE_DBUG(0, "Reuse SK buffer, rdes0", rdes0);
1027 dmfe_reuse_skb(db, rxptr->rx_skb_ptr);
1028 }
1029 }
1030
1031 rxptr = rxptr->next_rx_desc;
1032 }
1033
1034 db->rx_ready_ptr = rxptr;
1035 }
1036
1037 /*
1038 * Set DM910X multicast address
1039 */
1040
dmfe_set_filter_mode(struct net_device * dev)1041 static void dmfe_set_filter_mode(struct net_device *dev)
1042 {
1043 struct dmfe_board_info *db = netdev_priv(dev);
1044 unsigned long flags;
1045 int mc_count = netdev_mc_count(dev);
1046
1047 DMFE_DBUG(0, "dmfe_set_filter_mode()", 0);
1048 spin_lock_irqsave(&db->lock, flags);
1049
1050 if (dev->flags & IFF_PROMISC) {
1051 DMFE_DBUG(0, "Enable PROM Mode", 0);
1052 db->cr6_data |= CR6_PM | CR6_PBF;
1053 update_cr6(db->cr6_data, db->ioaddr);
1054 spin_unlock_irqrestore(&db->lock, flags);
1055 return;
1056 }
1057
1058 if (dev->flags & IFF_ALLMULTI || mc_count > DMFE_MAX_MULTICAST) {
1059 DMFE_DBUG(0, "Pass all multicast address", mc_count);
1060 db->cr6_data &= ~(CR6_PM | CR6_PBF);
1061 db->cr6_data |= CR6_PAM;
1062 spin_unlock_irqrestore(&db->lock, flags);
1063 return;
1064 }
1065
1066 DMFE_DBUG(0, "Set multicast address", mc_count);
1067 if (db->chip_id == PCI_DM9132_ID)
1068 dm9132_id_table(dev); /* DM9132 */
1069 else
1070 send_filter_frame(dev); /* DM9102/DM9102A */
1071 spin_unlock_irqrestore(&db->lock, flags);
1072 }
1073
1074 /*
1075 * Ethtool interace
1076 */
1077
dmfe_ethtool_get_drvinfo(struct net_device * dev,struct ethtool_drvinfo * info)1078 static void dmfe_ethtool_get_drvinfo(struct net_device *dev,
1079 struct ethtool_drvinfo *info)
1080 {
1081 struct dmfe_board_info *np = netdev_priv(dev);
1082
1083 strlcpy(info->driver, DRV_NAME, sizeof(info->driver));
1084 strlcpy(info->version, DRV_VERSION, sizeof(info->version));
1085 strlcpy(info->bus_info, pci_name(np->pdev), sizeof(info->bus_info));
1086 }
1087
dmfe_ethtool_set_wol(struct net_device * dev,struct ethtool_wolinfo * wolinfo)1088 static int dmfe_ethtool_set_wol(struct net_device *dev,
1089 struct ethtool_wolinfo *wolinfo)
1090 {
1091 struct dmfe_board_info *db = netdev_priv(dev);
1092
1093 if (wolinfo->wolopts & (WAKE_UCAST | WAKE_MCAST | WAKE_BCAST |
1094 WAKE_ARP | WAKE_MAGICSECURE))
1095 return -EOPNOTSUPP;
1096
1097 db->wol_mode = wolinfo->wolopts;
1098 return 0;
1099 }
1100
dmfe_ethtool_get_wol(struct net_device * dev,struct ethtool_wolinfo * wolinfo)1101 static void dmfe_ethtool_get_wol(struct net_device *dev,
1102 struct ethtool_wolinfo *wolinfo)
1103 {
1104 struct dmfe_board_info *db = netdev_priv(dev);
1105
1106 wolinfo->supported = WAKE_PHY | WAKE_MAGIC;
1107 wolinfo->wolopts = db->wol_mode;
1108 }
1109
1110
1111 static const struct ethtool_ops netdev_ethtool_ops = {
1112 .get_drvinfo = dmfe_ethtool_get_drvinfo,
1113 .get_link = ethtool_op_get_link,
1114 .set_wol = dmfe_ethtool_set_wol,
1115 .get_wol = dmfe_ethtool_get_wol,
1116 };
1117
1118 /*
1119 * A periodic timer routine
1120 * Dynamic media sense, allocate Rx buffer...
1121 */
1122
dmfe_timer(struct timer_list * t)1123 static void dmfe_timer(struct timer_list *t)
1124 {
1125 struct dmfe_board_info *db = from_timer(db, t, timer);
1126 struct net_device *dev = pci_get_drvdata(db->pdev);
1127 void __iomem *ioaddr = db->ioaddr;
1128 u32 tmp_cr8;
1129 unsigned char tmp_cr12;
1130 unsigned long flags;
1131
1132 int link_ok, link_ok_phy;
1133
1134 DMFE_DBUG(0, "dmfe_timer()", 0);
1135 spin_lock_irqsave(&db->lock, flags);
1136
1137 /* Media mode process when Link OK before enter this route */
1138 if (db->first_in_callback == 0) {
1139 db->first_in_callback = 1;
1140 if (db->chip_type && (db->chip_id==PCI_DM9102_ID)) {
1141 db->cr6_data &= ~0x40000;
1142 update_cr6(db->cr6_data, ioaddr);
1143 dmfe_phy_write(ioaddr, db->phy_addr, 0, 0x1000, db->chip_id);
1144 db->cr6_data |= 0x40000;
1145 update_cr6(db->cr6_data, ioaddr);
1146 db->timer.expires = DMFE_TIMER_WUT + HZ * 2;
1147 add_timer(&db->timer);
1148 spin_unlock_irqrestore(&db->lock, flags);
1149 return;
1150 }
1151 }
1152
1153
1154 /* Operating Mode Check */
1155 if ( (db->dm910x_chk_mode & 0x1) &&
1156 (dev->stats.rx_packets > MAX_CHECK_PACKET) )
1157 db->dm910x_chk_mode = 0x4;
1158
1159 /* Dynamic reset DM910X : system error or transmit time-out */
1160 tmp_cr8 = dr32(DCR8);
1161 if ( (db->interval_rx_cnt==0) && (tmp_cr8) ) {
1162 db->reset_cr8++;
1163 db->wait_reset = 1;
1164 }
1165 db->interval_rx_cnt = 0;
1166
1167 /* TX polling kick monitor */
1168 if ( db->tx_packet_cnt &&
1169 time_after(jiffies, dev_trans_start(dev) + DMFE_TX_KICK) ) {
1170 dw32(DCR1, 0x1); /* Tx polling again */
1171
1172 /* TX Timeout */
1173 if (time_after(jiffies, dev_trans_start(dev) + DMFE_TX_TIMEOUT) ) {
1174 db->reset_TXtimeout++;
1175 db->wait_reset = 1;
1176 dev_warn(&dev->dev, "Tx timeout - resetting\n");
1177 }
1178 }
1179
1180 if (db->wait_reset) {
1181 DMFE_DBUG(0, "Dynamic Reset device", db->tx_packet_cnt);
1182 db->reset_count++;
1183 dmfe_dynamic_reset(dev);
1184 db->first_in_callback = 0;
1185 db->timer.expires = DMFE_TIMER_WUT;
1186 add_timer(&db->timer);
1187 spin_unlock_irqrestore(&db->lock, flags);
1188 return;
1189 }
1190
1191 /* Link status check, Dynamic media type change */
1192 if (db->chip_id == PCI_DM9132_ID)
1193 tmp_cr12 = dr8(DCR9 + 3); /* DM9132 */
1194 else
1195 tmp_cr12 = dr8(DCR12); /* DM9102/DM9102A */
1196
1197 if ( ((db->chip_id == PCI_DM9102_ID) &&
1198 (db->chip_revision == 0x30)) ||
1199 ((db->chip_id == PCI_DM9132_ID) &&
1200 (db->chip_revision == 0x10)) ) {
1201 /* DM9102A Chip */
1202 if (tmp_cr12 & 2)
1203 link_ok = 0;
1204 else
1205 link_ok = 1;
1206 }
1207 else
1208 /*0x43 is used instead of 0x3 because bit 6 should represent
1209 link status of external PHY */
1210 link_ok = (tmp_cr12 & 0x43) ? 1 : 0;
1211
1212
1213 /* If chip reports that link is failed it could be because external
1214 PHY link status pin is not connected correctly to chip
1215 To be sure ask PHY too.
1216 */
1217
1218 /* need a dummy read because of PHY's register latch*/
1219 dmfe_phy_read (db->ioaddr, db->phy_addr, 1, db->chip_id);
1220 link_ok_phy = (dmfe_phy_read (db->ioaddr,
1221 db->phy_addr, 1, db->chip_id) & 0x4) ? 1 : 0;
1222
1223 if (link_ok_phy != link_ok) {
1224 DMFE_DBUG (0, "PHY and chip report different link status", 0);
1225 link_ok = link_ok | link_ok_phy;
1226 }
1227
1228 if ( !link_ok && netif_carrier_ok(dev)) {
1229 /* Link Failed */
1230 DMFE_DBUG(0, "Link Failed", tmp_cr12);
1231 netif_carrier_off(dev);
1232
1233 /* For Force 10/100M Half/Full mode: Enable Auto-Nego mode */
1234 /* AUTO or force 1M Homerun/Longrun don't need */
1235 if ( !(db->media_mode & 0x38) )
1236 dmfe_phy_write(db->ioaddr, db->phy_addr,
1237 0, 0x1000, db->chip_id);
1238
1239 /* AUTO mode, if INT phyxcer link failed, select EXT device */
1240 if (db->media_mode & DMFE_AUTO) {
1241 /* 10/100M link failed, used 1M Home-Net */
1242 db->cr6_data|=0x00040000; /* bit18=1, MII */
1243 db->cr6_data&=~0x00000200; /* bit9=0, HD mode */
1244 update_cr6(db->cr6_data, ioaddr);
1245 }
1246 } else if (!netif_carrier_ok(dev)) {
1247
1248 DMFE_DBUG(0, "Link link OK", tmp_cr12);
1249
1250 /* Auto Sense Speed */
1251 if ( !(db->media_mode & DMFE_AUTO) || !dmfe_sense_speed(db)) {
1252 netif_carrier_on(dev);
1253 SHOW_MEDIA_TYPE(db->op_mode);
1254 }
1255
1256 dmfe_process_mode(db);
1257 }
1258
1259 /* HPNA remote command check */
1260 if (db->HPNA_command & 0xf00) {
1261 db->HPNA_timer--;
1262 if (!db->HPNA_timer)
1263 dmfe_HPNA_remote_cmd_chk(db);
1264 }
1265
1266 /* Timer active again */
1267 db->timer.expires = DMFE_TIMER_WUT;
1268 add_timer(&db->timer);
1269 spin_unlock_irqrestore(&db->lock, flags);
1270 }
1271
1272
1273 /*
1274 * Dynamic reset the DM910X board
1275 * Stop DM910X board
1276 * Free Tx/Rx allocated memory
1277 * Reset DM910X board
1278 * Re-initialize DM910X board
1279 */
1280
dmfe_dynamic_reset(struct net_device * dev)1281 static void dmfe_dynamic_reset(struct net_device *dev)
1282 {
1283 struct dmfe_board_info *db = netdev_priv(dev);
1284 void __iomem *ioaddr = db->ioaddr;
1285
1286 DMFE_DBUG(0, "dmfe_dynamic_reset()", 0);
1287
1288 /* Sopt MAC controller */
1289 db->cr6_data &= ~(CR6_RXSC | CR6_TXSC); /* Disable Tx/Rx */
1290 update_cr6(db->cr6_data, ioaddr);
1291 dw32(DCR7, 0); /* Disable Interrupt */
1292 dw32(DCR5, dr32(DCR5));
1293
1294 /* Disable upper layer interface */
1295 netif_stop_queue(dev);
1296
1297 /* Free Rx Allocate buffer */
1298 dmfe_free_rxbuffer(db);
1299
1300 /* system variable init */
1301 db->tx_packet_cnt = 0;
1302 db->tx_queue_cnt = 0;
1303 db->rx_avail_cnt = 0;
1304 netif_carrier_off(dev);
1305 db->wait_reset = 0;
1306
1307 /* Re-initialize DM910X board */
1308 dmfe_init_dm910x(dev);
1309
1310 /* Restart upper layer interface */
1311 netif_wake_queue(dev);
1312 }
1313
1314
1315 /*
1316 * free all allocated rx buffer
1317 */
1318
dmfe_free_rxbuffer(struct dmfe_board_info * db)1319 static void dmfe_free_rxbuffer(struct dmfe_board_info * db)
1320 {
1321 DMFE_DBUG(0, "dmfe_free_rxbuffer()", 0);
1322
1323 /* free allocated rx buffer */
1324 while (db->rx_avail_cnt) {
1325 dev_kfree_skb(db->rx_ready_ptr->rx_skb_ptr);
1326 db->rx_ready_ptr = db->rx_ready_ptr->next_rx_desc;
1327 db->rx_avail_cnt--;
1328 }
1329 }
1330
1331
1332 /*
1333 * Reuse the SK buffer
1334 */
1335
dmfe_reuse_skb(struct dmfe_board_info * db,struct sk_buff * skb)1336 static void dmfe_reuse_skb(struct dmfe_board_info *db, struct sk_buff * skb)
1337 {
1338 struct rx_desc *rxptr = db->rx_insert_ptr;
1339
1340 if (!(rxptr->rdes0 & cpu_to_le32(0x80000000))) {
1341 rxptr->rx_skb_ptr = skb;
1342 rxptr->rdes2 = cpu_to_le32( pci_map_single(db->pdev,
1343 skb->data, RX_ALLOC_SIZE, PCI_DMA_FROMDEVICE) );
1344 wmb();
1345 rxptr->rdes0 = cpu_to_le32(0x80000000);
1346 db->rx_avail_cnt++;
1347 db->rx_insert_ptr = rxptr->next_rx_desc;
1348 } else
1349 DMFE_DBUG(0, "SK Buffer reuse method error", db->rx_avail_cnt);
1350 }
1351
1352
1353 /*
1354 * Initialize transmit/Receive descriptor
1355 * Using Chain structure, and allocate Tx/Rx buffer
1356 */
1357
dmfe_descriptor_init(struct net_device * dev)1358 static void dmfe_descriptor_init(struct net_device *dev)
1359 {
1360 struct dmfe_board_info *db = netdev_priv(dev);
1361 void __iomem *ioaddr = db->ioaddr;
1362 struct tx_desc *tmp_tx;
1363 struct rx_desc *tmp_rx;
1364 unsigned char *tmp_buf;
1365 dma_addr_t tmp_tx_dma, tmp_rx_dma;
1366 dma_addr_t tmp_buf_dma;
1367 int i;
1368
1369 DMFE_DBUG(0, "dmfe_descriptor_init()", 0);
1370
1371 /* tx descriptor start pointer */
1372 db->tx_insert_ptr = db->first_tx_desc;
1373 db->tx_remove_ptr = db->first_tx_desc;
1374 dw32(DCR4, db->first_tx_desc_dma); /* TX DESC address */
1375
1376 /* rx descriptor start pointer */
1377 db->first_rx_desc = (void *)db->first_tx_desc +
1378 sizeof(struct tx_desc) * TX_DESC_CNT;
1379
1380 db->first_rx_desc_dma = db->first_tx_desc_dma +
1381 sizeof(struct tx_desc) * TX_DESC_CNT;
1382 db->rx_insert_ptr = db->first_rx_desc;
1383 db->rx_ready_ptr = db->first_rx_desc;
1384 dw32(DCR3, db->first_rx_desc_dma); /* RX DESC address */
1385
1386 /* Init Transmit chain */
1387 tmp_buf = db->buf_pool_start;
1388 tmp_buf_dma = db->buf_pool_dma_start;
1389 tmp_tx_dma = db->first_tx_desc_dma;
1390 for (tmp_tx = db->first_tx_desc, i = 0; i < TX_DESC_CNT; i++, tmp_tx++) {
1391 tmp_tx->tx_buf_ptr = tmp_buf;
1392 tmp_tx->tdes0 = cpu_to_le32(0);
1393 tmp_tx->tdes1 = cpu_to_le32(0x81000000); /* IC, chain */
1394 tmp_tx->tdes2 = cpu_to_le32(tmp_buf_dma);
1395 tmp_tx_dma += sizeof(struct tx_desc);
1396 tmp_tx->tdes3 = cpu_to_le32(tmp_tx_dma);
1397 tmp_tx->next_tx_desc = tmp_tx + 1;
1398 tmp_buf = tmp_buf + TX_BUF_ALLOC;
1399 tmp_buf_dma = tmp_buf_dma + TX_BUF_ALLOC;
1400 }
1401 (--tmp_tx)->tdes3 = cpu_to_le32(db->first_tx_desc_dma);
1402 tmp_tx->next_tx_desc = db->first_tx_desc;
1403
1404 /* Init Receive descriptor chain */
1405 tmp_rx_dma=db->first_rx_desc_dma;
1406 for (tmp_rx = db->first_rx_desc, i = 0; i < RX_DESC_CNT; i++, tmp_rx++) {
1407 tmp_rx->rdes0 = cpu_to_le32(0);
1408 tmp_rx->rdes1 = cpu_to_le32(0x01000600);
1409 tmp_rx_dma += sizeof(struct rx_desc);
1410 tmp_rx->rdes3 = cpu_to_le32(tmp_rx_dma);
1411 tmp_rx->next_rx_desc = tmp_rx + 1;
1412 }
1413 (--tmp_rx)->rdes3 = cpu_to_le32(db->first_rx_desc_dma);
1414 tmp_rx->next_rx_desc = db->first_rx_desc;
1415
1416 /* pre-allocate Rx buffer */
1417 allocate_rx_buffer(dev);
1418 }
1419
1420
1421 /*
1422 * Update CR6 value
1423 * Firstly stop DM910X , then written value and start
1424 */
1425
update_cr6(u32 cr6_data,void __iomem * ioaddr)1426 static void update_cr6(u32 cr6_data, void __iomem *ioaddr)
1427 {
1428 u32 cr6_tmp;
1429
1430 cr6_tmp = cr6_data & ~0x2002; /* stop Tx/Rx */
1431 dw32(DCR6, cr6_tmp);
1432 udelay(5);
1433 dw32(DCR6, cr6_data);
1434 udelay(5);
1435 }
1436
1437
1438 /*
1439 * Send a setup frame for DM9132
1440 * This setup frame initialize DM910X address filter mode
1441 */
1442
dm9132_id_table(struct net_device * dev)1443 static void dm9132_id_table(struct net_device *dev)
1444 {
1445 struct dmfe_board_info *db = netdev_priv(dev);
1446 void __iomem *ioaddr = db->ioaddr + 0xc0;
1447 u16 *addrptr = (u16 *)dev->dev_addr;
1448 struct netdev_hw_addr *ha;
1449 u16 i, hash_table[4];
1450
1451 /* Node address */
1452 for (i = 0; i < 3; i++) {
1453 dw16(0, addrptr[i]);
1454 ioaddr += 4;
1455 }
1456
1457 /* Clear Hash Table */
1458 memset(hash_table, 0, sizeof(hash_table));
1459
1460 /* broadcast address */
1461 hash_table[3] = 0x8000;
1462
1463 /* the multicast address in Hash Table : 64 bits */
1464 netdev_for_each_mc_addr(ha, dev) {
1465 u32 hash_val = cal_CRC((char *)ha->addr, 6, 0) & 0x3f;
1466
1467 hash_table[hash_val / 16] |= (u16) 1 << (hash_val % 16);
1468 }
1469
1470 /* Write the hash table to MAC MD table */
1471 for (i = 0; i < 4; i++, ioaddr += 4)
1472 dw16(0, hash_table[i]);
1473 }
1474
1475
1476 /*
1477 * Send a setup frame for DM9102/DM9102A
1478 * This setup frame initialize DM910X address filter mode
1479 */
1480
send_filter_frame(struct net_device * dev)1481 static void send_filter_frame(struct net_device *dev)
1482 {
1483 struct dmfe_board_info *db = netdev_priv(dev);
1484 struct netdev_hw_addr *ha;
1485 struct tx_desc *txptr;
1486 u16 * addrptr;
1487 u32 * suptr;
1488 int i;
1489
1490 DMFE_DBUG(0, "send_filter_frame()", 0);
1491
1492 txptr = db->tx_insert_ptr;
1493 suptr = (u32 *) txptr->tx_buf_ptr;
1494
1495 /* Node address */
1496 addrptr = (u16 *) dev->dev_addr;
1497 *suptr++ = addrptr[0];
1498 *suptr++ = addrptr[1];
1499 *suptr++ = addrptr[2];
1500
1501 /* broadcast address */
1502 *suptr++ = 0xffff;
1503 *suptr++ = 0xffff;
1504 *suptr++ = 0xffff;
1505
1506 /* fit the multicast address */
1507 netdev_for_each_mc_addr(ha, dev) {
1508 addrptr = (u16 *) ha->addr;
1509 *suptr++ = addrptr[0];
1510 *suptr++ = addrptr[1];
1511 *suptr++ = addrptr[2];
1512 }
1513
1514 for (i = netdev_mc_count(dev); i < 14; i++) {
1515 *suptr++ = 0xffff;
1516 *suptr++ = 0xffff;
1517 *suptr++ = 0xffff;
1518 }
1519
1520 /* prepare the setup frame */
1521 db->tx_insert_ptr = txptr->next_tx_desc;
1522 txptr->tdes1 = cpu_to_le32(0x890000c0);
1523
1524 /* Resource Check and Send the setup packet */
1525 if (!db->tx_packet_cnt) {
1526 void __iomem *ioaddr = db->ioaddr;
1527
1528 /* Resource Empty */
1529 db->tx_packet_cnt++;
1530 txptr->tdes0 = cpu_to_le32(0x80000000);
1531 update_cr6(db->cr6_data | 0x2000, ioaddr);
1532 dw32(DCR1, 0x1); /* Issue Tx polling */
1533 update_cr6(db->cr6_data, ioaddr);
1534 netif_trans_update(dev);
1535 } else
1536 db->tx_queue_cnt++; /* Put in TX queue */
1537 }
1538
1539
1540 /*
1541 * Allocate rx buffer,
1542 * As possible as allocate maxiumn Rx buffer
1543 */
1544
allocate_rx_buffer(struct net_device * dev)1545 static void allocate_rx_buffer(struct net_device *dev)
1546 {
1547 struct dmfe_board_info *db = netdev_priv(dev);
1548 struct rx_desc *rxptr;
1549 struct sk_buff *skb;
1550
1551 rxptr = db->rx_insert_ptr;
1552
1553 while(db->rx_avail_cnt < RX_DESC_CNT) {
1554 if ( ( skb = netdev_alloc_skb(dev, RX_ALLOC_SIZE) ) == NULL )
1555 break;
1556 rxptr->rx_skb_ptr = skb; /* FIXME (?) */
1557 rxptr->rdes2 = cpu_to_le32( pci_map_single(db->pdev, skb->data,
1558 RX_ALLOC_SIZE, PCI_DMA_FROMDEVICE) );
1559 wmb();
1560 rxptr->rdes0 = cpu_to_le32(0x80000000);
1561 rxptr = rxptr->next_rx_desc;
1562 db->rx_avail_cnt++;
1563 }
1564
1565 db->rx_insert_ptr = rxptr;
1566 }
1567
srom_clk_write(void __iomem * ioaddr,u32 data)1568 static void srom_clk_write(void __iomem *ioaddr, u32 data)
1569 {
1570 static const u32 cmd[] = {
1571 CR9_SROM_READ | CR9_SRCS,
1572 CR9_SROM_READ | CR9_SRCS | CR9_SRCLK,
1573 CR9_SROM_READ | CR9_SRCS
1574 };
1575 int i;
1576
1577 for (i = 0; i < ARRAY_SIZE(cmd); i++) {
1578 dw32(DCR9, data | cmd[i]);
1579 udelay(5);
1580 }
1581 }
1582
1583 /*
1584 * Read one word data from the serial ROM
1585 */
read_srom_word(void __iomem * ioaddr,int offset)1586 static u16 read_srom_word(void __iomem *ioaddr, int offset)
1587 {
1588 u16 srom_data;
1589 int i;
1590
1591 dw32(DCR9, CR9_SROM_READ);
1592 udelay(5);
1593 dw32(DCR9, CR9_SROM_READ | CR9_SRCS);
1594 udelay(5);
1595
1596 /* Send the Read Command 110b */
1597 srom_clk_write(ioaddr, SROM_DATA_1);
1598 srom_clk_write(ioaddr, SROM_DATA_1);
1599 srom_clk_write(ioaddr, SROM_DATA_0);
1600
1601 /* Send the offset */
1602 for (i = 5; i >= 0; i--) {
1603 srom_data = (offset & (1 << i)) ? SROM_DATA_1 : SROM_DATA_0;
1604 srom_clk_write(ioaddr, srom_data);
1605 }
1606
1607 dw32(DCR9, CR9_SROM_READ | CR9_SRCS);
1608 udelay(5);
1609
1610 for (i = 16; i > 0; i--) {
1611 dw32(DCR9, CR9_SROM_READ | CR9_SRCS | CR9_SRCLK);
1612 udelay(5);
1613 srom_data = (srom_data << 1) |
1614 ((dr32(DCR9) & CR9_CRDOUT) ? 1 : 0);
1615 dw32(DCR9, CR9_SROM_READ | CR9_SRCS);
1616 udelay(5);
1617 }
1618
1619 dw32(DCR9, CR9_SROM_READ);
1620 udelay(5);
1621 return srom_data;
1622 }
1623
1624
1625 /*
1626 * Auto sense the media mode
1627 */
1628
dmfe_sense_speed(struct dmfe_board_info * db)1629 static u8 dmfe_sense_speed(struct dmfe_board_info *db)
1630 {
1631 void __iomem *ioaddr = db->ioaddr;
1632 u8 ErrFlag = 0;
1633 u16 phy_mode;
1634
1635 /* CR6 bit18=0, select 10/100M */
1636 update_cr6(db->cr6_data & ~0x40000, ioaddr);
1637
1638 phy_mode = dmfe_phy_read(db->ioaddr, db->phy_addr, 1, db->chip_id);
1639 phy_mode = dmfe_phy_read(db->ioaddr, db->phy_addr, 1, db->chip_id);
1640
1641 if ( (phy_mode & 0x24) == 0x24 ) {
1642 if (db->chip_id == PCI_DM9132_ID) /* DM9132 */
1643 phy_mode = dmfe_phy_read(db->ioaddr,
1644 db->phy_addr, 7, db->chip_id) & 0xf000;
1645 else /* DM9102/DM9102A */
1646 phy_mode = dmfe_phy_read(db->ioaddr,
1647 db->phy_addr, 17, db->chip_id) & 0xf000;
1648 switch (phy_mode) {
1649 case 0x1000: db->op_mode = DMFE_10MHF; break;
1650 case 0x2000: db->op_mode = DMFE_10MFD; break;
1651 case 0x4000: db->op_mode = DMFE_100MHF; break;
1652 case 0x8000: db->op_mode = DMFE_100MFD; break;
1653 default: db->op_mode = DMFE_10MHF;
1654 ErrFlag = 1;
1655 break;
1656 }
1657 } else {
1658 db->op_mode = DMFE_10MHF;
1659 DMFE_DBUG(0, "Link Failed :", phy_mode);
1660 ErrFlag = 1;
1661 }
1662
1663 return ErrFlag;
1664 }
1665
1666
1667 /*
1668 * Set 10/100 phyxcer capability
1669 * AUTO mode : phyxcer register4 is NIC capability
1670 * Force mode: phyxcer register4 is the force media
1671 */
1672
dmfe_set_phyxcer(struct dmfe_board_info * db)1673 static void dmfe_set_phyxcer(struct dmfe_board_info *db)
1674 {
1675 void __iomem *ioaddr = db->ioaddr;
1676 u16 phy_reg;
1677
1678 /* Select 10/100M phyxcer */
1679 db->cr6_data &= ~0x40000;
1680 update_cr6(db->cr6_data, ioaddr);
1681
1682 /* DM9009 Chip: Phyxcer reg18 bit12=0 */
1683 if (db->chip_id == PCI_DM9009_ID) {
1684 phy_reg = dmfe_phy_read(db->ioaddr,
1685 db->phy_addr, 18, db->chip_id) & ~0x1000;
1686
1687 dmfe_phy_write(db->ioaddr,
1688 db->phy_addr, 18, phy_reg, db->chip_id);
1689 }
1690
1691 /* Phyxcer capability setting */
1692 phy_reg = dmfe_phy_read(db->ioaddr, db->phy_addr, 4, db->chip_id) & ~0x01e0;
1693
1694 if (db->media_mode & DMFE_AUTO) {
1695 /* AUTO Mode */
1696 phy_reg |= db->PHY_reg4;
1697 } else {
1698 /* Force Mode */
1699 switch(db->media_mode) {
1700 case DMFE_10MHF: phy_reg |= 0x20; break;
1701 case DMFE_10MFD: phy_reg |= 0x40; break;
1702 case DMFE_100MHF: phy_reg |= 0x80; break;
1703 case DMFE_100MFD: phy_reg |= 0x100; break;
1704 }
1705 if (db->chip_id == PCI_DM9009_ID) phy_reg &= 0x61;
1706 }
1707
1708 /* Write new capability to Phyxcer Reg4 */
1709 if ( !(phy_reg & 0x01e0)) {
1710 phy_reg|=db->PHY_reg4;
1711 db->media_mode|=DMFE_AUTO;
1712 }
1713 dmfe_phy_write(db->ioaddr, db->phy_addr, 4, phy_reg, db->chip_id);
1714
1715 /* Restart Auto-Negotiation */
1716 if ( db->chip_type && (db->chip_id == PCI_DM9102_ID) )
1717 dmfe_phy_write(db->ioaddr, db->phy_addr, 0, 0x1800, db->chip_id);
1718 if ( !db->chip_type )
1719 dmfe_phy_write(db->ioaddr, db->phy_addr, 0, 0x1200, db->chip_id);
1720 }
1721
1722
1723 /*
1724 * Process op-mode
1725 * AUTO mode : PHY controller in Auto-negotiation Mode
1726 * Force mode: PHY controller in force mode with HUB
1727 * N-way force capability with SWITCH
1728 */
1729
dmfe_process_mode(struct dmfe_board_info * db)1730 static void dmfe_process_mode(struct dmfe_board_info *db)
1731 {
1732 u16 phy_reg;
1733
1734 /* Full Duplex Mode Check */
1735 if (db->op_mode & 0x4)
1736 db->cr6_data |= CR6_FDM; /* Set Full Duplex Bit */
1737 else
1738 db->cr6_data &= ~CR6_FDM; /* Clear Full Duplex Bit */
1739
1740 /* Transciver Selection */
1741 if (db->op_mode & 0x10) /* 1M HomePNA */
1742 db->cr6_data |= 0x40000;/* External MII select */
1743 else
1744 db->cr6_data &= ~0x40000;/* Internal 10/100 transciver */
1745
1746 update_cr6(db->cr6_data, db->ioaddr);
1747
1748 /* 10/100M phyxcer force mode need */
1749 if ( !(db->media_mode & 0x18)) {
1750 /* Forece Mode */
1751 phy_reg = dmfe_phy_read(db->ioaddr, db->phy_addr, 6, db->chip_id);
1752 if ( !(phy_reg & 0x1) ) {
1753 /* parter without N-Way capability */
1754 phy_reg = 0x0;
1755 switch(db->op_mode) {
1756 case DMFE_10MHF: phy_reg = 0x0; break;
1757 case DMFE_10MFD: phy_reg = 0x100; break;
1758 case DMFE_100MHF: phy_reg = 0x2000; break;
1759 case DMFE_100MFD: phy_reg = 0x2100; break;
1760 }
1761 dmfe_phy_write(db->ioaddr,
1762 db->phy_addr, 0, phy_reg, db->chip_id);
1763 if ( db->chip_type && (db->chip_id == PCI_DM9102_ID) )
1764 mdelay(20);
1765 dmfe_phy_write(db->ioaddr,
1766 db->phy_addr, 0, phy_reg, db->chip_id);
1767 }
1768 }
1769 }
1770
1771
1772 /*
1773 * Write a word to Phy register
1774 */
1775
dmfe_phy_write(void __iomem * ioaddr,u8 phy_addr,u8 offset,u16 phy_data,u32 chip_id)1776 static void dmfe_phy_write(void __iomem *ioaddr, u8 phy_addr, u8 offset,
1777 u16 phy_data, u32 chip_id)
1778 {
1779 u16 i;
1780
1781 if (chip_id == PCI_DM9132_ID) {
1782 dw16(0x80 + offset * 4, phy_data);
1783 } else {
1784 /* DM9102/DM9102A Chip */
1785
1786 /* Send 33 synchronization clock to Phy controller */
1787 for (i = 0; i < 35; i++)
1788 dmfe_phy_write_1bit(ioaddr, PHY_DATA_1);
1789
1790 /* Send start command(01) to Phy */
1791 dmfe_phy_write_1bit(ioaddr, PHY_DATA_0);
1792 dmfe_phy_write_1bit(ioaddr, PHY_DATA_1);
1793
1794 /* Send write command(01) to Phy */
1795 dmfe_phy_write_1bit(ioaddr, PHY_DATA_0);
1796 dmfe_phy_write_1bit(ioaddr, PHY_DATA_1);
1797
1798 /* Send Phy address */
1799 for (i = 0x10; i > 0; i = i >> 1)
1800 dmfe_phy_write_1bit(ioaddr,
1801 phy_addr & i ? PHY_DATA_1 : PHY_DATA_0);
1802
1803 /* Send register address */
1804 for (i = 0x10; i > 0; i = i >> 1)
1805 dmfe_phy_write_1bit(ioaddr,
1806 offset & i ? PHY_DATA_1 : PHY_DATA_0);
1807
1808 /* written trasnition */
1809 dmfe_phy_write_1bit(ioaddr, PHY_DATA_1);
1810 dmfe_phy_write_1bit(ioaddr, PHY_DATA_0);
1811
1812 /* Write a word data to PHY controller */
1813 for ( i = 0x8000; i > 0; i >>= 1)
1814 dmfe_phy_write_1bit(ioaddr,
1815 phy_data & i ? PHY_DATA_1 : PHY_DATA_0);
1816 }
1817 }
1818
1819
1820 /*
1821 * Read a word data from phy register
1822 */
1823
dmfe_phy_read(void __iomem * ioaddr,u8 phy_addr,u8 offset,u32 chip_id)1824 static u16 dmfe_phy_read(void __iomem *ioaddr, u8 phy_addr, u8 offset, u32 chip_id)
1825 {
1826 int i;
1827 u16 phy_data;
1828
1829 if (chip_id == PCI_DM9132_ID) {
1830 /* DM9132 Chip */
1831 phy_data = dr16(0x80 + offset * 4);
1832 } else {
1833 /* DM9102/DM9102A Chip */
1834
1835 /* Send 33 synchronization clock to Phy controller */
1836 for (i = 0; i < 35; i++)
1837 dmfe_phy_write_1bit(ioaddr, PHY_DATA_1);
1838
1839 /* Send start command(01) to Phy */
1840 dmfe_phy_write_1bit(ioaddr, PHY_DATA_0);
1841 dmfe_phy_write_1bit(ioaddr, PHY_DATA_1);
1842
1843 /* Send read command(10) to Phy */
1844 dmfe_phy_write_1bit(ioaddr, PHY_DATA_1);
1845 dmfe_phy_write_1bit(ioaddr, PHY_DATA_0);
1846
1847 /* Send Phy address */
1848 for (i = 0x10; i > 0; i = i >> 1)
1849 dmfe_phy_write_1bit(ioaddr,
1850 phy_addr & i ? PHY_DATA_1 : PHY_DATA_0);
1851
1852 /* Send register address */
1853 for (i = 0x10; i > 0; i = i >> 1)
1854 dmfe_phy_write_1bit(ioaddr,
1855 offset & i ? PHY_DATA_1 : PHY_DATA_0);
1856
1857 /* Skip transition state */
1858 dmfe_phy_read_1bit(ioaddr);
1859
1860 /* read 16bit data */
1861 for (phy_data = 0, i = 0; i < 16; i++) {
1862 phy_data <<= 1;
1863 phy_data |= dmfe_phy_read_1bit(ioaddr);
1864 }
1865 }
1866
1867 return phy_data;
1868 }
1869
1870
1871 /*
1872 * Write one bit data to Phy Controller
1873 */
1874
dmfe_phy_write_1bit(void __iomem * ioaddr,u32 phy_data)1875 static void dmfe_phy_write_1bit(void __iomem *ioaddr, u32 phy_data)
1876 {
1877 dw32(DCR9, phy_data); /* MII Clock Low */
1878 udelay(1);
1879 dw32(DCR9, phy_data | MDCLKH); /* MII Clock High */
1880 udelay(1);
1881 dw32(DCR9, phy_data); /* MII Clock Low */
1882 udelay(1);
1883 }
1884
1885
1886 /*
1887 * Read one bit phy data from PHY controller
1888 */
1889
dmfe_phy_read_1bit(void __iomem * ioaddr)1890 static u16 dmfe_phy_read_1bit(void __iomem *ioaddr)
1891 {
1892 u16 phy_data;
1893
1894 dw32(DCR9, 0x50000);
1895 udelay(1);
1896 phy_data = (dr32(DCR9) >> 19) & 0x1;
1897 dw32(DCR9, 0x40000);
1898 udelay(1);
1899
1900 return phy_data;
1901 }
1902
1903
1904 /*
1905 * Parser SROM and media mode
1906 */
1907
dmfe_parse_srom(struct dmfe_board_info * db)1908 static void dmfe_parse_srom(struct dmfe_board_info * db)
1909 {
1910 char * srom = db->srom;
1911 int dmfe_mode, tmp_reg;
1912
1913 DMFE_DBUG(0, "dmfe_parse_srom() ", 0);
1914
1915 /* Init CR15 */
1916 db->cr15_data = CR15_DEFAULT;
1917
1918 /* Check SROM Version */
1919 if ( ( (int) srom[18] & 0xff) == SROM_V41_CODE) {
1920 /* SROM V4.01 */
1921 /* Get NIC support media mode */
1922 db->NIC_capability = le16_to_cpup((__le16 *) (srom + 34));
1923 db->PHY_reg4 = 0;
1924 for (tmp_reg = 1; tmp_reg < 0x10; tmp_reg <<= 1) {
1925 switch( db->NIC_capability & tmp_reg ) {
1926 case 0x1: db->PHY_reg4 |= 0x0020; break;
1927 case 0x2: db->PHY_reg4 |= 0x0040; break;
1928 case 0x4: db->PHY_reg4 |= 0x0080; break;
1929 case 0x8: db->PHY_reg4 |= 0x0100; break;
1930 }
1931 }
1932
1933 /* Media Mode Force or not check */
1934 dmfe_mode = (le32_to_cpup((__le32 *) (srom + 34)) &
1935 le32_to_cpup((__le32 *) (srom + 36)));
1936 switch(dmfe_mode) {
1937 case 0x4: dmfe_media_mode = DMFE_100MHF; break; /* 100MHF */
1938 case 0x2: dmfe_media_mode = DMFE_10MFD; break; /* 10MFD */
1939 case 0x8: dmfe_media_mode = DMFE_100MFD; break; /* 100MFD */
1940 case 0x100:
1941 case 0x200: dmfe_media_mode = DMFE_1M_HPNA; break;/* HomePNA */
1942 }
1943
1944 /* Special Function setting */
1945 /* VLAN function */
1946 if ( (SF_mode & 0x1) || (srom[43] & 0x80) )
1947 db->cr15_data |= 0x40;
1948
1949 /* Flow Control */
1950 if ( (SF_mode & 0x2) || (srom[40] & 0x1) )
1951 db->cr15_data |= 0x400;
1952
1953 /* TX pause packet */
1954 if ( (SF_mode & 0x4) || (srom[40] & 0xe) )
1955 db->cr15_data |= 0x9800;
1956 }
1957
1958 /* Parse HPNA parameter */
1959 db->HPNA_command = 1;
1960
1961 /* Accept remote command or not */
1962 if (HPNA_rx_cmd == 0)
1963 db->HPNA_command |= 0x8000;
1964
1965 /* Issue remote command & operation mode */
1966 if (HPNA_tx_cmd == 1)
1967 switch(HPNA_mode) { /* Issue Remote Command */
1968 case 0: db->HPNA_command |= 0x0904; break;
1969 case 1: db->HPNA_command |= 0x0a00; break;
1970 case 2: db->HPNA_command |= 0x0506; break;
1971 case 3: db->HPNA_command |= 0x0602; break;
1972 }
1973 else
1974 switch(HPNA_mode) { /* Don't Issue */
1975 case 0: db->HPNA_command |= 0x0004; break;
1976 case 1: db->HPNA_command |= 0x0000; break;
1977 case 2: db->HPNA_command |= 0x0006; break;
1978 case 3: db->HPNA_command |= 0x0002; break;
1979 }
1980
1981 /* Check DM9801 or DM9802 present or not */
1982 db->HPNA_present = 0;
1983 update_cr6(db->cr6_data | 0x40000, db->ioaddr);
1984 tmp_reg = dmfe_phy_read(db->ioaddr, db->phy_addr, 3, db->chip_id);
1985 if ( ( tmp_reg & 0xfff0 ) == 0xb900 ) {
1986 /* DM9801 or DM9802 present */
1987 db->HPNA_timer = 8;
1988 if ( dmfe_phy_read(db->ioaddr, db->phy_addr, 31, db->chip_id) == 0x4404) {
1989 /* DM9801 HomeRun */
1990 db->HPNA_present = 1;
1991 dmfe_program_DM9801(db, tmp_reg);
1992 } else {
1993 /* DM9802 LongRun */
1994 db->HPNA_present = 2;
1995 dmfe_program_DM9802(db);
1996 }
1997 }
1998
1999 }
2000
2001
2002 /*
2003 * Init HomeRun DM9801
2004 */
2005
dmfe_program_DM9801(struct dmfe_board_info * db,int HPNA_rev)2006 static void dmfe_program_DM9801(struct dmfe_board_info * db, int HPNA_rev)
2007 {
2008 uint reg17, reg25;
2009
2010 if ( !HPNA_NoiseFloor ) HPNA_NoiseFloor = DM9801_NOISE_FLOOR;
2011 switch(HPNA_rev) {
2012 case 0xb900: /* DM9801 E3 */
2013 db->HPNA_command |= 0x1000;
2014 reg25 = dmfe_phy_read(db->ioaddr, db->phy_addr, 24, db->chip_id);
2015 reg25 = ( (reg25 + HPNA_NoiseFloor) & 0xff) | 0xf000;
2016 reg17 = dmfe_phy_read(db->ioaddr, db->phy_addr, 17, db->chip_id);
2017 break;
2018 case 0xb901: /* DM9801 E4 */
2019 reg25 = dmfe_phy_read(db->ioaddr, db->phy_addr, 25, db->chip_id);
2020 reg25 = (reg25 & 0xff00) + HPNA_NoiseFloor;
2021 reg17 = dmfe_phy_read(db->ioaddr, db->phy_addr, 17, db->chip_id);
2022 reg17 = (reg17 & 0xfff0) + HPNA_NoiseFloor + 3;
2023 break;
2024 case 0xb902: /* DM9801 E5 */
2025 case 0xb903: /* DM9801 E6 */
2026 default:
2027 db->HPNA_command |= 0x1000;
2028 reg25 = dmfe_phy_read(db->ioaddr, db->phy_addr, 25, db->chip_id);
2029 reg25 = (reg25 & 0xff00) + HPNA_NoiseFloor - 5;
2030 reg17 = dmfe_phy_read(db->ioaddr, db->phy_addr, 17, db->chip_id);
2031 reg17 = (reg17 & 0xfff0) + HPNA_NoiseFloor;
2032 break;
2033 }
2034 dmfe_phy_write(db->ioaddr, db->phy_addr, 16, db->HPNA_command, db->chip_id);
2035 dmfe_phy_write(db->ioaddr, db->phy_addr, 17, reg17, db->chip_id);
2036 dmfe_phy_write(db->ioaddr, db->phy_addr, 25, reg25, db->chip_id);
2037 }
2038
2039
2040 /*
2041 * Init HomeRun DM9802
2042 */
2043
dmfe_program_DM9802(struct dmfe_board_info * db)2044 static void dmfe_program_DM9802(struct dmfe_board_info * db)
2045 {
2046 uint phy_reg;
2047
2048 if ( !HPNA_NoiseFloor ) HPNA_NoiseFloor = DM9802_NOISE_FLOOR;
2049 dmfe_phy_write(db->ioaddr, db->phy_addr, 16, db->HPNA_command, db->chip_id);
2050 phy_reg = dmfe_phy_read(db->ioaddr, db->phy_addr, 25, db->chip_id);
2051 phy_reg = ( phy_reg & 0xff00) + HPNA_NoiseFloor;
2052 dmfe_phy_write(db->ioaddr, db->phy_addr, 25, phy_reg, db->chip_id);
2053 }
2054
2055
2056 /*
2057 * Check remote HPNA power and speed status. If not correct,
2058 * issue command again.
2059 */
2060
dmfe_HPNA_remote_cmd_chk(struct dmfe_board_info * db)2061 static void dmfe_HPNA_remote_cmd_chk(struct dmfe_board_info * db)
2062 {
2063 uint phy_reg;
2064
2065 /* Got remote device status */
2066 phy_reg = dmfe_phy_read(db->ioaddr, db->phy_addr, 17, db->chip_id) & 0x60;
2067 switch(phy_reg) {
2068 case 0x00: phy_reg = 0x0a00;break; /* LP/LS */
2069 case 0x20: phy_reg = 0x0900;break; /* LP/HS */
2070 case 0x40: phy_reg = 0x0600;break; /* HP/LS */
2071 case 0x60: phy_reg = 0x0500;break; /* HP/HS */
2072 }
2073
2074 /* Check remote device status match our setting ot not */
2075 if ( phy_reg != (db->HPNA_command & 0x0f00) ) {
2076 dmfe_phy_write(db->ioaddr, db->phy_addr, 16, db->HPNA_command,
2077 db->chip_id);
2078 db->HPNA_timer=8;
2079 } else
2080 db->HPNA_timer=600; /* Match, every 10 minutes, check */
2081 }
2082
2083
2084
2085 static const struct pci_device_id dmfe_pci_tbl[] = {
2086 { 0x1282, 0x9132, PCI_ANY_ID, PCI_ANY_ID, 0, 0, PCI_DM9132_ID },
2087 { 0x1282, 0x9102, PCI_ANY_ID, PCI_ANY_ID, 0, 0, PCI_DM9102_ID },
2088 { 0x1282, 0x9100, PCI_ANY_ID, PCI_ANY_ID, 0, 0, PCI_DM9100_ID },
2089 { 0x1282, 0x9009, PCI_ANY_ID, PCI_ANY_ID, 0, 0, PCI_DM9009_ID },
2090 { 0, }
2091 };
2092 MODULE_DEVICE_TABLE(pci, dmfe_pci_tbl);
2093
2094
2095 #ifdef CONFIG_PM
dmfe_suspend(struct pci_dev * pci_dev,pm_message_t state)2096 static int dmfe_suspend(struct pci_dev *pci_dev, pm_message_t state)
2097 {
2098 struct net_device *dev = pci_get_drvdata(pci_dev);
2099 struct dmfe_board_info *db = netdev_priv(dev);
2100 void __iomem *ioaddr = db->ioaddr;
2101 u32 tmp;
2102
2103 /* Disable upper layer interface */
2104 netif_device_detach(dev);
2105
2106 /* Disable Tx/Rx */
2107 db->cr6_data &= ~(CR6_RXSC | CR6_TXSC);
2108 update_cr6(db->cr6_data, ioaddr);
2109
2110 /* Disable Interrupt */
2111 dw32(DCR7, 0);
2112 dw32(DCR5, dr32(DCR5));
2113
2114 /* Fre RX buffers */
2115 dmfe_free_rxbuffer(db);
2116
2117 /* Enable WOL */
2118 pci_read_config_dword(pci_dev, 0x40, &tmp);
2119 tmp &= ~(DMFE_WOL_LINKCHANGE|DMFE_WOL_MAGICPACKET);
2120
2121 if (db->wol_mode & WAKE_PHY)
2122 tmp |= DMFE_WOL_LINKCHANGE;
2123 if (db->wol_mode & WAKE_MAGIC)
2124 tmp |= DMFE_WOL_MAGICPACKET;
2125
2126 pci_write_config_dword(pci_dev, 0x40, tmp);
2127
2128 pci_enable_wake(pci_dev, PCI_D3hot, 1);
2129 pci_enable_wake(pci_dev, PCI_D3cold, 1);
2130
2131 /* Power down device*/
2132 pci_save_state(pci_dev);
2133 pci_set_power_state(pci_dev, pci_choose_state (pci_dev, state));
2134
2135 return 0;
2136 }
2137
dmfe_resume(struct pci_dev * pci_dev)2138 static int dmfe_resume(struct pci_dev *pci_dev)
2139 {
2140 struct net_device *dev = pci_get_drvdata(pci_dev);
2141 u32 tmp;
2142
2143 pci_set_power_state(pci_dev, PCI_D0);
2144 pci_restore_state(pci_dev);
2145
2146 /* Re-initialize DM910X board */
2147 dmfe_init_dm910x(dev);
2148
2149 /* Disable WOL */
2150 pci_read_config_dword(pci_dev, 0x40, &tmp);
2151
2152 tmp &= ~(DMFE_WOL_LINKCHANGE | DMFE_WOL_MAGICPACKET);
2153 pci_write_config_dword(pci_dev, 0x40, tmp);
2154
2155 pci_enable_wake(pci_dev, PCI_D3hot, 0);
2156 pci_enable_wake(pci_dev, PCI_D3cold, 0);
2157
2158 /* Restart upper layer interface */
2159 netif_device_attach(dev);
2160
2161 return 0;
2162 }
2163 #else
2164 #define dmfe_suspend NULL
2165 #define dmfe_resume NULL
2166 #endif
2167
2168 static struct pci_driver dmfe_driver = {
2169 .name = "dmfe",
2170 .id_table = dmfe_pci_tbl,
2171 .probe = dmfe_init_one,
2172 .remove = dmfe_remove_one,
2173 .suspend = dmfe_suspend,
2174 .resume = dmfe_resume
2175 };
2176
2177 MODULE_AUTHOR("Sten Wang, sten_wang@davicom.com.tw");
2178 MODULE_DESCRIPTION("Davicom DM910X fast ethernet driver");
2179 MODULE_LICENSE("GPL");
2180 MODULE_VERSION(DRV_VERSION);
2181
2182 module_param(debug, int, 0);
2183 module_param(mode, byte, 0);
2184 module_param(cr6set, int, 0);
2185 module_param(chkmode, byte, 0);
2186 module_param(HPNA_mode, byte, 0);
2187 module_param(HPNA_rx_cmd, byte, 0);
2188 module_param(HPNA_tx_cmd, byte, 0);
2189 module_param(HPNA_NoiseFloor, byte, 0);
2190 module_param(SF_mode, byte, 0);
2191 MODULE_PARM_DESC(debug, "Davicom DM9xxx enable debugging (0-1)");
2192 MODULE_PARM_DESC(mode, "Davicom DM9xxx: "
2193 "Bit 0: 10/100Mbps, bit 2: duplex, bit 8: HomePNA");
2194
2195 MODULE_PARM_DESC(SF_mode, "Davicom DM9xxx special function "
2196 "(bit 0: VLAN, bit 1 Flow Control, bit 2: TX pause packet)");
2197
2198 /* Description:
2199 * when user used insmod to add module, system invoked init_module()
2200 * to initialize and register.
2201 */
2202
dmfe_init_module(void)2203 static int __init dmfe_init_module(void)
2204 {
2205 int rc;
2206
2207 pr_info("%s\n", version);
2208 printed_version = 1;
2209
2210 DMFE_DBUG(0, "init_module() ", debug);
2211
2212 if (debug)
2213 dmfe_debug = debug; /* set debug flag */
2214 if (cr6set)
2215 dmfe_cr6_user_set = cr6set;
2216
2217 switch(mode) {
2218 case DMFE_10MHF:
2219 case DMFE_100MHF:
2220 case DMFE_10MFD:
2221 case DMFE_100MFD:
2222 case DMFE_1M_HPNA:
2223 dmfe_media_mode = mode;
2224 break;
2225 default:dmfe_media_mode = DMFE_AUTO;
2226 break;
2227 }
2228
2229 if (HPNA_mode > 4)
2230 HPNA_mode = 0; /* Default: LP/HS */
2231 if (HPNA_rx_cmd > 1)
2232 HPNA_rx_cmd = 0; /* Default: Ignored remote cmd */
2233 if (HPNA_tx_cmd > 1)
2234 HPNA_tx_cmd = 0; /* Default: Don't issue remote cmd */
2235 if (HPNA_NoiseFloor > 15)
2236 HPNA_NoiseFloor = 0;
2237
2238 rc = pci_register_driver(&dmfe_driver);
2239 if (rc < 0)
2240 return rc;
2241
2242 return 0;
2243 }
2244
2245
2246 /*
2247 * Description:
2248 * when user used rmmod to delete module, system invoked clean_module()
2249 * to un-register all registered services.
2250 */
2251
dmfe_cleanup_module(void)2252 static void __exit dmfe_cleanup_module(void)
2253 {
2254 DMFE_DBUG(0, "dmfe_cleanup_module() ", debug);
2255 pci_unregister_driver(&dmfe_driver);
2256 }
2257
2258 module_init(dmfe_init_module);
2259 module_exit(dmfe_cleanup_module);
2260