Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 6 Mar 2015 12:45:22 +0000
From:      Matt Dooner <dclscratch@gmail.com>
To:        freebsd-net@freebsd.org
Cc:        matt@doonerconsulting.com
Subject:   cpsw/atphy network drivers
Message-ID:  <CAJi99x3QuM2rh4OZBJMCSB3%2BU2Gkaqh6EUiax54PV8cR5ZxaWg@mail.gmail.com>

next in thread | raw e-mail | index | archive | help
Hello,

I am having some trouble configurating the network driver on a TI
T335x-based CoM system
(http://www.compulab.co.il/products/computer-on-modules/cm-t335/). It
uses the "the AM335x integrated Ethernet MAC coupled with the AR8033
RGMII Ethernet PHY from Atheros". U-Boot is able to find the device as
expected:

CM-T335w # mii device
MII devices: 'cpsw'
Current device: 'cpsw'

CM-T335w # mdio list
cpsw:
0 - AR8031/AR8033 <--> cpsw

CM-T335w # dhcp
link up on port 0, speed 100, half duplex
BOOTP broadcast 1
DHCP client bound to address 10.1.192.67
CM-T335w # ping 8.8.8.8
link up on port 0, speed 100, half duplex
Using cpsw device
host 8.8.8.8 is alive

And devinfo(8) reports the correct modules being loaded:

root@beaglebone:~ # devinfo
nexus0
  ofwbus0
    simplebus0
      aintc0
      ti_scm0
      am335x_prcm0
      am335x_dmtimer0
      ti_adc0
      gpio0
        gpioc0
        gpiobus0
      uart0
      ti_edma30
      sdhci_ti0
        mmc0
          mmcsd0
      cpsw0
        miibus0
          atphy0
      ...

The interface does not appear to be sending or receiving any traffic
over the physical interface, and does not report receiving any packets
at all. I have enabled debug mode on the cpsw driver:

root@beaglebone:~ # ifconfig cpsw0 debug
root@beaglebone:~ # ifconfig cpsw0 up
09:54:45 cpsw_ioctl SIOCSIFFLAGS: UP but not RUNNING; starting up
09:54:45 cpsw_init_locked
root@beaglebone:~ # dhclient cpsw0
09:54:56 cpsw_ifmedia_sts
09:54:56 cpsw_ioctl SIOCSIFFLAGS: UP & RUNNING (changed=0x0)
09:54:56 cpsw_init
09:54:56 cpsw_init_locked
DHCPDISCOVER on cpsw0 to 255.255.255.255 port 67 interval 5
09:54:56 cpsw_tx_enqueue Queueing TX packet: 1 segments + 0 pad bytes
09:54:57 cpsw_tx_dequeue TX removing completed packet
...

A DHCP address is never negotiated.

root@beaglebone:~ # ifconfig
cpsw0: flags=8847<UP,BROADCAST,DEBUG,RUNNING,SIMPLEX,MULTICAST> metric
0 mtu 1500
        options=8000b<RXCSUM,TXCSUM,VLAN_MTU,LINKSTATE>
        ether 1c:ba:8c:ed:40:99
        inet 0.0.0.0 netmask 0xff000000 broadcast 255.255.255.255
09:58:57 cpsw_ifmedia_sts
09:58:57 cpsw_ifmedia_sts
09:58:57 cpsw_ifmedia_sts
        media: Ethernet autoselect (100baseTX <half-duplex>)
        status: active
        nd6 options=29<PERFORMNUD,IFDISABLED,AUTO_LINKLOCAL>
lo0: flags=8049<UP,LOOPBACK,RUNNING,MULTICAST> metric 0 mtu 16384
        options=600003<RXCSUM,TXCSUM,RXCSUM_IPV6,TXCSUM_IPV6>
        inet6 ::1 prefixlen 128
        inet6 fe80::1%lo0 prefixlen 64 scopeid 0x2
        inet 127.0.0.1 netmask 0xff000000
        nd6 options=21<PERFORMNUD,AUTO_LINKLOCAL>

When connected to another computer running Wireshark no frames are
recorded as having been transmitted over the interface. The cpsw
driver never reports receiving any packets, even when I use a tool
like Ostinato to craft frames addressed to the MAC of the NIC on the
board.

The network interface works perfectly in Debian Linux:

root@cm-debian:~# ethtool eth2

Settings for eth2:

Supported ports: [ TP AUI BNC MII FIBRE ]
Supported link modes:   10baseT/Half 10baseT/Full
                        100baseT/Half 100baseT/Full
                        1000baseT/Full
Supported pause frame use: No
Supports auto-negotiation: Yes
Advertised link modes:  10baseT/Half 10baseT/Full
                        100baseT/Half 100baseT/Full
                        1000baseT/Full
Advertised pause frame use: No
Advertised auto-negotiation: Yes
Speed: 100Mb/s
Duplex: Half
Port: MII
PHYAD: 0
Transceiver: external
Auto-negotiation: on
Current message level: 0x00000000 (0)
Link detected: yes

root@cm-debian:~# ethtool -i eth2
driver: TI CPSW Driver v1.0
version: 1.0
firmware-version:
bus-info: cpsw
supports-statistics: no
supports-test: no
supports-eeprom-access: no
supports-register-dump: no
supports-priv-flags: no

Can anyone reccomend some next steps for debugging this network
interface in FreeBSD? I seem to have exhausted the options I've found
in the handbook, man pages, and google searches.

It is more relevant for freebsd-embedded, but if anyone is curious my
freebsd-crochet board config is forked at
https://github.com/MattDooner/crochet-freebsd/ and u-boot changes
against 2014.04 at https://github.com/MattDooner/u-boot

Cheers,
Matt



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CAJi99x3QuM2rh4OZBJMCSB3%2BU2Gkaqh6EUiax54PV8cR5ZxaWg>