Ethernet
The phyBOARD-Rigel AM67x has 1 external gigabit ethernet ports. All interfaces offer a standard Linux network port that can be programmed using the BSD socket interface. The whole network configuration is handled by the systemd-networkd daemon. The relevant configuration files can be found on the target in /lib/systemd/network/ as well as the BSP in meta-ampliphy/recipes-core/systemd/systemd-conf. To learn more information about the phyCORE-AM67x ethernet serial interface, please see the Ethernet section in the Hardware Manual.
 
Requirements
- CAT5e cable (comes included with the development kit) 
- Network switch connected to a DHCP enabled network 
Establishing a Connection
If a valid connection between the phyBOARD-Rigel AM67x and a DHCP enabled network is made then the phyBOARD-Rigel AM67x will automatically negotiate a connection and will be assigned a unique IPv4 address.
By default, the network configuration supports both DHCP and static IP addressing simultaneously through systemd-networkd. The default static IP address is configured as 192.168.4.11/24. This dual configuration allows the interface to obtain a DHCP address while maintaining the static fallback address, ensuring connectivity in various network environments.
The network configuration is managed by systemd-networkd and allows:
- Automatic IP address assignment via DHCP 
- Static IP fallback (192.168.4.11/24) 
- Multiple IP addresses on the same interface 
- Parallel operation of DHCP and static configuration 
[ 2332.082057] am65-cpsw-nuss 8000000.ethernet eth0: Link is Up - 1Gbps/Full - flow control off
After the connection is established, you can try the following command to ping a host. We’ll ping 8.8.8.8 which is the primary DNS server for Google DNS in this example:
sh-phyboard-rigel-am67xx-1:~# ping 8.8.8.8 -c 10
PING 8.8.8.8 (8.8.8.8) 56(84) bytes of data.
64 bytes from 8.8.8.8: icmp_seq=1 ttl=250 time=39.5 ms
64 bytes from 8.8.8.8: icmp_seq=2 ttl=250 time=39.1 ms
64 bytes from 8.8.8.8: icmp_seq=3 ttl=250 time=38.6 ms
64 bytes from 8.8.8.8: icmp_seq=4 ttl=250 time=39.0 ms
64 bytes from 8.8.8.8: icmp_seq=5 ttl=250 time=39.1 ms
64 bytes from 8.8.8.8: icmp_seq=6 ttl=250 time=47.1 ms
64 bytes from 8.8.8.8: icmp_seq=7 ttl=250 time=52.4 ms
64 bytes from 8.8.8.8: icmp_seq=8 ttl=250 time=40.2 ms
64 bytes from 8.8.8.8: icmp_seq=9 ttl=250 time=41.0 ms
64 bytes from 8.8.8.8: icmp_seq=10 ttl=250 time=39.5 ms
--- 8.8.8.8 ping statistics ---
10 packets transmitted, 10 received, 0% packet loss, time 9010ms
rtt min/avg/max/mdev = 38.644/41.557/52.433/4.318 ms
Show assigned IP addresses
To view the IP address assigned to your device’s network interfaces, use the following command:
sh-phyboard-rigel-am67xx-1:~# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host noprefixroute
       valid_lft forever preferred_lft forever
2: end0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
    link/ether dc:be:04:6d:b8:ff brd ff:ff:ff:ff:ff:ff
    altname eth0
    inet 192.168.3.11/24 brd 192.168.3.255 scope global end0
       valid_lft forever preferred_lft forever
    inet 172.22.30.132/24 metric 1024 brd 172.22.30.255 scope global end0
       valid_lft forever preferred_lft forever
    inet6 fe80::debe:4ff:fe6d:b8ff/64 scope link proto kernel_ll
       valid_lft forever preferred_lft forever
3: main_mcan0: <NOARP,UP,LOWER_UP,ECHO> mtu 72 qdisc pfifo_fast state UP group default qlen 10
    link/can
Changing Static IPv4 Address
There are two ways to modify the static IP address configuration:
Runtime Configuration
To change the static IP address on the running system:
- Edit the network configuration file: - sh-phyboard-rigel-am67xx-1:~# vi /lib/systemd/network/10-eth0.network 
- Modify the ‘Address’ line under the [Network] section: - [Network] Address=192.168.3.11/24 
- Restart the network service: - sh-phyboard-rigel-am67xx-1:~# systemctl restart systemd-networkd 
Build-time Configuration
To permanently change the default static IP:
- Edit the network configuration in your BSP layer: - meta-ampliphy/recipes-core/systemd/systemd-conf/10-eth0.network
- Update the Address line as shown above 
- Rebuild the BSP image 
SSH into the Board
Once the phyBOARD-Rigel AM67x IPv4 address is known, we can use it to interact with the development kit over the network. This section of the guide will walk through establishing an SSH connection with the hardware which can be a handy way to quickly get a second terminal session up and running. This might be useful if you are doing development directly on the target and need to process a second task in parallel with something running in the standard hardware UART console.
- In order to most easily follow this section of the guide, you will want both the phyBOARD-Rigel AM67x and your Ubuntu host machine connected to the same local area network (LAN). 
- Using your Ubuntu host machine, start a new terminal session and use the following command to ensure that ssh is installed: - sh-host:~$ sudo apt update sh-host:~$ sudo apt install ssh 
- The phyBOARD-Rigel AM67x Linux BSP has a ssh server installed and enabled by default so it is already pre-configured to accept ssh connections. Establish a connection with the development kit using the Ubuntu host machine: - sh-host:~$ ssh root@10.0.0.222 
You should see a response similar to the following:
The authenticity of host '10.0.0.222 (10.0.0.222)' can't be established. RSA key fingerprint is SHA256:ERfYI41VP/hXh17ulInjqWq5wIn4D2mO69H8PILHmW8. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added '10.0.0.222' (RSA) to the list of known hosts. ____ _ _ __ __ _____ _____ ____ | _ \ | | | |\ \ / /|_ _|| ____| / ___| | |_) || |_| | \ V / | | | _| | | | __/ | _ | | | | | | |___ | |___ |_| |_| |_| |_| |_| |_____| \____| _ __ __ ____ _ ___ ____ _ _ __ __ / \ | \/ || _ \ | | |_ _|| _ \ | | | |\ \ / / / _ \ | |\/| || |_) || | | | | |_) || |_| | \ V / / ___ \ | | | || __/ | |___ | | | __/ | _ | | | /_/ \_\|_| |_||_| |_____||___||_| |_| |_| |_| ampliPHY Vendor (Phytec Vendor Distribution) BSP-Yocto-Ampliphy-AM67x-PD25.1.0 phyboard-rigel-am67xx-1 ttyS2 sh-phyboard-rigel-am67xx-1:~#
Finally to close the ssh connection, you can type exit at the prompt:
sh-phyboard-rigel-am67xx-1:~# exit
Benchmarking Network Performance
The iperf3 utility is pre-installed for measuring network throughput. You can install iperf3 on an Ubuntu machine with:
sh-host:~$ sudo apt update
sh-host:~$ sudo apt install iperf3
By default iperf3 runs a 10-second test; use -t to change the duration.
Server Mode
On the target board, start iperf3 in server mode:
sh-phyboard-rigel-am67xx-1:~# iperf3 -s
Client Mode
On another machine in your network, install iperf3 and run it in client mode, pointing to the target board’s IP address:
sh-host:~$ iperf3 -c 192.168.4.11
This will run a 10-second throughput test. Example output:
[ ID] Interval           Transfer     Bitrate
[  4]   0.00-10.00  sec  1.10 GBytes   942 Mbits/sec
Common options
For more detailed testing, try:
- -t— specify test duration in seconds
- -P— run multiple parallel streams
- -R— test in the reverse direction (server -> client)
- -p <port>— change the port (default is 5201)
Setting a MAC Address
The phyBOARD-Rigel AM67x comes with randomly generated MAC addresses by default. While this ensures unique addresses for development, you may want to set static MAC addresses for production use. To learn how to configure static MAC addresses for your device, see MAC Address