-
Notifications
You must be signed in to change notification settings - Fork 0
Ubuntu OS configuration
This page describes the process to configure Ubuntu 24.04 to interface with the vehicle sensors and run docker containers
In order to configure the network properly, we need to migrate the configuration files/settings that the previous CentOS 7 had to communcate with the sensors.
The sever neeeds two configurations: the network interface and the dhcp server.
CentOS7 ifconfig
output:
enp129s0f0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.27.28.69 netmask 255.255.252.0 broadcast 172.27.31.255
inet6 fe80::ae1f:6bff:fe8a:5218 prefixlen 64 scopeid 0x20<link>
ether ac:1f:6b:8a:52:18 txqueuelen 1000 (Ethernet)
RX packets 3004 bytes 863431 (843.1 KiB)
RX errors 0 dropped 1 overruns 0 frame 0
TX packets 523 bytes 46865 (45.7 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
enp129s0f1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.31.0.1 netmask 255.255.0.0 broadcast 172.31.255.255
inet6 fe80::ae1f:6bff:fe8a:5219 prefixlen 64 scopeid 0x20<link>
ether ac:1f:6b:8a:52:19 txqueuelen 1000 (Ethernet)
RX packets 1129 bytes 102963 (100.5 KiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 2198 bytes 380183 (371.2 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
enp129s0f1:1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 10.2.0.81 netmask 255.255.0.0 broadcast 10.2.255.255
ether ac:1f:6b:8a:52:19 txqueuelen 1000 (Ethernet)
enp129s0f1.101: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 10.1.0.81 netmask 255.255.0.0 broadcast 10.1.255.255
inet6 fe80::ae1f:6bff:fe8a:5219 prefixlen 64 scopeid 0x20<link>
ether ac:1f:6b:8a:52:19 txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 667 bytes 41746 (40.7 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
We need to recplicate this settings in Ubuntu.
Ubuntu uses Netplan to configure networks based on YAML files
Based on CentOS ifcfg-enp129s0f1
and route-enp129s0f1
configuration files:
# ifcfg-enp129s0f1
DEVICE="enp129s0f1"
TYPE="Ethernet"
ONBOOT="yes"
BOOTPROTO="static"
IPADDR="172.31.0.1"
NETMASK="255.255.0.0"
NM_CONTROLLED="no"
IPV6INIT="no"
ZONE="sensor-lan"
DEFROUTE="no"
ETHTOOL_OPTS="-L ${DEVICE} combined 16; -A ${DEVICE} autoneg off tx off rx off"
# route-enp129s0f1
0.2.0.0/16 dev enp129s0f1
Ubuntu 24.04 by default sets both enp129s0f1
and enp129s0f0
both to be DHCP4 clients by default due to Cloud configuration (???) and automatically defines /etc/netplan/50-cloud-init.yaml
:
# This file is generated from information provided by the datasource. Changes
# to it will not persist across an instance reboot. To disable cloud-init's
# network configuration capabilities, write a file
# /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg with the following:
# network: {config: disabled}
network:
ethernets:
enp129s0f0:
dhcp4: true
enp129s0f1:
dhcp4: true
version: 2
As per file description, we created a /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg
file with the network: {config: disabled}
But also the contents inside 50-cloud-init.yaml
file was commented as clashes with the target configuration which is deactivating dhcp4 client on enp129s0f1
A 40_lxo_network_config.yaml
file was created with chmod 600
to avoid warnings:
network:
version: 2
ethernets:
enp129s0f0:
dhcp4: true
enp129s0f1:
addresses:
- 172.31.0.1/16 # /16 corresponds to a subnet mask of 255.255.0.0
dhcp4: false
dhcp6: false
routes:
- to: default
via: 172.31.0.1
Changes are applied with sudo netplan apply
.
This ubuntu netlplan tutorial suggests using renderer: networkd
however, this casues issues on the configuration and it was omitted. This will cause the NetworkManager
to use it
The vehicle interact with IMU, cameras, datspped dbw and pico temp sensors via usb.
Five left a bunch of udev rules files in /etc/udev/rules.d
40-pgr.rules
70-snap.snapd.rules
90-camera-trigger.rules
90-dataspeed.rules
90-imu.rules
90-pico.rules
90-transportssd.rules
It easy to identiy that custom rules as the system do not use 90-
perfix`
The following configuration is based on the files listed above
90-imu.rules
SUBSYSTEM=="tty", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="5740", ATTRS{product}=="Lord Inertial Sensor", ATTRS{serial}=="0000__6254.75215", SYMLINK+="imu-front", MODE="0666"
The udev rules also contained another 20 IMUS configuration, based on this I was able to know which usb credentials belong to the boot imu
Bus 003 Device 018: ID 0483:5740 STMicroelectronics Virtual COM Por
# with udevadm info --query=all --name=/dev/ttyACM0
S: serial/by-path/pci-0000:00:14.0-usb-0:2:1.0
E: DEVPATH=/devices/pci0000:00/0000:00:14.0/usb3/3-2/3-2:1.0/tty/ttyACM0
E: DEVNAME=/dev/ttyACM0
E: MAJOR=166
E: MINOR=0
E: SUBSYSTEM=tty
E: USEC_INITIALIZED=5139236294
E: ID_BUS=usb
E: ID_MODEL=Lord_Inertial_Sensor
E: ID_MODEL_ENC=Lord\x20Inertial\x20Sensor
E: ID_MODEL_ID=5740
E: ID_SERIAL=Lord_Microstrain_Lord_Inertial_Sensor_0000__6254.75204
E: ID_SERIAL_SHORT=0000__6254.75204
E: ID_VENDOR=Lord_Microstrain
E: ID_VENDOR_ENC=Lord\x20Microstrain
E: ID_VENDOR_ID=0483
E: ID_REVISION=0200
we add to 90-imu.rules
:
SUBSYSTEM=="tty", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="5740", ATTRS{product}=="Lord Inertial Sensor", ATTRS{serial}=="0000__6254.75204", SYMLINK+="imu-boot", MODE="0666"
Then appy udev changes
sudo udevadm control --reload-rules && sudo udevadm trigger
I configure the av_imu
to run with /dev/imu-front
and/dev/imu-boot
# imu-front
[microstrain_inertial_driver_node-1] [INFO] [1729534928.142733041] [sensor.imu.microstrain_inertial_driver_node]: Running microstrain_inertial_driver version: unknown
[microstrain_inertial_driver_node-1] [INFO] [1729534928.142803093] [sensor.imu.microstrain_inertial_driver_node]: Using MIP SDK version: v0.0.0
[microstrain_inertial_driver_node-1] [WARN] [1729534928.142817976] [sensor.imu.microstrain_inertial_driver_node]: No relative position configured. We will not publish relative odometry or transforms.
[microstrain_inertial_driver_node-1] [WARN] [1729534928.142826459] [sensor.imu.microstrain_inertial_driver_node]: Please configure relative position to publish relative position data
[microstrain_inertial_driver_node-1] [INFO] [1729534928.142934057] [sensor.imu.microstrain_inertial_driver_node]: Attempting to open serial port </dev/imu-front> at <230400>
[microstrain_inertial_driver_node-1] [INFO] [1729534928.143166763] [sensor.imu.microstrain_inertial_driver_node]: Setting device to idle in order to configure
[microstrain_inertial_driver_node-1] [INFO] [1729534928.162207310] [sensor.imu.microstrain_inertial_driver_node]: Main Connection Info:
[microstrain_inertial_driver_node-1] #######################
[microstrain_inertial_driver_node-1] Model Name: 3DM-GX5-15
[microstrain_inertial_driver_node-1] Serial Number: 6254.75215
[microstrain_inertial_driver_node-1] Firmware Version: 1.1.58
[microstrain_inertial_driver_node-1] #######################
# imu-boot
[INFO] [launch]: All log files can be found below /root/.ros/log/2024-10-21-19-16-50-026715-lxo-230
[INFO] [launch]: Default logging verbosity is set to INFO
[INFO] [microstrain_inertial_driver_node-1]: process started with pid [231]
[microstrain_inertial_driver_node-1] [INFO] [1729534610.136822963] [sensor.imu.microstrain_inertial_driver_node]: Running microstrain_inertial_driver version: unknown
[microstrain_inertial_driver_node-1] [INFO] [1729534610.136892352] [sensor.imu.microstrain_inertial_driver_node]: Using MIP SDK version: v0.0.0
[microstrain_inertial_driver_node-1] [WARN] [1729534610.136904824] [sensor.imu.microstrain_inertial_driver_node]: No relative position configured. We will not publish relative odometry or transforms.
[microstrain_inertial_driver_node-1] [WARN] [1729534610.136912900] [sensor.imu.microstrain_inertial_driver_node]: Please configure relative position to publish relative position data
[microstrain_inertial_driver_node-1] [INFO] [1729534610.137027153] [sensor.imu.microstrain_inertial_driver_node]: Attempting to open serial port </dev/imu-boot> at <230400>
[microstrain_inertial_driver_node-1] [INFO] [1729534610.137278335] [sensor.imu.microstrain_inertial_driver_node]: Setting device to idle in order to configure
[microstrain_inertial_driver_node-1] [INFO] [1729534610.151596899] [sensor.imu.microstrain_inertial_driver_node]: Main Connection Info:
[microstrain_inertial_driver_node-1] #######################
[microstrain_inertial_driver_node-1] Model Name: 3DM-GX5-15
[microstrain_inertial_driver_node-1] Serial Number: 6254.75204
[microstrain_inertial_driver_node-1] Firmware Version: 1.1.58
[microstrain_inertial_driver_node-1] #######################
CentOs pps functionality test
# $ sudo ppstest /dev/pps1
trying PPS source "/dev/pps1"
found PPS source "/dev/pps1"
ok, found 1 source(s), now start fetching data...
source 0 - assert 1729601119.610080661, sequence: 2060 - clear 1729601118.710078807, sequence: 2059
source 0 - assert 1729601119.610080661, sequence: 2060 - clear 1729601119.710081672, sequence: 2060
source 0 - assert 1729601120.610078540, sequence: 2061 - clear 1729601119.710081672, sequence: 2060
source 0 - assert 1729601120.610078540, sequence: 2061 - clear 1729601120.710075499, sequence: 2061
source 0 - assert 1729601121.610079487, sequence: 2062 - clear 1729601120.710075499, sequence: 2061
source 0 - assert 1729601121.610079487, sequence: 2062 - clear 1729601121.710076211, sequence: 206
# $ udevadm info --query=all --name=/dev/pps1
P: /devices/virtual/pps/pps1
N: pps1
E: DEVNAME=/dev/pps1
E: DEVPATH=/devices/virtual/pps/pps1
E: MAJOR=243
E: MINOR=1
E: SUBSYSTEM=pps
# $ dmesg | grep pps
[ 1.640520] pps_core: LinuxPPS API ver. 1 registered
[ 1.640521] pps_core: Software ver. 5.3.6 - Copyright 2005-2007 Rodolfo Giometti <[email protected]>
[ 93.708604] pps pps0: new PPS source ptp0
[ 94.949775] pps_ldisc: PPS line discipline registered
[ 94.950266] pps pps1: new PPS source serial0
[ 94.950283] pps pps1: source "/dev/ttyS0" added
[ 97.877274] pps pps2: new PPS source ptp1
[ 98.411751] pps pps2: new PPS source ptp1