diff options
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/ibm_newemac/core.c | 61 | ||||
-rw-r--r-- | drivers/net/ibm_newemac/core.h | 83 | ||||
-rw-r--r-- | drivers/net/ibm_newemac/debug.c | 52 | ||||
-rw-r--r-- | drivers/net/ibm_newemac/emac.h | 101 |
4 files changed, 232 insertions, 65 deletions
diff --git a/drivers/net/ibm_newemac/core.c b/drivers/net/ibm_newemac/core.c index 5d2108c5ac7c..ed24a1d607dd 100644 --- a/drivers/net/ibm_newemac/core.c +++ b/drivers/net/ibm_newemac/core.c | |||
@@ -363,25 +363,31 @@ static int emac_reset(struct emac_instance *dev) | |||
363 | 363 | ||
364 | static void emac_hash_mc(struct emac_instance *dev) | 364 | static void emac_hash_mc(struct emac_instance *dev) |
365 | { | 365 | { |
366 | struct emac_regs __iomem *p = dev->emacp; | 366 | const int regs = EMAC_XAHT_REGS(dev); |
367 | u16 gaht[4] = { 0 }; | 367 | u32 *gaht_base = emac_gaht_base(dev); |
368 | u32 gaht_temp[regs]; | ||
368 | struct dev_mc_list *dmi; | 369 | struct dev_mc_list *dmi; |
370 | int i; | ||
369 | 371 | ||
370 | DBG(dev, "hash_mc %d" NL, dev->ndev->mc_count); | 372 | DBG(dev, "hash_mc %d" NL, dev->ndev->mc_count); |
371 | 373 | ||
374 | memset(gaht_temp, 0, sizeof (gaht_temp)); | ||
375 | |||
372 | for (dmi = dev->ndev->mc_list; dmi; dmi = dmi->next) { | 376 | for (dmi = dev->ndev->mc_list; dmi; dmi = dmi->next) { |
373 | int bit; | 377 | int slot, reg, mask; |
374 | DBG2(dev, "mc %02x:%02x:%02x:%02x:%02x:%02x" NL, | 378 | DBG2(dev, "mc %02x:%02x:%02x:%02x:%02x:%02x" NL, |
375 | dmi->dmi_addr[0], dmi->dmi_addr[1], dmi->dmi_addr[2], | 379 | dmi->dmi_addr[0], dmi->dmi_addr[1], dmi->dmi_addr[2], |
376 | dmi->dmi_addr[3], dmi->dmi_addr[4], dmi->dmi_addr[5]); | 380 | dmi->dmi_addr[3], dmi->dmi_addr[4], dmi->dmi_addr[5]); |
377 | 381 | ||
378 | bit = 63 - (ether_crc(ETH_ALEN, dmi->dmi_addr) >> 26); | 382 | slot = EMAC_XAHT_CRC_TO_SLOT(dev, ether_crc(ETH_ALEN, dmi->dmi_addr)); |
379 | gaht[bit >> 4] |= 0x8000 >> (bit & 0x0f); | 383 | reg = EMAC_XAHT_SLOT_TO_REG(dev, slot); |
384 | mask = EMAC_XAHT_SLOT_TO_MASK(dev, slot); | ||
385 | |||
386 | gaht_temp[reg] |= mask; | ||
380 | } | 387 | } |
381 | out_be32(&p->gaht1, gaht[0]); | 388 | |
382 | out_be32(&p->gaht2, gaht[1]); | 389 | for (i = 0; i < regs; i++) |
383 | out_be32(&p->gaht3, gaht[2]); | 390 | out_be32(gaht_base + i, gaht_temp[i]); |
384 | out_be32(&p->gaht4, gaht[3]); | ||
385 | } | 391 | } |
386 | 392 | ||
387 | static inline u32 emac_iff2rmr(struct net_device *ndev) | 393 | static inline u32 emac_iff2rmr(struct net_device *ndev) |
@@ -398,7 +404,8 @@ static inline u32 emac_iff2rmr(struct net_device *ndev) | |||
398 | 404 | ||
399 | if (ndev->flags & IFF_PROMISC) | 405 | if (ndev->flags & IFF_PROMISC) |
400 | r |= EMAC_RMR_PME; | 406 | r |= EMAC_RMR_PME; |
401 | else if (ndev->flags & IFF_ALLMULTI || ndev->mc_count > 32) | 407 | else if (ndev->flags & IFF_ALLMULTI || |
408 | (ndev->mc_count > EMAC_XAHT_SLOTS(dev))) | ||
402 | r |= EMAC_RMR_PMME; | 409 | r |= EMAC_RMR_PMME; |
403 | else if (ndev->mc_count > 0) | 410 | else if (ndev->mc_count > 0) |
404 | r |= EMAC_RMR_MAE; | 411 | r |= EMAC_RMR_MAE; |
@@ -542,7 +549,7 @@ static int emac_configure(struct emac_instance *dev) | |||
542 | /* Put some arbitrary OUI, Manuf & Rev IDs so we can | 549 | /* Put some arbitrary OUI, Manuf & Rev IDs so we can |
543 | * identify this GPCS PHY later. | 550 | * identify this GPCS PHY later. |
544 | */ | 551 | */ |
545 | out_be32(&p->ipcr, 0xdeadbeef); | 552 | out_be32(&p->u1.emac4.ipcr, 0xdeadbeef); |
546 | } else | 553 | } else |
547 | mr1 |= EMAC_MR1_MF_1000; | 554 | mr1 |= EMAC_MR1_MF_1000; |
548 | 555 | ||
@@ -2015,10 +2022,10 @@ static int emac_get_regs_len(struct emac_instance *dev) | |||
2015 | { | 2022 | { |
2016 | if (emac_has_feature(dev, EMAC_FTR_EMAC4)) | 2023 | if (emac_has_feature(dev, EMAC_FTR_EMAC4)) |
2017 | return sizeof(struct emac_ethtool_regs_subhdr) + | 2024 | return sizeof(struct emac_ethtool_regs_subhdr) + |
2018 | EMAC4_ETHTOOL_REGS_SIZE; | 2025 | EMAC4_ETHTOOL_REGS_SIZE(dev); |
2019 | else | 2026 | else |
2020 | return sizeof(struct emac_ethtool_regs_subhdr) + | 2027 | return sizeof(struct emac_ethtool_regs_subhdr) + |
2021 | EMAC_ETHTOOL_REGS_SIZE; | 2028 | EMAC_ETHTOOL_REGS_SIZE(dev); |
2022 | } | 2029 | } |
2023 | 2030 | ||
2024 | static int emac_ethtool_get_regs_len(struct net_device *ndev) | 2031 | static int emac_ethtool_get_regs_len(struct net_device *ndev) |
@@ -2045,12 +2052,12 @@ static void *emac_dump_regs(struct emac_instance *dev, void *buf) | |||
2045 | hdr->index = dev->cell_index; | 2052 | hdr->index = dev->cell_index; |
2046 | if (emac_has_feature(dev, EMAC_FTR_EMAC4)) { | 2053 | if (emac_has_feature(dev, EMAC_FTR_EMAC4)) { |
2047 | hdr->version = EMAC4_ETHTOOL_REGS_VER; | 2054 | hdr->version = EMAC4_ETHTOOL_REGS_VER; |
2048 | memcpy_fromio(hdr + 1, dev->emacp, EMAC4_ETHTOOL_REGS_SIZE); | 2055 | memcpy_fromio(hdr + 1, dev->emacp, EMAC4_ETHTOOL_REGS_SIZE(dev)); |
2049 | return ((void *)(hdr + 1) + EMAC4_ETHTOOL_REGS_SIZE); | 2056 | return ((void *)(hdr + 1) + EMAC4_ETHTOOL_REGS_SIZE(dev)); |
2050 | } else { | 2057 | } else { |
2051 | hdr->version = EMAC_ETHTOOL_REGS_VER; | 2058 | hdr->version = EMAC_ETHTOOL_REGS_VER; |
2052 | memcpy_fromio(hdr + 1, dev->emacp, EMAC_ETHTOOL_REGS_SIZE); | 2059 | memcpy_fromio(hdr + 1, dev->emacp, EMAC_ETHTOOL_REGS_SIZE(dev)); |
2053 | return ((void *)(hdr + 1) + EMAC_ETHTOOL_REGS_SIZE); | 2060 | return ((void *)(hdr + 1) + EMAC_ETHTOOL_REGS_SIZE(dev)); |
2054 | } | 2061 | } |
2055 | } | 2062 | } |
2056 | 2063 | ||
@@ -2540,7 +2547,9 @@ static int __devinit emac_init_config(struct emac_instance *dev) | |||
2540 | } | 2547 | } |
2541 | 2548 | ||
2542 | /* Check EMAC version */ | 2549 | /* Check EMAC version */ |
2543 | if (of_device_is_compatible(np, "ibm,emac4")) { | 2550 | if (of_device_is_compatible(np, "ibm,emac4sync")) { |
2551 | dev->features |= (EMAC_FTR_EMAC4 | EMAC_FTR_EMAC4SYNC); | ||
2552 | } else if (of_device_is_compatible(np, "ibm,emac4")) { | ||
2544 | dev->features |= EMAC_FTR_EMAC4; | 2553 | dev->features |= EMAC_FTR_EMAC4; |
2545 | if (of_device_is_compatible(np, "ibm,emac-440gx")) | 2554 | if (of_device_is_compatible(np, "ibm,emac-440gx")) |
2546 | dev->features |= EMAC_FTR_440GX_PHY_CLK_FIX; | 2555 | dev->features |= EMAC_FTR_440GX_PHY_CLK_FIX; |
@@ -2601,6 +2610,15 @@ static int __devinit emac_init_config(struct emac_instance *dev) | |||
2601 | } | 2610 | } |
2602 | memcpy(dev->ndev->dev_addr, p, 6); | 2611 | memcpy(dev->ndev->dev_addr, p, 6); |
2603 | 2612 | ||
2613 | /* IAHT and GAHT filter parameterization */ | ||
2614 | if (emac_has_feature(dev, EMAC_FTR_EMAC4SYNC)) { | ||
2615 | dev->xaht_slots_shift = EMAC4SYNC_XAHT_SLOTS_SHIFT; | ||
2616 | dev->xaht_width_shift = EMAC4SYNC_XAHT_WIDTH_SHIFT; | ||
2617 | } else { | ||
2618 | dev->xaht_slots_shift = EMAC4_XAHT_SLOTS_SHIFT; | ||
2619 | dev->xaht_width_shift = EMAC4_XAHT_WIDTH_SHIFT; | ||
2620 | } | ||
2621 | |||
2604 | DBG(dev, "features : 0x%08x / 0x%08x\n", dev->features, EMAC_FTRS_POSSIBLE); | 2622 | DBG(dev, "features : 0x%08x / 0x%08x\n", dev->features, EMAC_FTRS_POSSIBLE); |
2605 | DBG(dev, "tx_fifo_size : %d (%d gige)\n", dev->tx_fifo_size, dev->tx_fifo_size_gige); | 2623 | DBG(dev, "tx_fifo_size : %d (%d gige)\n", dev->tx_fifo_size, dev->tx_fifo_size_gige); |
2606 | DBG(dev, "rx_fifo_size : %d (%d gige)\n", dev->rx_fifo_size, dev->rx_fifo_size_gige); | 2624 | DBG(dev, "rx_fifo_size : %d (%d gige)\n", dev->rx_fifo_size, dev->rx_fifo_size_gige); |
@@ -2672,7 +2690,8 @@ static int __devinit emac_probe(struct of_device *ofdev, | |||
2672 | goto err_irq_unmap; | 2690 | goto err_irq_unmap; |
2673 | } | 2691 | } |
2674 | // TODO : request_mem_region | 2692 | // TODO : request_mem_region |
2675 | dev->emacp = ioremap(dev->rsrc_regs.start, sizeof(struct emac_regs)); | 2693 | dev->emacp = ioremap(dev->rsrc_regs.start, |
2694 | dev->rsrc_regs.end - dev->rsrc_regs.start + 1); | ||
2676 | if (dev->emacp == NULL) { | 2695 | if (dev->emacp == NULL) { |
2677 | printk(KERN_ERR "%s: Can't map device registers!\n", | 2696 | printk(KERN_ERR "%s: Can't map device registers!\n", |
2678 | np->full_name); | 2697 | np->full_name); |
@@ -2884,6 +2903,10 @@ static struct of_device_id emac_match[] = | |||
2884 | .type = "network", | 2903 | .type = "network", |
2885 | .compatible = "ibm,emac4", | 2904 | .compatible = "ibm,emac4", |
2886 | }, | 2905 | }, |
2906 | { | ||
2907 | .type = "network", | ||
2908 | .compatible = "ibm,emac4sync", | ||
2909 | }, | ||
2887 | {}, | 2910 | {}, |
2888 | }; | 2911 | }; |
2889 | 2912 | ||
diff --git a/drivers/net/ibm_newemac/core.h b/drivers/net/ibm_newemac/core.h index 223090466760..6545e69d12c3 100644 --- a/drivers/net/ibm_newemac/core.h +++ b/drivers/net/ibm_newemac/core.h | |||
@@ -235,6 +235,10 @@ struct emac_instance { | |||
235 | u32 fifo_entry_size; | 235 | u32 fifo_entry_size; |
236 | u32 mal_burst_size; /* move to MAL ? */ | 236 | u32 mal_burst_size; /* move to MAL ? */ |
237 | 237 | ||
238 | /* IAHT and GAHT filter parameterization */ | ||
239 | u32 xaht_slots_shift; | ||
240 | u32 xaht_width_shift; | ||
241 | |||
238 | /* Descriptor management | 242 | /* Descriptor management |
239 | */ | 243 | */ |
240 | struct mal_descriptor *tx_desc; | 244 | struct mal_descriptor *tx_desc; |
@@ -309,6 +313,10 @@ struct emac_instance { | |||
309 | * Set if we need phy clock workaround for 440ep or 440gr | 313 | * Set if we need phy clock workaround for 440ep or 440gr |
310 | */ | 314 | */ |
311 | #define EMAC_FTR_440EP_PHY_CLK_FIX 0x00000100 | 315 | #define EMAC_FTR_440EP_PHY_CLK_FIX 0x00000100 |
316 | /* | ||
317 | * The 405EX and 460EX contain the EMAC4SYNC core | ||
318 | */ | ||
319 | #define EMAC_FTR_EMAC4SYNC 0x00000200 | ||
312 | 320 | ||
313 | 321 | ||
314 | /* Right now, we don't quite handle the always/possible masks on the | 322 | /* Right now, we don't quite handle the always/possible masks on the |
@@ -320,7 +328,8 @@ enum { | |||
320 | 328 | ||
321 | EMAC_FTRS_POSSIBLE = | 329 | EMAC_FTRS_POSSIBLE = |
322 | #ifdef CONFIG_IBM_NEW_EMAC_EMAC4 | 330 | #ifdef CONFIG_IBM_NEW_EMAC_EMAC4 |
323 | EMAC_FTR_EMAC4 | EMAC_FTR_HAS_NEW_STACR | | 331 | EMAC_FTR_EMAC4 | EMAC_FTR_EMAC4SYNC | |
332 | EMAC_FTR_HAS_NEW_STACR | | ||
324 | EMAC_FTR_STACR_OC_INVERT | EMAC_FTR_440GX_PHY_CLK_FIX | | 333 | EMAC_FTR_STACR_OC_INVERT | EMAC_FTR_440GX_PHY_CLK_FIX | |
325 | #endif | 334 | #endif |
326 | #ifdef CONFIG_IBM_NEW_EMAC_TAH | 335 | #ifdef CONFIG_IBM_NEW_EMAC_TAH |
@@ -342,6 +351,71 @@ static inline int emac_has_feature(struct emac_instance *dev, | |||
342 | (EMAC_FTRS_POSSIBLE & dev->features & feature); | 351 | (EMAC_FTRS_POSSIBLE & dev->features & feature); |
343 | } | 352 | } |
344 | 353 | ||
354 | /* | ||
355 | * Various instances of the EMAC core have varying 1) number of | ||
356 | * address match slots, 2) width of the registers for handling address | ||
357 | * match slots, 3) number of registers for handling address match | ||
358 | * slots and 4) base offset for those registers. | ||
359 | * | ||
360 | * These macros and inlines handle these differences based on | ||
361 | * parameters supplied by the device structure which are, in turn, | ||
362 | * initialized based on the "compatible" entry in the device tree. | ||
363 | */ | ||
364 | |||
365 | #define EMAC4_XAHT_SLOTS_SHIFT 6 | ||
366 | #define EMAC4_XAHT_WIDTH_SHIFT 4 | ||
367 | |||
368 | #define EMAC4SYNC_XAHT_SLOTS_SHIFT 8 | ||
369 | #define EMAC4SYNC_XAHT_WIDTH_SHIFT 5 | ||
370 | |||
371 | #define EMAC_XAHT_SLOTS(dev) (1 << (dev)->xaht_slots_shift) | ||
372 | #define EMAC_XAHT_WIDTH(dev) (1 << (dev)->xaht_width_shift) | ||
373 | #define EMAC_XAHT_REGS(dev) (1 << ((dev)->xaht_slots_shift - \ | ||
374 | (dev)->xaht_width_shift)) | ||
375 | |||
376 | #define EMAC_XAHT_CRC_TO_SLOT(dev, crc) \ | ||
377 | ((EMAC_XAHT_SLOTS(dev) - 1) - \ | ||
378 | ((crc) >> ((sizeof (u32) * BITS_PER_BYTE) - \ | ||
379 | (dev)->xaht_slots_shift))) | ||
380 | |||
381 | #define EMAC_XAHT_SLOT_TO_REG(dev, slot) \ | ||
382 | ((slot) >> (dev)->xaht_width_shift) | ||
383 | |||
384 | #define EMAC_XAHT_SLOT_TO_MASK(dev, slot) \ | ||
385 | ((u32)(1 << (EMAC_XAHT_WIDTH(dev) - 1)) >> \ | ||
386 | ((slot) & (u32)(EMAC_XAHT_WIDTH(dev) - 1))) | ||
387 | |||
388 | static inline u32 *emac_xaht_base(struct emac_instance *dev) | ||
389 | { | ||
390 | struct emac_regs __iomem *p = dev->emacp; | ||
391 | int offset; | ||
392 | |||
393 | /* The first IAHT entry always is the base of the block of | ||
394 | * IAHT and GAHT registers. | ||
395 | */ | ||
396 | if (emac_has_feature(dev, EMAC_FTR_EMAC4SYNC)) | ||
397 | offset = offsetof(struct emac_regs, u1.emac4sync.iaht1); | ||
398 | else | ||
399 | offset = offsetof(struct emac_regs, u0.emac4.iaht1); | ||
400 | |||
401 | return ((u32 *)((ptrdiff_t)p + offset)); | ||
402 | } | ||
403 | |||
404 | static inline u32 *emac_gaht_base(struct emac_instance *dev) | ||
405 | { | ||
406 | /* GAHT registers always come after an identical number of | ||
407 | * IAHT registers. | ||
408 | */ | ||
409 | return (emac_xaht_base(dev) + EMAC_XAHT_REGS(dev)); | ||
410 | } | ||
411 | |||
412 | static inline u32 *emac_iaht_base(struct emac_instance *dev) | ||
413 | { | ||
414 | /* IAHT registers always come before an identical number of | ||
415 | * GAHT registers. | ||
416 | */ | ||
417 | return (emac_xaht_base(dev)); | ||
418 | } | ||
345 | 419 | ||
346 | /* Ethtool get_regs complex data. | 420 | /* Ethtool get_regs complex data. |
347 | * We want to get not just EMAC registers, but also MAL, ZMII, RGMII, TAH | 421 | * We want to get not just EMAC registers, but also MAL, ZMII, RGMII, TAH |
@@ -366,4 +440,11 @@ struct emac_ethtool_regs_subhdr { | |||
366 | u32 index; | 440 | u32 index; |
367 | }; | 441 | }; |
368 | 442 | ||
443 | #define EMAC_ETHTOOL_REGS_VER 0 | ||
444 | #define EMAC_ETHTOOL_REGS_SIZE(dev) ((dev)->rsrc_regs.end - \ | ||
445 | (dev)->rsrc_regs.start + 1) | ||
446 | #define EMAC4_ETHTOOL_REGS_VER 1 | ||
447 | #define EMAC4_ETHTOOL_REGS_SIZE(dev) ((dev)->rsrc_regs.end - \ | ||
448 | (dev)->rsrc_regs.start + 1) | ||
449 | |||
369 | #endif /* __IBM_NEWEMAC_CORE_H */ | 450 | #endif /* __IBM_NEWEMAC_CORE_H */ |
diff --git a/drivers/net/ibm_newemac/debug.c b/drivers/net/ibm_newemac/debug.c index 86b756a30784..775c850a425a 100644 --- a/drivers/net/ibm_newemac/debug.c +++ b/drivers/net/ibm_newemac/debug.c | |||
@@ -67,29 +67,55 @@ static void emac_desc_dump(struct emac_instance *p) | |||
67 | static void emac_mac_dump(struct emac_instance *dev) | 67 | static void emac_mac_dump(struct emac_instance *dev) |
68 | { | 68 | { |
69 | struct emac_regs __iomem *p = dev->emacp; | 69 | struct emac_regs __iomem *p = dev->emacp; |
70 | const int xaht_regs = EMAC_XAHT_REGS(dev); | ||
71 | u32 *gaht_base = emac_gaht_base(dev); | ||
72 | u32 *iaht_base = emac_iaht_base(dev); | ||
73 | int emac4sync = emac_has_feature(dev, EMAC_FTR_EMAC4SYNC); | ||
74 | int n; | ||
70 | 75 | ||
71 | printk("** EMAC %s registers **\n" | 76 | printk("** EMAC %s registers **\n" |
72 | "MR0 = 0x%08x MR1 = 0x%08x TMR0 = 0x%08x TMR1 = 0x%08x\n" | 77 | "MR0 = 0x%08x MR1 = 0x%08x TMR0 = 0x%08x TMR1 = 0x%08x\n" |
73 | "RMR = 0x%08x ISR = 0x%08x ISER = 0x%08x\n" | 78 | "RMR = 0x%08x ISR = 0x%08x ISER = 0x%08x\n" |
74 | "IAR = %04x%08x VTPID = 0x%04x VTCI = 0x%04x\n" | 79 | "IAR = %04x%08x VTPID = 0x%04x VTCI = 0x%04x\n", |
75 | "IAHT: 0x%04x 0x%04x 0x%04x 0x%04x " | ||
76 | "GAHT: 0x%04x 0x%04x 0x%04x 0x%04x\n" | ||
77 | "LSA = %04x%08x IPGVR = 0x%04x\n" | ||
78 | "STACR = 0x%08x TRTR = 0x%08x RWMR = 0x%08x\n" | ||
79 | "OCTX = 0x%08x OCRX = 0x%08x IPCR = 0x%08x\n", | ||
80 | dev->ofdev->node->full_name, in_be32(&p->mr0), in_be32(&p->mr1), | 80 | dev->ofdev->node->full_name, in_be32(&p->mr0), in_be32(&p->mr1), |
81 | in_be32(&p->tmr0), in_be32(&p->tmr1), | 81 | in_be32(&p->tmr0), in_be32(&p->tmr1), |
82 | in_be32(&p->rmr), in_be32(&p->isr), in_be32(&p->iser), | 82 | in_be32(&p->rmr), in_be32(&p->isr), in_be32(&p->iser), |
83 | in_be32(&p->iahr), in_be32(&p->ialr), in_be32(&p->vtpid), | 83 | in_be32(&p->iahr), in_be32(&p->ialr), in_be32(&p->vtpid), |
84 | in_be32(&p->vtci), | 84 | in_be32(&p->vtci) |
85 | in_be32(&p->iaht1), in_be32(&p->iaht2), in_be32(&p->iaht3), | 85 | ); |
86 | in_be32(&p->iaht4), | 86 | |
87 | in_be32(&p->gaht1), in_be32(&p->gaht2), in_be32(&p->gaht3), | 87 | if (emac4sync) |
88 | in_be32(&p->gaht4), | 88 | printk("MAR = %04x%08x MMAR = %04x%08x\n", |
89 | in_be32(&p->u0.emac4sync.mahr), | ||
90 | in_be32(&p->u0.emac4sync.malr), | ||
91 | in_be32(&p->u0.emac4sync.mmahr), | ||
92 | in_be32(&p->u0.emac4sync.mmalr) | ||
93 | ); | ||
94 | |||
95 | for (n = 0; n < xaht_regs; n++) | ||
96 | printk("IAHT%02d = 0x%08x\n", n + 1, in_be32(iaht_base + n)); | ||
97 | |||
98 | for (n = 0; n < xaht_regs; n++) | ||
99 | printk("GAHT%02d = 0x%08x\n", n + 1, in_be32(gaht_base + n)); | ||
100 | |||
101 | printk("LSA = %04x%08x IPGVR = 0x%04x\n" | ||
102 | "STACR = 0x%08x TRTR = 0x%08x RWMR = 0x%08x\n" | ||
103 | "OCTX = 0x%08x OCRX = 0x%08x\n", | ||
89 | in_be32(&p->lsah), in_be32(&p->lsal), in_be32(&p->ipgvr), | 104 | in_be32(&p->lsah), in_be32(&p->lsal), in_be32(&p->ipgvr), |
90 | in_be32(&p->stacr), in_be32(&p->trtr), in_be32(&p->rwmr), | 105 | in_be32(&p->stacr), in_be32(&p->trtr), in_be32(&p->rwmr), |
91 | in_be32(&p->octx), in_be32(&p->ocrx), in_be32(&p->ipcr) | 106 | in_be32(&p->octx), in_be32(&p->ocrx) |
92 | ); | 107 | ); |
108 | |||
109 | if (!emac4sync) { | ||
110 | printk("IPCR = 0x%08x\n", | ||
111 | in_be32(&p->u1.emac4.ipcr) | ||
112 | ); | ||
113 | } else { | ||
114 | printk("REVID = 0x%08x TPC = 0x%08x\n", | ||
115 | in_be32(&p->u1.emac4sync.revid), | ||
116 | in_be32(&p->u1.emac4sync.tpc) | ||
117 | ); | ||
118 | } | ||
93 | 119 | ||
94 | emac_desc_dump(dev); | 120 | emac_desc_dump(dev); |
95 | } | 121 | } |
diff --git a/drivers/net/ibm_newemac/emac.h b/drivers/net/ibm_newemac/emac.h index 91cb096ab405..0afc2cf5c52b 100644 --- a/drivers/net/ibm_newemac/emac.h +++ b/drivers/net/ibm_newemac/emac.h | |||
@@ -27,37 +27,80 @@ | |||
27 | 27 | ||
28 | #include <linux/types.h> | 28 | #include <linux/types.h> |
29 | 29 | ||
30 | /* EMAC registers Write Access rules */ | 30 | /* EMAC registers Write Access rules */ |
31 | struct emac_regs { | 31 | struct emac_regs { |
32 | u32 mr0; /* special */ | 32 | /* Common registers across all EMAC implementations. */ |
33 | u32 mr1; /* Reset */ | 33 | u32 mr0; /* Special */ |
34 | u32 tmr0; /* special */ | 34 | u32 mr1; /* Reset */ |
35 | u32 tmr1; /* special */ | 35 | u32 tmr0; /* Special */ |
36 | u32 rmr; /* Reset */ | 36 | u32 tmr1; /* Special */ |
37 | u32 isr; /* Always */ | 37 | u32 rmr; /* Reset */ |
38 | u32 iser; /* Reset */ | 38 | u32 isr; /* Always */ |
39 | u32 iahr; /* Reset, R, T */ | 39 | u32 iser; /* Reset */ |
40 | u32 ialr; /* Reset, R, T */ | 40 | u32 iahr; /* Reset, R, T */ |
41 | u32 vtpid; /* Reset, R, T */ | 41 | u32 ialr; /* Reset, R, T */ |
42 | u32 vtci; /* Reset, R, T */ | 42 | u32 vtpid; /* Reset, R, T */ |
43 | u32 ptr; /* Reset, T */ | 43 | u32 vtci; /* Reset, R, T */ |
44 | u32 iaht1; /* Reset, R */ | 44 | u32 ptr; /* Reset, T */ |
45 | u32 iaht2; /* Reset, R */ | 45 | union { |
46 | u32 iaht3; /* Reset, R */ | 46 | /* Registers unique to EMAC4 implementations */ |
47 | u32 iaht4; /* Reset, R */ | 47 | struct { |
48 | u32 gaht1; /* Reset, R */ | 48 | u32 iaht1; /* Reset, R */ |
49 | u32 gaht2; /* Reset, R */ | 49 | u32 iaht2; /* Reset, R */ |
50 | u32 gaht3; /* Reset, R */ | 50 | u32 iaht3; /* Reset, R */ |
51 | u32 gaht4; /* Reset, R */ | 51 | u32 iaht4; /* Reset, R */ |
52 | u32 gaht1; /* Reset, R */ | ||
53 | u32 gaht2; /* Reset, R */ | ||
54 | u32 gaht3; /* Reset, R */ | ||
55 | u32 gaht4; /* Reset, R */ | ||
56 | } emac4; | ||
57 | /* Registers unique to EMAC4SYNC implementations */ | ||
58 | struct { | ||
59 | u32 mahr; /* Reset, R, T */ | ||
60 | u32 malr; /* Reset, R, T */ | ||
61 | u32 mmahr; /* Reset, R, T */ | ||
62 | u32 mmalr; /* Reset, R, T */ | ||
63 | u32 rsvd0[4]; | ||
64 | } emac4sync; | ||
65 | } u0; | ||
66 | /* Common registers across all EMAC implementations. */ | ||
52 | u32 lsah; | 67 | u32 lsah; |
53 | u32 lsal; | 68 | u32 lsal; |
54 | u32 ipgvr; /* Reset, T */ | 69 | u32 ipgvr; /* Reset, T */ |
55 | u32 stacr; /* special */ | 70 | u32 stacr; /* Special */ |
56 | u32 trtr; /* special */ | 71 | u32 trtr; /* Special */ |
57 | u32 rwmr; /* Reset */ | 72 | u32 rwmr; /* Reset */ |
58 | u32 octx; | 73 | u32 octx; |
59 | u32 ocrx; | 74 | u32 ocrx; |
60 | u32 ipcr; | 75 | union { |
76 | /* Registers unique to EMAC4 implementations */ | ||
77 | struct { | ||
78 | u32 ipcr; | ||
79 | } emac4; | ||
80 | /* Registers unique to EMAC4SYNC implementations */ | ||
81 | struct { | ||
82 | u32 rsvd1; | ||
83 | u32 revid; | ||
84 | u32 rsvd2[2]; | ||
85 | u32 iaht1; /* Reset, R */ | ||
86 | u32 iaht2; /* Reset, R */ | ||
87 | u32 iaht3; /* Reset, R */ | ||
88 | u32 iaht4; /* Reset, R */ | ||
89 | u32 iaht5; /* Reset, R */ | ||
90 | u32 iaht6; /* Reset, R */ | ||
91 | u32 iaht7; /* Reset, R */ | ||
92 | u32 iaht8; /* Reset, R */ | ||
93 | u32 gaht1; /* Reset, R */ | ||
94 | u32 gaht2; /* Reset, R */ | ||
95 | u32 gaht3; /* Reset, R */ | ||
96 | u32 gaht4; /* Reset, R */ | ||
97 | u32 gaht5; /* Reset, R */ | ||
98 | u32 gaht6; /* Reset, R */ | ||
99 | u32 gaht7; /* Reset, R */ | ||
100 | u32 gaht8; /* Reset, R */ | ||
101 | u32 tpc; /* Reset, T */ | ||
102 | } emac4sync; | ||
103 | } u1; | ||
61 | }; | 104 | }; |
62 | 105 | ||
63 | /* | 106 | /* |
@@ -73,12 +116,6 @@ struct emac_regs { | |||
73 | #define PHY_MODE_RTBI 7 | 116 | #define PHY_MODE_RTBI 7 |
74 | #define PHY_MODE_SGMII 8 | 117 | #define PHY_MODE_SGMII 8 |
75 | 118 | ||
76 | |||
77 | #define EMAC_ETHTOOL_REGS_VER 0 | ||
78 | #define EMAC_ETHTOOL_REGS_SIZE (sizeof(struct emac_regs) - sizeof(u32)) | ||
79 | #define EMAC4_ETHTOOL_REGS_VER 1 | ||
80 | #define EMAC4_ETHTOOL_REGS_SIZE sizeof(struct emac_regs) | ||
81 | |||
82 | /* EMACx_MR0 */ | 119 | /* EMACx_MR0 */ |
83 | #define EMAC_MR0_RXI 0x80000000 | 120 | #define EMAC_MR0_RXI 0x80000000 |
84 | #define EMAC_MR0_TXI 0x40000000 | 121 | #define EMAC_MR0_TXI 0x40000000 |