Skip to content

Ubuntu OS configuration

Hector Cruz edited this page Oct 22, 2024 · 18 revisions

This page describes the process to configure Ubuntu 24.04 to interface with the vehicle sensors and run docker containers

Network configuration

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

Configuring enp129s0f1

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

USB devices

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

IMU

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]     #######################

PPS & NMEA

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
Clone this wiki locally