Installing LinuxCNC 2.9 on Raspberry Pi 4B with Preempt-RT kernel
- alangibson
- Offline
- Senior Member
Less
More
- Posts: 59
- Thank you received: 23
13 Dec 2022 19:10 - 08 Jan 2023 09:49 #259347
by alangibson
I've seen a lot of people, including myself, have trouble getting LinuxCNC running on the Raspberry Pi 4. I've just gotten it all working, so I thought I'd share my recipe.
We will be overclocking and disabling power management in order to decrease latency. Make sure your Raspberry Pi has a *very large* heat sink, the kind that basically covers the entire board, before attempting this. A fan wouldn't hurt anything either.
Make sure you are using the fastest SD card you can find. Slow reads and writes will cause latency spikes.
1. On Linux desktop computer
Everything in this section should be run on your Linux desktop computer. These commands were tested on Linux Mint 21, but any reasonably recent Debian distro should work.
1.1 Install Raspberry Pi Imager
If that doesn't work, you can manually download and install from www.raspberrypi.com/software/
1.2 Build Rasberry Pi OS image with Realtime-RT kernel
The script will spit out the name of the OS image file at the end of its run.
adding: 2022-09-22-raspios-bullseye-arm64-full.img (deflated 65%)
1.3 Burn image to SD card with Rasbperry Pi Imager
Insert the SD card into your computer.
Open Raspberry Pi Imager.
Click "Choose OS" button. Select "Use Custom" from the bottom of the menu. Select the '.img' file you just built in the `rpi-rt-kernel` directory.
Click "Choose Storage" button. Select your SD card.
Click the settings sprocket image button. Set your WLAN credentials, enable ssh, hostname, username/password, and timezone in the settings. I use
hostname = linuxcnc
enable ssh = checked
use password authentication = selected
set username and password = checked
username = pi
password = (password of your choice)
configure wireless lan = checked
SSID = (your wifi access point name)
password = (your wifi password)
wireless lan country = (your country code)
set locale settings = checked
timezone = (your timezone)
Click the "Write" button
1.4 Boot Raspberry Pi
Insert the micro SD card in your RPi 4 and power it up. If you correctly set your WLAN credentials, it should be available on your Wifi network in about a minute. You can watch for it to appear by running `ping`.
1.5 Connect to Raspberry Pi
Once the Rasberry Pi is online, `ssh` in to it
Enter your password when prompted.
2. On Rasbperrry Pi
The following instructions are based on gnipsel.com/linuxcnc/debian-11-emc.html
2.1 Fix locale setting
First check if you need to set the locale
If you don't get anything back, then run
2.2 Build LinuxCNC
2.3 Install LinuxCNC
2.4 Configure notification service
2.5 Install Qt Designer
2.6 Install Mesaflash
2.7 Install Mesa Configuration Tool
2.8 Improve latency
2.9 Fix virtual keyboard
2.10 (Optional) Fix USB ports on Raspberry Pi 4 Compute Module
2.11 (Optional) Improve latency by stopping unnecessary networking
This will disable Wifi, automatic IP address assignment, remote shell access, and local DNS naming. Make sure you have a monitor and keyboard connected before doing this.
And that's about it.
With 7 glxgears and a ping flood to my 7i96S running, base thread jitter is 25us. That's good enough for slow-ish software stepping according to the Wiki.
We will be overclocking and disabling power management in order to decrease latency. Make sure your Raspberry Pi has a *very large* heat sink, the kind that basically covers the entire board, before attempting this. A fan wouldn't hurt anything either.
Make sure you are using the fastest SD card you can find. Slow reads and writes will cause latency spikes.
1. On Linux desktop computer
Everything in this section should be run on your Linux desktop computer. These commands were tested on Linux Mint 21, but any reasonably recent Debian distro should work.
1.1 Install Raspberry Pi Imager
sudo apt install rpi-imager
If that doesn't work, you can manually download and install from www.raspberrypi.com/software/
1.2 Build Rasberry Pi OS image with Realtime-RT kernel
sudo apt install git
git clone --depth 1 https://github.com/remusmp/rpi-rt-kernel
cd rpi-rt-kernel
make RASPIOS_IMAGE_NAME=raspios_full_arm64
The script will spit out the name of the OS image file at the end of its run.
adding: 2022-09-22-raspios-bullseye-arm64-full.img (deflated 65%)
1.3 Burn image to SD card with Rasbperry Pi Imager
Insert the SD card into your computer.
Open Raspberry Pi Imager.
Click "Choose OS" button. Select "Use Custom" from the bottom of the menu. Select the '.img' file you just built in the `rpi-rt-kernel` directory.
Click "Choose Storage" button. Select your SD card.
Click the settings sprocket image button. Set your WLAN credentials, enable ssh, hostname, username/password, and timezone in the settings. I use
hostname = linuxcnc
enable ssh = checked
use password authentication = selected
set username and password = checked
username = pi
password = (password of your choice)
configure wireless lan = checked
SSID = (your wifi access point name)
password = (your wifi password)
wireless lan country = (your country code)
set locale settings = checked
timezone = (your timezone)
Click the "Write" button
1.4 Boot Raspberry Pi
Insert the micro SD card in your RPi 4 and power it up. If you correctly set your WLAN credentials, it should be available on your Wifi network in about a minute. You can watch for it to appear by running `ping`.
ping linuxcnc.local
1.5 Connect to Raspberry Pi
Once the Rasberry Pi is online, `ssh` in to it
ssh username@linuxcnc.local
Enter your password when prompted.
2. On Rasbperrry Pi
The following instructions are based on gnipsel.com/linuxcnc/debian-11-emc.html
2.1 Fix locale setting
First check if you need to set the locale
echo $LC_ALL
If you don't get anything back, then run
echo "export LANGUAGE=$LANG" >> ~/.bashrc
echo "export LC_ALL=$LANG" >> ~/.bashrc
source ~/.bashrc
2.2 Build LinuxCNC
sudo apt install build-essential devscripts autoconf automake \
debhelper dh-python libudev-dev bwidget \
intltool libboost-python-dev libepoxy-dev libgl1-mesa-dev \
libglu1-mesa-dev libgtk2.0-dev libgtk-3-dev libmodbus-dev \
libeditreadline-dev libxmu-dev netcat po4a python3-dev \
python3-tk python3-xlib tcl8.6-dev tclx tk8.6-dev yapps2 \
asciidoc docbook-xsl dvipng groff imagemagick \
python3-lxml source-highlight w3c-linkchecker xsltproc \
texlive-extra-utils texlive-font-utils texlive-fonts-recommended \
texlive-lang-cyrillic texlive-lang-french texlive-lang-german \
texlive-lang-polish texlive-lang-spanish texlive-xetex \
texlive-latex-recommended dblatex asciidoc-dblatex \
libusb-1.0-0-dev graphviz inkscape texlive-lang-european
git clone -b 2.9 --depth 1 https://github.com/LinuxCNC/linuxcnc.git build
cd build
./debian/configure no-docs
dpkg-checkbuilddeps
debuild -uc -us
2.3 Install LinuxCNC
sudo apt install libxml2 gir1.2-gtksource-3.0 libxml2-dev libglew2.1 mesa-utils python3-configobj libgtksourceview-3.0-dev tclreadline
cd ..
sudo dpkg -i linuxcnc-uspace_2.9.0~pre1_arm64.deb
2.4 Configure notification service
sudo apt install -y notification-daemon
cat | sudo tee /usr/share/dbus-1/services/org.freedesktop.Notifications.service <<EOF
[D-BUS Service]
Name=org.freedesktop.Notifications
Exec=/usr/lib/notification-daemon/notification-daemon
EOF
2.5 Install Qt Designer
sudo sed -i 's/x86_64-linux-gnu/aarch64-linux-gnu/' /usr/lib/python3/dist-packages/qtvcp/designer/install_script
/usr/lib/python3/dist-packages/qtvcp/designer/install_script
2.6 Install Mesaflash
git clone https://github.com/LinuxCNC/mesaflash.git
sudo apt install libpci-dev libmd-dev pkg-config
cd mesaflash
sudo make install
2.7 Install Mesa Configuration Tool
cd ~
sudo apt install python3-packaging
curl -L -O https://github.com/jethornton/mesact/raw/master/mesact_1.1.2_arm64.deb
sudo dpkg -i mesact_1.1.2_arm64.deb
2.8 Improve latency
# Stop and disable services we don't need
sudo systemctl stop alsa-restore apache2 bluetooth hciuart cron cups-browsed cups triggerhappy upower packagekit
sudo systemctl disable alsa-restore apache2 bluetooth hciuart cron cups-browsed cups triggerhappy upower packagekit
# Overclock CPU
echo 'over_voltage=6' | sudo tee -a /boot/config.txt
echo 'arm_freq=2000' | sudo tee -a /boot/config.txt
echo -n ' isolcpus=1,2,3 idle=poll processor.max_cstate=1' | sudo tee -a /boot/cmdline.txt
echo -n 'performance' | sudo tee /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor
# Overclock SD card
echo 'dtparam=sd_overclock=100' | sudo tee -a /boot/config.txt
# Disable audio
sudo sed -i 's/dtparam=audio=on/# dtparam=audio=on/' /boot/config.txt
2.9 Fix virtual keyboard
sudo apt-get install onboard
pip install pygst
sudo sed -i 's/stderr=subprocess.PIPE,/stderr=subprocess.PIPE, text=True,/' /usr/lib/python3/dist-packages/gladevcp/hal_filechooser.py
2.10 (Optional) Fix USB ports on Raspberry Pi 4 Compute Module
echo -n ' dtoverlay=dwc2,dr_mode=host' | sudo tee -a /boot/cmdline.txt
2.11 (Optional) Improve latency by stopping unnecessary networking
This will disable Wifi, automatic IP address assignment, remote shell access, and local DNS naming. Make sure you have a monitor and keyboard connected before doing this.
sudo systemctl stop avahi-daemon ssh wpa_supplicant dhcpcd ModemManager
sudo systemctl disable avahi-daemon ssh wpa_supplicant dhcpcd ModemManager
And that's about it.
With 7 glxgears and a ping flood to my 7i96S running, base thread jitter is 25us. That's good enough for slow-ish software stepping according to the Wiki.
Last edit: 08 Jan 2023 09:49 by alangibson.
Please Log in or Create an account to join the conversation.
- tommylight
- Away
- Moderator
Less
More
- Posts: 18665
- Thank you received: 6268
13 Dec 2022 19:28 #259348
by tommylight
Replied by tommylight on topic Installing LinuxCNC 2.9 on Raspberry Pi 4 with Preempt-RT kernel
You should also mention the version of the RPI4, by now there are several versions with different hardware so all this might not work on all of them, as can be noted from complaints about the official image not working on some new RPI4.
Thank you.
Thank you.
Please Log in or Create an account to join the conversation.
13 Dec 2022 20:07 #259351
by rodw
Replied by rodw on topic Installing LinuxCNC 2.9 on Raspberry Pi 4 with Preempt-RT kernel
I don't think the version matters as from the git files Pi 1 to Pi 4/4b are supported.You should also mention the version of the RPI4, by now there are several versions with different hardware so all this might not work on all of them, as can be noted from complaints about the official image not working on some new RPI4.
Thank you.
Please Log in or Create an account to join the conversation.
- tommylight
- Away
- Moderator
Less
More
- Posts: 18665
- Thank you received: 6268
13 Dec 2022 20:28 #259359
by tommylight
Replied by tommylight on topic Installing LinuxCNC 2.9 on Raspberry Pi 4 with Preempt-RT kernel
It does, new versions had issues with the official Raspbian, it did not work several months back.
I do not nor do i intend to use RPI4 in the foreseeable future, but i read everything on this forum and there are several topic with that subject.
I do not nor do i intend to use RPI4 in the foreseeable future, but i read everything on this forum and there are several topic with that subject.
Please Log in or Create an account to join the conversation.
25 Dec 2022 17:08 #260283
by RMS
Replied by RMS on topic Installing LinuxCNC 2.9 on Raspberry Pi 4 with Preempt-RT kernel
Alangibson,
I have tested your recipe on raspberry Pi, compute module CM4108016, 8G RAM + 16G eMMc installed on mother board “Compute Module 4 IO Board” and mesa 7i96S
This is the cleanest OS 64 installation for linuxcnc 2.9 preRT with kernel
uname -a
Linux linuxcnc29 5.15.84-rt54-v8+ #1 SMP PREEMPT_RT Fri Dec 23 20:39:48 CET 2022 aarch64 GNU/Linux
Note: compute module carrier board IO must have
in the file /boot/config.txt
dtoverlay=dwc2,dr_mode=host
to enable usb PORTS.
The only hiccup I have experienced was with setting on the “locale”.
for users experiencing the issue
VERIFY IF YOU HAVE THOSE LINES
export LC_ALL="en_US.UTF-8"
export LC_CTYPE="en_US.UTF-8"
So far i have no issues with other programs residing in raspberrian.
My project is mobile robotic analytical platform with linuxcnc as the backbone for sample collection.
This is my third setup. The other systems were for big CNC 4x6 ft table with encoders in the loop using 7i96 + 7i85 raspberry pi 4M
and Grizzly CNC with Jetson TX1 and 7i95
Thank you and the other contributors.
RMS
I have tested your recipe on raspberry Pi, compute module CM4108016, 8G RAM + 16G eMMc installed on mother board “Compute Module 4 IO Board” and mesa 7i96S
This is the cleanest OS 64 installation for linuxcnc 2.9 preRT with kernel
uname -a
Linux linuxcnc29 5.15.84-rt54-v8+ #1 SMP PREEMPT_RT Fri Dec 23 20:39:48 CET 2022 aarch64 GNU/Linux
Note: compute module carrier board IO must have
in the file /boot/config.txt
dtoverlay=dwc2,dr_mode=host
to enable usb PORTS.
The only hiccup I have experienced was with setting on the “locale”.
for users experiencing the issue
VERIFY IF YOU HAVE THOSE LINES
export LC_ALL="en_US.UTF-8"
export LC_CTYPE="en_US.UTF-8"
So far i have no issues with other programs residing in raspberrian.
My project is mobile robotic analytical platform with linuxcnc as the backbone for sample collection.
This is my third setup. The other systems were for big CNC 4x6 ft table with encoders in the loop using 7i96 + 7i85 raspberry pi 4M
and Grizzly CNC with Jetson TX1 and 7i95
Thank you and the other contributors.
RMS
The following user(s) said Thank You: tommylight
Please Log in or Create an account to join the conversation.
- voltaicsca
- Offline
- New Member
Less
More
- Posts: 3
- Thank you received: 3
26 Dec 2022 10:17 - 26 Dec 2022 10:40 #260304
by voltaicsca
Replied by voltaicsca on topic Installing LinuxCNC 2.9 on Raspberry Pi 4 with Preempt-RT kernel
Similar problem, but different enough to chime in. My tack was admittedly a bit hacky, but it worked.
My goal was to create a "fresh" rpi image (ie, modify the .img file, BEFORE flashing, rather than after, since after first boot, things change) with the rt preempt kernel, but based on the rpi images supplied by linuxcnc, rather than the vanilla raspbian. This was difficult, because the released images from linuxcnc don't seem to support the RPi 4*B*, which is what I'm running, and the raspbian image with a new kernel didn't seem to want to install linuxcnc. Both sets of software had something I wanted, but neither had everything, hence the deep-dive.
I found a way that worked for me, and have some (poorly documented) code here: github.com/InternetofAwesome/pm-940-cnc/...misc/distro-build.sh
Basically, the script is going to want a "fresh" image of the 2.8.1 build from linuxcnc for rpi, and the files from /boot from a more recent raspbian build.
Those are in the top of the script in a clearly marked config section, and named IMAGE_PATH and BOOTLOADER_PATH, respectively.
Once the script runs, you should have a ready-to-flash base OS image. From there, the apt repos are setup to grab from the mainline linuxcnc sources, and worked fine for me.
I didn't need/want to build LCNC from source, so the mainline releases were fine for me.
My goal was to create a "fresh" rpi image (ie, modify the .img file, BEFORE flashing, rather than after, since after first boot, things change) with the rt preempt kernel, but based on the rpi images supplied by linuxcnc, rather than the vanilla raspbian. This was difficult, because the released images from linuxcnc don't seem to support the RPi 4*B*, which is what I'm running, and the raspbian image with a new kernel didn't seem to want to install linuxcnc. Both sets of software had something I wanted, but neither had everything, hence the deep-dive.
I found a way that worked for me, and have some (poorly documented) code here: github.com/InternetofAwesome/pm-940-cnc/...misc/distro-build.sh
Basically, the script is going to want a "fresh" image of the 2.8.1 build from linuxcnc for rpi, and the files from /boot from a more recent raspbian build.
Those are in the top of the script in a clearly marked config section, and named IMAGE_PATH and BOOTLOADER_PATH, respectively.
Once the script runs, you should have a ready-to-flash base OS image. From there, the apt repos are setup to grab from the mainline linuxcnc sources, and worked fine for me.
I didn't need/want to build LCNC from source, so the mainline releases were fine for me.
Last edit: 26 Dec 2022 10:40 by voltaicsca. Reason: Misread the original post, and edited the reply.
Please Log in or Create an account to join the conversation.
05 Jan 2023 18:04 - 05 Jan 2023 18:21 #261012
by RMS
Replied by RMS on topic Installing LinuxCNC 2.9 on Raspberry Pi 4 with Preempt-RT kernel
Dear All,
With ongoing extensive testing, of this kernel
Linux linuxcnc29 5.15.84-rt54-v8+ #1 SMP PREEMPT_RT Fri Dec 23 20:39:48 CET 2022 aarch64 GNU/Linux
Unfortunately, I have found few problems.
1. the virtual keyboard was not found by gmoccapy.
The solution was the installation of onboard and pygst
$sudo apt-get install onboard
$pip install pygst
Note:
The matchbox-keyboard in this kernel is defective
2. In gmoccapy when loading png the error box pops up:
Found an error!
The following information may be usefull in troubleshooting
File "/usr/lib/python3/dist-packages/gladevcp/hal_filechooser.py", line 56, in update
m=progress_re.match(stderr_line)
TypeError: cannot use a string pattern on bytes-like object
Solution:
TBD , we need to ask developer of gmoccapy.
However, the “axis” imports and processes the png’s and py’s OK
Thanks,
RMS
With ongoing extensive testing, of this kernel
Linux linuxcnc29 5.15.84-rt54-v8+ #1 SMP PREEMPT_RT Fri Dec 23 20:39:48 CET 2022 aarch64 GNU/Linux
Unfortunately, I have found few problems.
1. the virtual keyboard was not found by gmoccapy.
The solution was the installation of onboard and pygst
$sudo apt-get install onboard
$pip install pygst
Note:
The matchbox-keyboard in this kernel is defective
2. In gmoccapy when loading png the error box pops up:
Found an error!
The following information may be usefull in troubleshooting
File "/usr/lib/python3/dist-packages/gladevcp/hal_filechooser.py", line 56, in update
m=progress_re.match(stderr_line)
TypeError: cannot use a string pattern on bytes-like object
Solution:
TBD , we need to ask developer of gmoccapy.
However, the “axis” imports and processes the png’s and py’s OK
Thanks,
RMS
Last edit: 05 Jan 2023 18:21 by RMS.
Please Log in or Create an account to join the conversation.
- alangibson
- Offline
- Senior Member
Less
More
- Posts: 59
- Thank you received: 23
06 Jan 2023 09:26 - 06 Jan 2023 09:27 #261070
by alangibson
Replied by alangibson on topic Installing LinuxCNC 2.9 on Raspberry Pi 4 with Preempt-RT kernel
Thanks for the report
1. I'll add that to the instructions
2. There may be a quick fix for that. Try this:
- Open file /usr/lib/python3/dist-packages/gladevcp/hal_filechooser.py
- Change this line
stderr=subprocess.PIPE,
to
stderr=subprocess.PIPE, text=True,
1. I'll add that to the instructions
2. There may be a quick fix for that. Try this:
- Open file /usr/lib/python3/dist-packages/gladevcp/hal_filechooser.py
- Change this line
stderr=subprocess.PIPE,
to
stderr=subprocess.PIPE, text=True,
Last edit: 06 Jan 2023 09:27 by alangibson.
The following user(s) said Thank You: RMS
Please Log in or Create an account to join the conversation.
07 Jan 2023 15:31 - 07 Jan 2023 15:37 #261171
by RMS
Replied by RMS on topic Installing LinuxCNC 2.9 on Raspberry Pi 4 with Preempt-RT kernel
Alan
it works thanks
RMS
P.S.1. With the overclocking I suggest being cautious. I was experiencing stability problem on CM4 and had to revert and clean cmdline.txt and config.txt from overclocking entries.
2. While loading button macros with custom ‘png” graphics i am getting error. File “/usr/bin/gmoccapy”, line 5728, in <module> app = gmoccapy(sys.arg)
...
File “/usr/bin/gmocappy”, line 1397, in_check_macro_for_image Image=line.split(“.”)[1] IndexError: list index out of range
Any clues?
it works thanks
RMS
P.S.1. With the overclocking I suggest being cautious. I was experiencing stability problem on CM4 and had to revert and clean cmdline.txt and config.txt from overclocking entries.
2. While loading button macros with custom ‘png” graphics i am getting error. File “/usr/bin/gmoccapy”, line 5728, in <module> app = gmoccapy(sys.arg)
...
File “/usr/bin/gmocappy”, line 1397, in_check_macro_for_image Image=line.split(“.”)[1] IndexError: list index out of range
Any clues?
Last edit: 07 Jan 2023 15:37 by RMS. Reason: add on info
Please Log in or Create an account to join the conversation.
- alangibson
- Offline
- Senior Member
Less
More
- Posts: 59
- Thank you received: 23
08 Jan 2023 09:51 #261249
by alangibson
Replied by alangibson on topic Installing LinuxCNC 2.9 on Raspberry Pi 4 with Preempt-RT kernel
Good to hear.
1. I've added a note about needing an very large heat sink. I've been thrashing my RPi for a week straight now without problems.
2. I'll take a look and get back to you
1. I've added a note about needing an very large heat sink. I've been thrashing my RPi for a week straight now without problems.
2. I'll take a look and get back to you
The following user(s) said Thank You: RMS
Please Log in or Create an account to join the conversation.
Time to create page: 0.124 seconds