Ethernet Over USB net helper script and docs

- for CDC ECM driver

Squashed commit of the following:

commit aa9a715498e15ad46d43318a663d296f38160cf8
Author: Adam Feuer <adam@starcat.io>
Date:   Mon Feb 24 16:42:52 2020 -0800

    code formatting; removed ping

commit 56520b7f7e2b7f03697eacc2f2b5450b0f7af676
Author: Adam Feuer <adam@starcat.io>
Date:   Mon Feb 24 16:42:32 2020 -0800

    add description of netusb.sh helper script

commit afee3d33b1e66138afb7e9713d86b765ceab55b0
Author: Adam Feuer <adam@starcat.io>
Date:   Mon Feb 24 16:41:40 2020 -0800

    readme formatting

commit 772e36021f4aee2ba1df408ad29d8b9adedeed9f
Author: Adam Feuer <adam@starcat.io>
Date:   Sun Feb 23 11:38:50 2020 -0800

    updated readme, removed redundant configs

commit 082785178aa6e0d1578034b4b163785fdcb61f22
Author: Adam Feuer <adam@starcat.io>
Date:   Sat Feb 22 17:40:05 2020 -0800

    README, defconfig, and helper script improvements
This commit is contained in:
Adam Feuer 2020-02-24 16:44:51 -08:00 committed by Xiang Xiao
parent 90eed5c8f8
commit 511e548613
5 changed files with 193 additions and 201 deletions

View file

@ -790,7 +790,9 @@ Networking
Networking support via the can be added to NSH by selecting the following
configuration options. The SAMA5D36 supports two different Ethernet MAC
peripherals: (1) The 10/100Base-T EMAC peripheral and (2) the
10/100/1000Base-T GMAC peripheral.
10/100/1000Base-T GMAC peripheral. Ethernet over USB using the
CDC ECM driver is also supported, and should work on Linux, macOS, and
Windows.
Selecting the EMAC peripheral
-----------------------------
@ -834,6 +836,21 @@ Networking
PHY selection. Later in the configuration steps, you will need to select
the KSZ9081 PHY for GMAC (See below)
Selecting Ethernet over USB (CDC ECM driver)
--------------------------------------------
This uses the USB 2.0 connector labeled USB-A. On the host computer you will
need to configure the CDC ECM Ethernet over USB driver (see below for Linux
configuration script).
CONFIG_USBDEV=y
CONFIG_USBDEV_DMA=y
CONFIG_USBDEV_DUALSPEED=y
CONFIG_NET_CDCECM=y
CONFIG_NET_ETH_PKTSIZE=1514
You can also use the defconfig file in `boards/arm/sama5/sama5d3-xplained/configs/ethernet-over-usb-2-high-speed`.
Common configuration settings
-----------------------------
@ -1019,6 +1036,69 @@ Networking
CONFIG_NSH_NETINIT_RETRYMSEC=2000 : Configure the network monitor as you like
CONFIG_NSH_NETINIT_SIGNO=18
Ethernet Over USB Configuration Script
--------------------------------------
There is a configuration script for Linux that will configure the USB Ethernet interface,
it is in `tools/netusb.sh`. You can use it as follows:
Once you boot a NuttX system with the CDC ECM Ethernet over USB device, the Linux network interface
will be added to your system. You should see something like the following messages in
/var/log/kern.log:
[302074.552879] usb 1-2: new high-speed USB device number 107 using ehci-pci
[302074.718264] usb 1-2: New USB device found, idVendor=0525, idProduct=a4a2, bcdDevice= 1.00
[302074.718267] usb 1-2: New USB device strings: Mfr=1, Product=2, SerialNumber=3
[302074.718269] usb 1-2: Product: CDC/ECM Ethernet
[302074.718271] usb 1-2: Manufacturer: NuttX
[302074.718272] usb 1-2: SerialNumber: 0
[302074.760638] cdc_ether 1-2:1.0 usb0: register 'cdc_ether' at usb-0000:02:03.0-2, CDC Ethernet Device, 02:00:00:11:22:33
[302074.796215] cdc_ether 1-2:1.0 ens160u4u2: renamed from usb0
If you execute the command 'ifconfig -a' you should see a new interface:
$ ifconfig -a
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.46.156 netmask 255.255.255.0 broadcast 192.168.46.255
inet6 fe80::20c:29ff:fe57:d0f8 prefixlen 64 scopeid 0x20<link>
ether 00:0c:29:57:d0:f8 txqueuelen 1000 (Ethernet)
RX packets 7628014 bytes 2002078802 (2.0 GB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 6040388 bytes 5327276865 (5.3 GB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
ens160u4u2: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet6 fe80::ff:fe11:2233 prefixlen 64 scopeid 0x20<link>
ether 02:00:00:11:22:33 txqueuelen 1000 (Ethernet)
RX packets 36798 bytes 51705300 (51.7 MB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 24196 bytes 1312512 (1.3 MB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
ens33 is the host Ethernet or wireless LAN interface. ens160u4u2 is the USB Ethernet
interface.
The script will bring up the interface, configure it, and set up routes and IP Tables rules so the
nuttx system can access the internet:
$ sudo ./tools/netusb.sh ens33 ens160u4u2 on
This will bring down the interface, configure it, and delete routes and IP Tables rules:
$ sudo ./tools/netusb.sh ens33 ens160u4u2 off
Now that the new interface has an IP address, you can ping the NuttX box at 10.0.0.2
(or whatever IP address you configured it to have). If you configured the telnet daemon
and started it, you should be able to telnet to the board using:
$ telnet 10.0.0.2
The helper script also sets up Network Address Translation (NAT) so the NuttX system
can access the Internet. If that is not what you want, you can remove the iptables
AT25 Serial FLASH
=================
@ -1380,86 +1460,10 @@ USB High-Speed Device
CDC/ECM Ethernet Over USB
-------------------------
This will select the CDC/ECM Ethernet over USB device. Defaults for the other
options should be okay.
This allows networking to the host system via Ethernet over USB. See the
Networking section for configuration. On USB 2.0 High Speed, the CDC ECM
driver uses DMA and can transfer 4.4 MBytes/sec (34 Mbits/sec).
CONFIG_NET_CDCECM=y
CONFIG_CDCECM_EP0MAXPACKET=64
CONFIG_CDCECM_EPINTIN=1
CONFIG_CDCECM_EPINTIN_FSSIZE=16
CONFIG_CDCECM_EPINTIN_HSSIZE=16
CONFIG_CDCECM_EPBULKOUT=5
CONFIG_CDCECM_EPBULKOUT_FSSIZE=64
CONFIG_CDCECM_EPBULKOUT_HSSIZE=512 # needed for non-fragmentation IP and ICMP packets in HS mode
CONFIG_CDCECM_EPBULKIN=2
CONFIG_CDCECM_EPBULKIN_FSSIZE=64
CONFIG_CDCECM_EPBULKIN_HSSIZE=512 # needed for non-fragmentation IP and ICMP packets in HS mode
CONFIG_CDCECM_VENDORID=0x0525
CONFIG_CDCECM_PRODUCTID=0xa4a2
CONFIG_CDCECM_VENDORSTR="NuttX"
CONFIG_CDCECM_PRODUCTSTR="CDC/ECM Ethernet"
There are two defconfig files that have been tested with these configurations:
ethernet-over-usb/defconfig
ethernet-over-usb-telnetd/defconfig
The latter has a telnetd enabled, so once the system boots, you can issue the telnetd command,
and then telnet into it from the host.
To use them, copy them to .config, and run 'make menuconfig' (you don't have to change anything),
then save the file. Then run 'make' to make NuttX.
On Linux, a helper script is provided called helpers/netusb-up.sh. This script can be used
to configure the Linux USB Ethernet Gadget network interface. Once you boot a NuttX system with the
CDC ECM Ethernet over USB device, the Linux network interface will be added to your system. You should
see something like the following messages in /var/log/kern.log:
[302074.552879] usb 1-2: new high-speed USB device number 107 using ehci-pci
[302074.718264] usb 1-2: New USB device found, idVendor=0525, idProduct=a4a2, bcdDevice= 1.00
[302074.718267] usb 1-2: New USB device strings: Mfr=1, Product=2, SerialNumber=3
[302074.718269] usb 1-2: Product: CDC/ECM Ethernet
[302074.718271] usb 1-2: Manufacturer: NuttX
[302074.718272] usb 1-2: SerialNumber: 0
[302074.760638] cdc_ether 1-2:1.0 usb0: register 'cdc_ether' at usb-0000:02:03.0-2, CDC Ethernet Device, 02:00:00:11:22:33
[302074.796215] cdc_ether 1-2:1.0 ens35u2: renamed from usb0
If you execute the command 'ifconfig -a' you should see a new interface:
$ ifconfig -a
ens35u2: flags=4098<BROADCAST,MULTICAST> mtu 576
ether 02:00:00:11:22:33 txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
If you run the netusb-up.sh script, then do ifconfig, you should see the following:
$ sudo ./netusb-up.sh
$ ifconfig -a
ens35u2: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 576
ether 02:00:00:11:22:33 txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 15 bytes 2477 (2.4 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
ens35u2:0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 576
inet 10.0.0.1 netmask 255.255.255.0 broadcast 10.0.0.255
ether 02:00:00:11:22:33 txqueuelen 1000 (Ethernet)
Now that the new interface has an IP address, you can ping the NuttX box at 10.0.0.2
(or whatever IP address you configured it to have). If you used the telnet defconfig,
you should be able to telnet to the board using:
$ telnet 10.0.0.2
The helper script also sets up Network Address Translation (NAT) so the NuttX system
can access the Internet. If that is not what you want, you can remove the iptables
NAT commands from the script.
Debugging USB Device
--------------------

View file

@ -25,11 +25,13 @@ CONFIG_BOARDCTL_USBDEVCTRL=y
CONFIG_BOARD_LOOPSPERMSEC=65775
CONFIG_BOOT_RUNFROMSDRAM=y
CONFIG_BUILTIN=y
CONFIG_CDCECM_EPINTIN_HSSIZE=16
CONFIG_DEBUG_FEATURES=y
CONFIG_DEBUG_SYMBOLS=y
CONFIG_DEV_LOOP=y
CONFIG_EXAMPLES_HELLO=y
CONFIG_EXAMPLES_TCPBLASTER=y
CONFIG_EXAMPLES_TCPBLASTER_GROUPSIZE=200
CONFIG_EXAMPLES_TCPECHO=y
CONFIG_EXAMPLES_WGET=y
CONFIG_EXAMPLES_WGET_URL="http://10.0.0.1/"
CONFIG_FAT_LCNAMES=y
@ -37,11 +39,13 @@ CONFIG_FAT_LFN=y
CONFIG_FS_FAT=y
CONFIG_FS_PROCFS=y
CONFIG_FS_PROCFS_EXCLUDE_VERSION=y
CONFIG_FS_ROMFS=y
CONFIG_HAVE_CXX=y
CONFIG_HAVE_CXXINITIALIZE=y
CONFIG_INTELHEX_BINARY=y
CONFIG_IOB_NBUFFERS=24
CONFIG_IOB_THROTTLE=0
CONFIG_INTERPRETERS_CHIBI_SCHEME=y
CONFIG_IOB_NBUFFERS=72
CONFIG_IOB_THROTTLE=16
CONFIG_MAX_TASKS=16
CONFIG_MAX_WDOGPARMS=2
CONFIG_MMCSD=y
@ -49,17 +53,18 @@ CONFIG_NETINIT_NETLOCAL=y
CONFIG_NETINIT_NOMAC=y
CONFIG_NETUTILS_NETLIB_GENERICURLPARSER=y
CONFIG_NETUTILS_TELNETC=y
CONFIG_NETUTILS_TELNETD=y
CONFIG_NETUTILS_WEBCLIENT=y
CONFIG_NET_ARP_IPIN=y
CONFIG_NET_ARP_SEND=y
CONFIG_NET_BROADCAST=y
CONFIG_NET_CDCECM=y
CONFIG_NET_ETH_PKTSIZE=1514
CONFIG_NET_ICMP=y
CONFIG_NET_ICMP_SOCKET=y
CONFIG_NET_ROUTE=y
CONFIG_NET_STATISTICS=y
CONFIG_NET_TCP=y
CONFIG_NET_TCPBACKLOG=y
CONFIG_NET_TCP_NOTIFIER=y
CONFIG_NET_TCP_WRITE_BUFFERS=y
CONFIG_NET_UDP=y
@ -69,6 +74,7 @@ CONFIG_NSH_ARCHINIT=y
CONFIG_NSH_BUILTIN_APPS=y
CONFIG_NSH_FILEIOSIZE=512
CONFIG_NSH_PROMPT_STRING="nsh> "
CONFIG_NSH_ROMFSETC=y
CONFIG_PREALLOC_MQ_MSGS=4
CONFIG_PREALLOC_TIMERS=4
CONFIG_PREALLOC_WDOGS=16
@ -96,8 +102,13 @@ CONFIG_SAMA5_PIO_IRQ=y
CONFIG_SAMA5_UART1=y
CONFIG_SAMA5_UDPHS=y
CONFIG_SCHED_HPWORK=y
CONFIG_SCHED_LPNTHREADS=2
CONFIG_SCHED_LPWORK=y
CONFIG_SCHED_WAITPID=y
CONFIG_SDCLONE_DISABLE=y
CONFIG_SERIAL_TERMIOS=y
CONFIG_SIG_DEFAULT=y
CONFIG_SIG_EVTHREAD=y
CONFIG_START_DAY=31
CONFIG_START_MONTH=7
CONFIG_START_YEAR=2014
@ -111,8 +122,12 @@ CONFIG_SYSTEM_NSH=y
CONFIG_SYSTEM_NSH_CXXINITIALIZE=y
CONFIG_SYSTEM_PING=y
CONFIG_SYSTEM_VI=y
CONFIG_TTY_SIGINT=y
CONFIG_TTY_SIGSTP=y
CONFIG_USBDEV=y
CONFIG_USBDEV_DMA=y
CONFIG_USBDEV_DUALSPEED=y
CONFIG_USBDEV_TRACE=y
CONFIG_USBDEV_TRACE_NRECORDS=512
CONFIG_USER_ENTRYPOINT="nsh_main"
CONFIG_WDOG_INTRESERVE=2

View file

@ -1,117 +0,0 @@
#
# This file is autogenerated: PLEASE DO NOT EDIT IT.
#
# You can use "make menuconfig" to make any modifications to the installed .config file.
# You can then do "make savedefconfig" to generate a new defconfig file that includes your
# modifications.
#
# CONFIG_DISABLE_OS_API is not set
# CONFIG_NSH_ARGCAT is not set
# CONFIG_NSH_CMDOPT_HEXDUMP is not set
# CONFIG_NSH_CMDPARMS is not set
CONFIG_ARCH="arm"
CONFIG_ARCH_BOARD="sama5d3-xplained"
CONFIG_ARCH_BOARD_SAMA5D3_XPLAINED=y
CONFIG_ARCH_CHIP="sama5"
CONFIG_ARCH_CHIP_ATSAMA5D36=y
CONFIG_ARCH_CHIP_SAMA5=y
CONFIG_ARCH_CHIP_SAMA5D3=y
CONFIG_ARCH_INTERRUPTSTACK=2048
CONFIG_ARCH_IRQPRIO=y
CONFIG_ARCH_LOWVECTORS=y
CONFIG_ARCH_STACKDUMP=y
CONFIG_ARM_SEMIHOSTING_SYSLOG=y
CONFIG_BOARDCTL_USBDEVCTRL=y
CONFIG_BOARD_LOOPSPERMSEC=65775
CONFIG_BOOT_RUNFROMSDRAM=y
CONFIG_BUILTIN=y
CONFIG_CDCECM_EPINTIN_HSSIZE=16
CONFIG_DEBUG_FEATURES=y
CONFIG_DEBUG_SYMBOLS=y
CONFIG_DEV_LOOP=y
CONFIG_EXAMPLES_HELLO=y
CONFIG_EXAMPLES_WGET=y
CONFIG_EXAMPLES_WGET_URL="http://10.0.0.1/"
CONFIG_FAT_LCNAMES=y
CONFIG_FAT_LFN=y
CONFIG_FS_FAT=y
CONFIG_FS_PROCFS=y
CONFIG_FS_PROCFS_EXCLUDE_VERSION=y
CONFIG_HAVE_CXX=y
CONFIG_HAVE_CXXINITIALIZE=y
CONFIG_INTELHEX_BINARY=y
CONFIG_IOB_NBUFFERS=24
CONFIG_IOB_THROTTLE=0
CONFIG_MAX_TASKS=16
CONFIG_MAX_WDOGPARMS=2
CONFIG_MMCSD=y
CONFIG_NETINIT_NETLOCAL=y
CONFIG_NETINIT_NOMAC=y
CONFIG_NETUTILS_NETLIB_GENERICURLPARSER=y
CONFIG_NETUTILS_TELNETC=y
CONFIG_NETUTILS_WEBCLIENT=y
CONFIG_NET_ARP_IPIN=y
CONFIG_NET_ARP_SEND=y
CONFIG_NET_BROADCAST=y
CONFIG_NET_CDCECM=y
CONFIG_NET_ICMP=y
CONFIG_NET_ICMP_SOCKET=y
CONFIG_NET_ROUTE=y
CONFIG_NET_STATISTICS=y
CONFIG_NET_TCP=y
CONFIG_NET_TCP_NOTIFIER=y
CONFIG_NET_TCP_WRITE_BUFFERS=y
CONFIG_NET_UDP=y
CONFIG_NFILE_DESCRIPTORS=8
CONFIG_NFILE_STREAMS=8
CONFIG_NSH_ARCHINIT=y
CONFIG_NSH_BUILTIN_APPS=y
CONFIG_NSH_FILEIOSIZE=512
CONFIG_NSH_PROMPT_STRING="nsh> "
CONFIG_PREALLOC_MQ_MSGS=4
CONFIG_PREALLOC_TIMERS=4
CONFIG_PREALLOC_WDOGS=16
CONFIG_RAM_SIZE=268435456
CONFIG_RAM_START=0x20000000
CONFIG_RAM_VSTART=0x20000000
CONFIG_RAW_BINARY=y
CONFIG_READLINE_CMD_HISTORY=y
CONFIG_READLINE_CMD_HISTORY_LEN=100
CONFIG_READLINE_CMD_HISTORY_LINELEN=120
CONFIG_READLINE_TABCOMPLETION=y
CONFIG_RR_INTERVAL=200
CONFIG_SAMA5D3XPLAINED_528MHZ=y
CONFIG_SAMA5_BOOT_SDRAM=y
CONFIG_SAMA5_DBGU=y
CONFIG_SAMA5_DBGU_CONSOLE=y
CONFIG_SAMA5_DBGU_NOCONFIG=y
CONFIG_SAMA5_HSMC=y
CONFIG_SAMA5_PIOA_IRQ=y
CONFIG_SAMA5_PIOB_IRQ=y
CONFIG_SAMA5_PIOC_IRQ=y
CONFIG_SAMA5_PIOD_IRQ=y
CONFIG_SAMA5_PIOE_IRQ=y
CONFIG_SAMA5_PIO_IRQ=y
CONFIG_SAMA5_UART1=y
CONFIG_SAMA5_UDPHS=y
CONFIG_SCHED_HPWORK=y
CONFIG_SCHED_WAITPID=y
CONFIG_SDCLONE_DISABLE=y
CONFIG_START_DAY=31
CONFIG_START_MONTH=7
CONFIG_START_YEAR=2014
CONFIG_SYMTAB_ORDEREDBYNAME=y
CONFIG_SYSLOG_CHARDEV=y
CONFIG_SYSLOG_TIMESTAMP=y
CONFIG_SYSTEM_CLE_CMD_HISTORY=y
CONFIG_SYSTEM_CLE_CMD_HISTORY_LEN=20
CONFIG_SYSTEM_CLE_CMD_HISTORY_LINELEN=120
CONFIG_SYSTEM_NSH=y
CONFIG_SYSTEM_NSH_CXXINITIALIZE=y
CONFIG_SYSTEM_PING=y
CONFIG_SYSTEM_VI=y
CONFIG_USBDEV=y
CONFIG_USBDEV_DMA=y
CONFIG_USBDEV_DUALSPEED=y
CONFIG_USER_ENTRYPOINT="nsh_main"
CONFIG_WDOG_INTRESERVE=2

View file

@ -787,6 +787,25 @@ mkdeps.c, cnvwindeps.c, mkwindeps.sh, and mknulldeps.sh
eventually be solvable but for now continue to use mkwindeps.sh in
that mixed environment.
netusb.sh
---------
Helper script used to set up the CDC ECM Ethernet Over USB driver,
host routes, and IP Tables rules to support networking with a NuttX
system that has a CDC ECM Ethernet Over USB driver configured. Only
supported on Linux.
General usage:
$ ./tools/netusb.sh
Usage: tools/netusb.sh <main-interface> <usb-net-interface> <on|off>
This has been tested on the SAMA5D3-Xplained board; see
`boards/arm/sama5/sama5d3-xplained/README.txt` for more information on how
to configure the CDC ECM driver for that board.
README.txt
----------

71
tools/netusb.sh Executable file
View file

@ -0,0 +1,71 @@
#!/bin/bash
#****************************************************************************
# tools/simhostroute.sh
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership. The
# ASF licenses this file to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance with the
# License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
#
#****************************************************************************
# USB Ethernet Gadget interface helper script - sets up nuttx to access
# the internet via a host route and IP Tables.
IP_NET="10.0.0.0/24"
IP_NETMASK="255.255.255.0"
IP_BROADCAST="10.0.0.255"
IP_HOST="10.0.0.1"
IP_NUTTX="10.0.0.2"
if [ $# != 3 ]; then
echo "Usage: $0 <main-interface> <usb-net-interface> <on|off>"
exit 1
fi
IF_HOST=$1
IF_USB=$2
STATUS=$3
net_off() {
ip route delete $IP_NET
ip route delete $IP_NUTTX/32
# delete nat rules to clean up
iptables -t nat -D POSTROUTING -o $IF_HOST -j MASQUERADE
iptables -D FORWARD -i $IF_HOST -o $IF_USB -m state --state RELATED,ESTABLISHED -j ACCEPT
iptables -D FORWARD -i $IF_USB -o $IF_HOST -j ACCEPT
ip route show
ifconfig $IF_USB down
}
if [ "$STATUS" == "on" ]; then
net_off
ifconfig $IF_USB up
ifconfig -a
ifconfig $IF_USB add $IP_HOST
ifconfig $IF_USB:0 broadcast $IP_BROADCAST netmask $IP_NETMASK
ip route add $IP_NET dev $IF_USB src $IP_HOST
ip route add $IP_NUTTX/32 dev $IF_USB src $IP_HOST
# nat to allow NuttX to access the internet
iptables -t nat -A POSTROUTING -o $IF_HOST -j MASQUERADE
iptables -A FORWARD -i $IF_HOST -o $IF_USB -m state --state RELATED,ESTABLISHED -j ACCEPT
iptables -A FORWARD -i $IF_USB -o $IF_HOST -j ACCEPT
ip route show
else
net_off
fi