| /* Copyright 2001 Sun Microsystems (thockin@sun.com) */ |
| #include <stdio.h> |
| #include "ethtool-util.h" |
| |
| static const char * const csr0_tap[4] = { |
| "No transmit automatic polling", |
| "Transmit automatic polling every 200 seconds", |
| "Transmit automatic polling every 800 seconds", |
| "Transmit automatic polling every 1.6 milliseconds", |
| }; |
| |
| static const char * const csr0_cache_al[4] = { |
| "not used", |
| "8-longword boundary alignment", |
| "16-longword boundary alignment", |
| "32-longword boundary alignment", |
| }; |
| |
| static const char * const csr5_buserr[8] = { |
| " Bus error: parity", |
| " Bus error: master abort", |
| " Bus error: target abort", |
| " Bus error: (unknown code, reserved)", |
| " Bus error: (unknown code, reserved)", |
| " Bus error: (unknown code, reserved)", |
| " Bus error: (unknown code, reserved)", |
| " Bus error: (unknown code, reserved)", |
| }; |
| |
| static const int csr6_tx_thresh[4] = { |
| 72, |
| 96, |
| 128, |
| 160, |
| }; |
| |
| static const char * const csr6_om[4] = { |
| "normal", |
| "internal loopback", |
| "external loopback", |
| "unknown (not used)", |
| }; |
| |
| static const char * const csr5_tx_state[8] = { |
| "stopped", |
| "running: fetch desc", |
| "running: wait xmit end", |
| "running: read buf", |
| "unknown (reserved)", |
| "running: setup packet", |
| "suspended", |
| "running: close desc", |
| }; |
| |
| static const char * const csr5_rx_state[8] = { |
| "stopped", |
| "running: fetch desc", |
| "running: chk pkt end", |
| "running: wait for pkt", |
| "suspended", |
| "running: close", |
| "running: flush", |
| "running: queue", |
| }; |
| |
| static const char * const csr12_nway_state[8] = { |
| "Autonegotiation disable", |
| "Transmit disable", |
| "Ability detect", |
| "Acknowledge detect", |
| "Complete acknowledge", |
| "FLP link good, nway complete", |
| "Link check", |
| "unknown (reserved)", |
| }; |
| |
| static const char * const csr14_tp_comp[4] = { |
| "Compensation Disabled Mode", |
| "Compensation Disabled Mode", |
| "High Power Mode", |
| "Normal Compensation Mode", |
| }; |
| |
| static void |
| print_ring_addresses(u32 csr3, u32 csr4) |
| { |
| fprintf(stdout, |
| "0x18: CSR3 (Rx Ring Base Address) 0x%08x\n" |
| "0x20: CSR4 (Tx Ring Base Address) 0x%08x\n" |
| , |
| csr3, |
| csr4); |
| } |
| |
| static void |
| print_rx_missed(u32 csr8) |
| { |
| fprintf(stdout, |
| "0x40: CSR8 (Missed Frames Counter) 0x%08x\n", csr8); |
| if (csr8 & (1 << 16)) |
| fprintf(stdout, |
| " Counter overflow\n"); |
| else { |
| unsigned int rx_missed = csr8 & 0xffff; |
| if (!rx_missed) |
| fprintf(stdout, |
| " No missed frames\n"); |
| else |
| fprintf(stdout, |
| " %u missed frames\n", rx_missed); |
| } |
| } |
| |
| static void |
| de21040_dump_regs(struct ethtool_drvinfo *info, struct ethtool_regs *regs) |
| { |
| u32 tmp, v, *data = (u32 *)regs->data; |
| |
| fprintf(stdout, "21040 Registers\n"); |
| fprintf(stdout, "---------------\n"); |
| |
| /* |
| * CSR0 |
| */ |
| v = data[0]; |
| fprintf(stdout, |
| "0x00: CSR0 (Bus Mode) 0x%08x\n" |
| " %s\n" |
| " %s address space\n" |
| " Cache alignment: %s\n" |
| , |
| v, |
| csr0_tap[(v >> 17) & 3], |
| v & (1 << 16) ? "Diagnostic" : "Standard", |
| csr0_cache_al[(v >> 14) & 3]); |
| tmp = (v >> 8) & 0x3f; |
| if (tmp == 0) |
| fprintf(stdout, " Programmable burst length unlimited\n"); |
| else |
| fprintf(stdout, |
| " Programmable burst length %d longwords\n", |
| tmp); |
| fprintf(stdout, |
| " %s endian data buffers\n" |
| " Descriptor skip length %d longwords\n" |
| " %s bus arbitration scheme\n" |
| , |
| v & (1 << 7) ? "Big" : "Little", |
| (v >> 2) & 0x1f, |
| v & (1 << 1) ? "Round-robin" : "RX-has-priority"); |
| if (v & (1 << 0)) |
| fprintf(stdout, " Software reset asserted\n"); |
| |
| /* |
| * CSR3, 4 |
| */ |
| print_ring_addresses(data[3], data[4]); |
| |
| /* |
| * CSR5 |
| */ |
| v = data[5]; |
| fprintf(stdout, |
| "0x28: CSR5 (Status) 0x%08x\n" |
| "%s" |
| " Transmit process %s\n" |
| " Receive process %s\n" |
| " Link %s\n" |
| , |
| v, |
| v & (1 << 13) ? csr5_buserr[(v >> 23) & 0x7] : "", |
| csr5_tx_state[(v >> 20) & 0x7], |
| csr5_rx_state[(v >> 17) & 0x7], |
| v & (1 << 12) ? "fail" : "OK"); |
| if (v & (1 << 16)) |
| fprintf(stdout, |
| " Normal interrupts: %s%s%s\n" |
| , |
| v & (1 << 0) ? "TxOK " : "", |
| v & (1 << 2) ? "TxNoBufs " : "", |
| v & (1 << 6) ? "RxOK" : ""); |
| if (v & (1 << 15)) |
| fprintf(stdout, |
| " Abnormal intr: %s%s%s%s%s%s%s%s\n" |
| , |
| v & (1 << 1) ? "TxStop " : "", |
| v & (1 << 3) ? "TxJabber " : "", |
| v & (1 << 5) ? "TxUnder " : "", |
| v & (1 << 7) ? "RxNoBufs " : "", |
| v & (1 << 8) ? "RxStopped " : "", |
| v & (1 << 9) ? "RxTimeout " : "", |
| v & (1 << 10) ? "AUI_TP " : "", |
| v & (1 << 11) ? "FD_Short " : ""); |
| |
| /* |
| * CSR6 |
| */ |
| v = data[6]; |
| fprintf(stdout, |
| "0x30: CSR6 (Operating Mode) 0x%08x\n" |
| "%s" |
| "%s" |
| " Transmit threshold %d bytes\n" |
| " Transmit DMA %sabled\n" |
| "%s" |
| " Operating mode: %s\n" |
| " %s duplex\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| " Receive DMA %sabled\n" |
| " %s filtering mode\n" |
| , |
| v, |
| v & (1<<17) ? " Capture effect enabled\n" : "", |
| v & (1<<16) ? " Back pressure enabled\n" : "", |
| csr6_tx_thresh[(v >> 14) & 3], |
| v & (1<<13) ? "en" : "dis", |
| v & (1<<12) ? " Forcing collisions\n" : "", |
| csr6_om[(v >> 10) & 3], |
| v & (1<<9) ? "Full" : "Half", |
| v & (1<<8) ? " Flaky oscillator disable\n" : "", |
| v & (1<<7) ? " Pass All Multicast\n" : "", |
| v & (1<<6) ? " Promisc Mode\n" : "", |
| v & (1<<5) ? " Start/Stop Backoff Counter\n" : "", |
| v & (1<<4) ? " Inverse Filtering\n" : "", |
| v & (1<<3) ? " Pass Bad Frames\n" : "", |
| v & (1<<2) ? " Hash-only Filtering\n" : "", |
| v & (1<<1) ? "en" : "dis", |
| v & (1<<0) ? "Hash" : "Perfect"); |
| |
| /* |
| * CSR7 |
| */ |
| v = data[7]; |
| fprintf(stdout, |
| "0x38: CSR7 (Interrupt Mask) 0x%08x\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| , |
| v, |
| v & (1<<16) ? " Normal interrupt summary\n" : "", |
| v & (1<<15) ? " Abnormal interrupt summary\n" : "", |
| v & (1<<13) ? " System error\n" : "", |
| v & (1<<12) ? " Link fail\n" : "", |
| v & (1<<11) ? " Full duplex\n" : "", |
| v & (1<<10) ? " AUI_TP pin\n" : "", |
| v & (1<<9) ? " Receive watchdog timeout\n" : "", |
| v & (1<<8) ? " Receive stopped\n" : "", |
| v & (1<<7) ? " Receive buffer unavailable\n" : "", |
| v & (1<<6) ? " Receive interrupt\n" : "", |
| v & (1<<5) ? " Transmit underflow\n" : "", |
| v & (1<<3) ? " Transmit jabber timeout\n" : "", |
| v & (1<<2) ? " Transmit buffer unavailable\n" : "", |
| v & (1<<1) ? " Transmit stopped\n" : "", |
| v & (1<<0) ? " Transmit interrupt\n" : ""); |
| |
| /* |
| * CSR8 |
| */ |
| print_rx_missed(data[8]); |
| |
| /* |
| * CSR9 |
| */ |
| v = data[9]; |
| fprintf(stdout, |
| "0x48: CSR9 (Ethernet Address ROM) 0x%08x\n", v); |
| |
| /* |
| * CSR11 |
| */ |
| v = data[11]; |
| fprintf(stdout, |
| "0x58: CSR11 (Full Duplex Autoconfig) 0x%08x\n", v); |
| |
| /* |
| * CSR12 |
| */ |
| v = data[12]; |
| fprintf(stdout, |
| "0x60: CSR12 (SIA Status) 0x%08x\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| " AUI_TP pin: %s\n" |
| , |
| v, |
| v & (1<<7) ? " PLL sampler high\n" : "", |
| v & (1<<6) ? " PLL sampler low\n" : "", |
| v & (1<<5) ? " PLL self-test pass\n" : "", |
| v & (1<<4) ? " PLL self-test done\n" : "", |
| v & (1<<3) ? " Autopolarity state\n" : "", |
| v & (1<<2) ? " Link fail\n" : "", |
| v & (1<<1) ? " Network connection error\n" : "", |
| v & (1<<0) ? "AUI" : "TP"); |
| |
| /* |
| * CSR13 |
| */ |
| v = data[13]; |
| fprintf(stdout, |
| "0x68: CSR13 (SIA Connectivity) 0x%08x\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| " External port output multiplexer select: %u%u%u%u\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| " %s interface selected\n" |
| "%s" |
| "%s" |
| "%s" |
| , |
| v, |
| v & (1<<15) ? " Enable pins 5, 6, 7\n" : "", |
| v & (1<<14) ? " Enable pins 2, 4\n" : "", |
| v & (1<<13) ? " Enable pins 1, 3\n" : "", |
| v & (1<<12) ? " Input enable\n" : "", |
| v & (1<<11) ? 1 : 0, |
| v & (1<<10) ? 1 : 0, |
| v & (1<<9) ? 1 : 0, |
| v & (1<<8) ? 1 : 0, |
| v & (1<<7) ? " APLL start\n" : "", |
| v & (1<<6) ? " Serial interface input multiplexer\n" : "", |
| v & (1<<5) ? " Encoder input multiplexer\n" : "", |
| v & (1<<4) ? " SIA PLL external input enable\n" : "", |
| v & (1<<3) ? "AUI" : "10base-T", |
| v & (1<<2) ? " CSR autoconfiguration\n" : "", |
| v & (1<<1) ? " AUI_TP pin autoconfiguration\n" : "", |
| v & (1<<0) ? " SIA reset\n" : ""); |
| |
| /* |
| * CSR14 |
| */ |
| v = data[14]; |
| fprintf(stdout, |
| "0x70: CSR14 (SIA Transmit and Receive) 0x%08x\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| " %s\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| , |
| v, |
| v & (1<<14) ? " Set polarity plus\n" : "", |
| v & (1<<13) ? " Autopolarity enable\n" : "", |
| v & (1<<12) ? " Link test enable\n" : "", |
| v & (1<<11) ? " Heartbeat enable\n" : "", |
| v & (1<<10) ? " Collision detect enable\n" : "", |
| v & (1<<9) ? " Collision squelch enable\n" : "", |
| v & (1<<8) ? " Receive squelch enable\n" : "", |
| csr14_tp_comp[(v >> 4) & 0x3], |
| v & (1<<3) ? " Link pulse send enable\n" : "", |
| v & (1<<2) ? " Driver enable\n" : "", |
| v & (1<<1) ? " Loopback enable\n" : "", |
| v & (1<<0) ? " Encoder enable\n" : ""); |
| |
| /* |
| * CSR15 |
| */ |
| v = data[15]; |
| fprintf(stdout, |
| "0x78: CSR15 (SIA General) 0x%08x\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| , |
| v, |
| v & (1<<13) ? " Force receiver low\n" : "", |
| v & (1<<12) ? " PLL self-test start\n" : "", |
| v & (1<<11) ? " Force link fail\n" : "", |
| v & (1<<9) ? " Force unsquelch\n" : "", |
| v & (1<<8) ? " Test clock\n" : "", |
| v & (1<<5) ? " Receive watchdog release\n" : "", |
| v & (1<<4) ? " Receive watchdog disable\n" : "", |
| v & (1<<2) ? " Jabber clock\n" : "", |
| v & (1<<1) ? " Host unjab\n" : "", |
| v & (1<<0) ? " Jabber disable\n" : ""); |
| } |
| |
| static void |
| de21041_dump_regs(struct ethtool_drvinfo *info, struct ethtool_regs *regs) |
| { |
| u32 tmp, v, *data = (u32 *)regs->data; |
| |
| fprintf(stdout, "21041 Registers\n"); |
| fprintf(stdout, "---------------\n"); |
| |
| /* |
| * CSR0 |
| */ |
| v = data[0]; |
| fprintf(stdout, |
| "0x00: CSR0 (Bus Mode) 0x%08x\n" |
| " %s endian descriptors\n" |
| " %s\n" |
| " %s address space\n" |
| " Cache alignment: %s\n" |
| , |
| v, |
| v & (1 << 20) ? "Big" : "Little", |
| csr0_tap[(v >> 17) & 3], |
| v & (1 << 16) ? "Diagnostic" : "Standard", |
| csr0_cache_al[(v >> 14) & 3]); |
| tmp = (v >> 8) & 0x3f; |
| if (tmp == 0) |
| fprintf(stdout, " Programmable burst length unlimited\n"); |
| else |
| fprintf(stdout, |
| " Programmable burst length %d longwords\n", |
| tmp); |
| fprintf(stdout, |
| " %s endian data buffers\n" |
| " Descriptor skip length %d longwords\n" |
| " %s bus arbitration scheme\n" |
| , |
| v & (1 << 7) ? "Big" : "Little", |
| (v >> 2) & 0x1f, |
| v & (1 << 1) ? "Round-robin" : "RX-has-priority"); |
| if (v & (1 << 0)) |
| fprintf(stdout, " Software reset asserted\n"); |
| |
| /* |
| * CSR3, 4 |
| */ |
| print_ring_addresses(data[3], data[4]); |
| |
| /* |
| * CSR5 |
| */ |
| v = data[5]; |
| fprintf(stdout, |
| "0x28: CSR5 (Status) 0x%08x\n" |
| "%s" |
| " Transmit process %s\n" |
| " Receive process %s\n" |
| " Link %s\n" |
| , |
| v, |
| v & (1 << 13) ? csr5_buserr[(v >> 23) & 0x7] : "", |
| csr5_tx_state[(v >> 20) & 0x7], |
| csr5_rx_state[(v >> 17) & 0x7], |
| v & (1 << 12) ? "fail" : "OK"); |
| if (v & (1 << 16)) |
| fprintf(stdout, |
| " Normal interrupts: %s%s%s%s%s\n" |
| , |
| v & (1 << 0) ? "TxOK " : "", |
| v & (1 << 2) ? "TxNoBufs " : "", |
| v & (1 << 6) ? "RxOK" : "", |
| v & (1 << 11) ? "TimerExp " : "", |
| v & (1 << 14) ? "EarlyRx " : ""); |
| if (v & (1 << 15)) |
| fprintf(stdout, |
| " Abnormal intr: %s%s%s%s%s%s%s\n" |
| , |
| v & (1 << 1) ? "TxStop " : "", |
| v & (1 << 3) ? "TxJabber " : "", |
| v & (1 << 4) ? "ANC " : "", |
| v & (1 << 5) ? "TxUnder " : "", |
| v & (1 << 7) ? "RxNoBufs " : "", |
| v & (1 << 8) ? "RxStopped " : "", |
| v & (1 << 9) ? "RxTimeout " : ""); |
| |
| /* |
| * CSR6 |
| */ |
| v = data[6]; |
| fprintf(stdout, |
| "0x30: CSR6 (Operating Mode) 0x%08x\n" |
| "%s" |
| "%s" |
| " Transmit threshold %d bytes\n" |
| " Transmit DMA %sabled\n" |
| "%s" |
| " Operating mode: %s\n" |
| " %s duplex\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| " Receive DMA %sabled\n" |
| " %s filtering mode\n" |
| , |
| v, |
| v & (1<<31) ? " Special capture effect enabled\n" : "", |
| v & (1<<17) ? " Capture effect enabled\n" : "", |
| csr6_tx_thresh[(v >> 14) & 3], |
| v & (1<<13) ? "en" : "dis", |
| v & (1<<12) ? " Forcing collisions\n" : "", |
| csr6_om[(v >> 10) & 3], |
| v & (1<<9) ? "Full" : "Half", |
| v & (1<<8) ? " Flaky oscillator disable\n" : "", |
| v & (1<<7) ? " Pass All Multicast\n" : "", |
| v & (1<<6) ? " Promisc Mode\n" : "", |
| v & (1<<5) ? " Start/Stop Backoff Counter\n" : "", |
| v & (1<<4) ? " Inverse Filtering\n" : "", |
| v & (1<<3) ? " Pass Bad Frames\n" : "", |
| v & (1<<2) ? " Hash-only Filtering\n" : "", |
| v & (1<<1) ? "en" : "dis", |
| v & (1<<0) ? "Hash" : "Perfect"); |
| |
| /* |
| * CSR7 |
| */ |
| v = data[7]; |
| fprintf(stdout, |
| "0x38: CSR7 (Interrupt Mask) 0x%08x\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| , |
| v, |
| v & (1<<16) ? " Normal interrupt summary\n" : "", |
| v & (1<<15) ? " Abnormal interrupt summary\n" : "", |
| v & (1<<14) ? " Early receive interrupt\n" : "", |
| v & (1<<13) ? " System error\n" : "", |
| v & (1<<12) ? " Link fail\n" : "", |
| v & (1<<11) ? " Timer expired\n" : "", |
| v & (1<<9) ? " Receive watchdog timeout\n" : "", |
| v & (1<<8) ? " Receive stopped\n" : "", |
| v & (1<<7) ? " Receive buffer unavailable\n" : "", |
| v & (1<<6) ? " Receive interrupt\n" : "", |
| v & (1<<5) ? " Transmit underflow\n" : "", |
| v & (1<<4) ? " Link pass\n" : "", |
| v & (1<<3) ? " Transmit jabber timeout\n" : "", |
| v & (1<<2) ? " Transmit buffer unavailable\n" : "", |
| v & (1<<1) ? " Transmit stopped\n" : "", |
| v & (1<<0) ? " Transmit interrupt\n" : ""); |
| |
| /* |
| * CSR8 |
| */ |
| print_rx_missed(data[8]); |
| |
| /* |
| * CSR9 |
| */ |
| v = data[9]; |
| fprintf(stdout, |
| "0x48: CSR9 (Boot and Ethernet ROMs) 0x%08x\n" |
| " Select bits: %s%s%s%s%s%s\n" |
| " Data: %d%d%d%d%d%d%d%d\n" |
| , |
| v, |
| v & (1<<15) ? "Mode " : "", |
| v & (1<<14) ? "Read " : "", |
| v & (1<<13) ? "Write " : "", |
| v & (1<<12) ? "BootROM " : "", |
| v & (1<<11) ? "SROM " : "", |
| v & (1<<10) ? "ExtReg " : "", |
| v & (1<<7) ? 1 : 0, |
| v & (1<<6) ? 1 : 0, |
| v & (1<<5) ? 1 : 0, |
| v & (1<<4) ? 1 : 0, |
| v & (1<<3) ? 1 : 0, |
| v & (1<<2) ? 1 : 0, |
| v & (1<<1) ? 1 : 0, |
| v & (1<<0) ? 1 : 0); |
| |
| /* |
| * CSR10 |
| */ |
| v = data[10]; |
| fprintf(stdout, |
| "0x50: CSR10 (Boot ROM Address) 0x%08x\n", v); |
| |
| /* |
| * CSR11 |
| */ |
| v = data[11]; |
| fprintf(stdout, |
| "0x58: CSR11 (General Purpose Timer) 0x%08x\n" |
| "%s" |
| " Timer value: %u cycles\n" |
| , |
| v, |
| v & (1<<16) ? " Continuous mode\n" : "", |
| v & 0xffff); |
| |
| /* |
| * CSR12 |
| */ |
| v = data[12]; |
| fprintf(stdout, |
| "0x60: CSR12 (SIA Status) 0x%08x\n" |
| " Link partner code word 0x%04x\n" |
| "%s" |
| " NWay state: %s\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| , |
| v, |
| v >> 16, |
| v & (1<<15) ? " Link partner negotiable\n" : "", |
| csr12_nway_state[(v >> 12) & 0x7], |
| v & (1<<11) ? " Transmit remote fault\n" : "", |
| v & (1<<10) ? " Unstable NLP detected\n" : "", |
| v & (1<<9) ? " Non-selected port receive activity\n" : "", |
| v & (1<<8) ? " Selected port receive activity\n" : "", |
| v & (1<<7) ? " PLL sampler high\n" : "", |
| v & (1<<6) ? " PLL sampler low\n" : "", |
| v & (1<<5) ? " PLL self-test pass\n" : "", |
| v & (1<<4) ? " PLL self-test done\n" : "", |
| v & (1<<3) ? " Autopolarity state\n" : "", |
| v & (1<<2) ? " Link fail\n" : "", |
| v & (1<<1) ? " Network connection error\n" : ""); |
| |
| /* |
| * CSR13 |
| */ |
| v = data[13]; |
| fprintf(stdout, |
| "0x68: CSR13 (SIA Connectivity) 0x%08x\n" |
| " SIA Diagnostic Mode 0x%04x\n" |
| " %s\n" |
| "%s" |
| "%s" |
| , |
| v, |
| (v >> 4) & 0xfff, |
| v & (1<<3) ? "AUI/BNC port" : "10base-T port", |
| v & (1<<2) ? " CSR autoconfiguration enabled\n" : "", |
| v & (1<<0) ? " SIA register reset asserted\n" : ""); |
| |
| /* |
| * CSR14 |
| */ |
| v = data[14]; |
| fprintf(stdout, |
| "0x70: CSR14 (SIA Transmit and Receive) 0x%08x\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| " %s\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| , |
| v, |
| v & (1<<15) ? " 10base-T/AUI autosensing\n" : "", |
| v & (1<<14) ? " Set polarity plus\n" : "", |
| v & (1<<13) ? " Autopolarity enable\n" : "", |
| v & (1<<12) ? " Link test enable\n" : "", |
| v & (1<<11) ? " Heartbeat enable\n" : "", |
| v & (1<<10) ? " Collision detect enable\n" : "", |
| v & (1<<9) ? " Collision squelch enable\n" : "", |
| v & (1<<8) ? " Receive squelch enable\n" : "", |
| v & (1<<7) ? " Autonegotiation enable\n" : "", |
| v & (1<<6) ? " Must Be One\n" : "", |
| csr14_tp_comp[(v >> 4) & 0x3], |
| v & (1<<3) ? " Link pulse send enable\n" : "", |
| v & (1<<2) ? " Driver enable\n" : "", |
| v & (1<<1) ? " Loopback enable\n" : "", |
| v & (1<<0) ? " Encoder enable\n" : ""); |
| |
| /* |
| * CSR15 |
| */ |
| v = data[15]; |
| fprintf(stdout, |
| "0x78: CSR15 (SIA General) 0x%08x\n" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| "%s" |
| " %s port selected\n" |
| "%s" |
| "%s" |
| "%s" |
| , |
| v, |
| v & (1<<15) ? " GP LED2 on\n" : "", |
| v & (1<<14) ? " GP LED2 enable\n" : "", |
| v & (1<<13) ? " Force receiver low\n" : "", |
| v & (1<<12) ? " PLL self-test start\n" : "", |
| v & (1<<11) ? " LED stretch disable\n" : "", |
| v & (1<<10) ? " Force link fail\n" : "", |
| v & (1<<9) ? " Force unsquelch\n" : "", |
| v & (1<<8) ? " Test clock\n" : "", |
| v & (1<<7) ? " GP LED1 on\n" : "", |
| v & (1<<6) ? " GP LED1 enable\n" : "", |
| v & (1<<5) ? " Receive watchdog release\n" : "", |
| v & (1<<4) ? " Receive watchdog disable\n" : "", |
| v & (1<<3) ? "AUI" : "BNC", |
| v & (1<<2) ? " Jabber clock\n" : "", |
| v & (1<<1) ? " Host unjab\n" : "", |
| v & (1<<0) ? " Jabber disable\n" : ""); |
| } |
| |
| int |
| de2104x_dump_regs(struct ethtool_drvinfo *info, struct ethtool_regs *regs) |
| { |
| unsigned int de21040 = regs->version & 1; |
| |
| if (de21040) |
| de21040_dump_regs(info, regs); |
| else |
| de21041_dump_regs(info, regs); |
| |
| return 0; |
| } |
| |