Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
- gene_weber
-
Topic Author
- Offline
- Senior Member
-
Less
More
- Posts: 47
- Thank you received: 18
16 Jan 2025 12:38 #319119
by gene_weber
Replied by gene_weber on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
The good news is switching to X11 is trivial.
You can check the session type: wayland
Launch Rasp-config command line tool in a terminal:
Arrow down to "Advanced Options", and enter.
Arrow down to "Wayland Switch between X and Wayland backends", and enter.
If not on the line that says "W1 X11 Openbox window manager with X11 backend", arrow to it and enter.
The popup should say "Openbox on X11 is active" and have "Ok" highlighted. Enter.
It will return to the main screen. Use left-righ arrows to select "Finish". Enter.
Popup asks if you would like to reboot now, with "Yes" highlighted. Enter.
After reboot: x11
Now here's the interesting apples to apples comparison. The only difference between these two pre-jitter-optimization baseline latency runs is Wayland vs X11.
Wayland:
X11:
You can check the session type:
echo $XDG_SESSION_TYPE
Launch Rasp-config command line tool in a terminal:
sudo raspi-config
Arrow down to "Advanced Options", and enter.
Arrow down to "Wayland Switch between X and Wayland backends", and enter.
If not on the line that says "W1 X11 Openbox window manager with X11 backend", arrow to it and enter.
The popup should say "Openbox on X11 is active" and have "Ok" highlighted. Enter.
It will return to the main screen. Use left-righ arrows to select "Finish". Enter.
Popup asks if you would like to reboot now, with "Yes" highlighted. Enter.
After reboot:
echo $XDG_SESSION_TYPE
Now here's the interesting apples to apples comparison. The only difference between these two pre-jitter-optimization baseline latency runs is Wayland vs X11.
Wayland:
X11:
Attachments:
Please Log in or Create an account to join the conversation.
- Cant do this anymore bye all
-
- Offline
- Platinum Member
-
Less
More
- Posts: 1200
- Thank you received: 425
16 Jan 2025 13:10 #319121
by Cant do this anymore bye all
Replied by Cant do this anymore bye all on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
Looks a lot better.
One thing that was strange when running a basic config I got a real time error. hmmmmm
ATM the best image I've come across is Joco's rpi5 image rod has on his googledrive, that has a 6.6.54 kernel. It's my choice of the pre-built images.
I installed mate desktop, with 2 cores isolated, watching youtube latency is about 17-18us on my pi.
One thing that was strange when running a basic config I got a real time error. hmmmmm
ATM the best image I've come across is Joco's rpi5 image rod has on his googledrive, that has a 6.6.54 kernel. It's my choice of the pre-built images.
I installed mate desktop, with 2 cores isolated, watching youtube latency is about 17-18us on my pi.
Please Log in or Create an account to join the conversation.
- gene_weber
-
Topic Author
- Offline
- Senior Member
-
Less
More
- Posts: 47
- Thank you received: 18
16 Jan 2025 14:42 #319126
by gene_weber
Replied by gene_weber on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
I edited my original post to include changing the display protocol from Wayland to X11. Comments by rodw and cornholio were based on the terrible jitter that Wayland induces as shown above.
Note that Kunena has the worst forum editor I've ever used, and it was quite a job to edit those posts and restore the formatting. I wonder if forum posting would increase with forum software that was more user friendly.
Note that Kunena has the worst forum editor I've ever used, and it was quite a job to edit those posts and restore the formatting. I wonder if forum posting would increase with forum software that was more user friendly.
The following user(s) said Thank You: behai
Please Log in or Create an account to join the conversation.
- Cant do this anymore bye all
-
- Offline
- Platinum Member
-
Less
More
- Posts: 1200
- Thank you received: 425
16 Jan 2025 15:46 #319128
by Cant do this anymore bye all
Replied by Cant do this anymore bye all on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
Ah yes the editor. Truly you have come of age and walked the path of darkness

The following user(s) said Thank You: behai
Please Log in or Create an account to join the conversation.
- gene_weber
-
Topic Author
- Offline
- Senior Member
-
Less
More
- Posts: 47
- Thank you received: 18
17 Jan 2025 17:00 #319192
by gene_weber
Replied by gene_weber on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
Rather than starting a new thread about jitter mitigation, I'm just going to add it here.
First, I'm keeping in mind that Peter Wallace said " The jitter is basically unimportant with a 7C81 unless its so bad you
get real time errors at the normal servo thread rate ."
I'm also treating the Raspberry Pi + 7C81 as a dedicated controller, not a PC. By that I mean I'm not going to be doing anything on the Pi except LinuxCNC. I may turn on WIFI to update packages, or use email to transfer a file. But I plan to even turn off WIFI before I launch LinuxCNC.
I ran several tests to see which combination of settings offered the most optimized jitter. I ran two Glxgears for all tests as I though that was reasonable, and ran the tests for long periods of time unless they looked bad early on.
I thought that turning off all unused services would decrease Jitter. So I turned off 9 of the 23 services, such as CUPS, Bluetooth, etc. To my surprise this did not decrease jitter.
Screen blank increased jitter a bit, so I turned that off. It doesn't make much sense anyway on a CNC controller.
These are the settings I added to the line already in /boot/firmware/cmdline.txt:
I tried a few others that some people recommended on various blogs. Nothing else I tried had any noticeable positive impact on jitter, and some noticeably slowed down the responsiveness of the Pi.
Turning off timer_migration did reduce jitter. What I read said that you could make this setting permanent by adding it to the boot command line, or setting it in either of two different system files. Oddly none of that worked. So I setup a cron job to disable it at boot, and that works.Add the following line:
The other thing that helped reduce jitter was changing the scheduling policy to real-time and increasing the priority. I decided to create a shell script to launch latency-histogram, and eventually linuxcnc, which changes these things on the process.
I named it rrt (run real-time). So to launch latency-histogram it's simply:
All spawned sub-processes inherit the policy and priority. So if linuxcnc is launched with rrt:all of the processes that are part of LinuxCNC have the policy of SCHED_RR and priority of 99. I used Round Robin scheduling to make sure no LinuxCNC process "starves" another.
I don't know if this will work in the end, but I'm going to give it a try. Nothing ventured, nothing gained.
Implementing all of these, here is the jitter histogram. Good enough.
First, I'm keeping in mind that Peter Wallace said " The jitter is basically unimportant with a 7C81 unless its so bad you
get real time errors at the normal servo thread rate ."
I'm also treating the Raspberry Pi + 7C81 as a dedicated controller, not a PC. By that I mean I'm not going to be doing anything on the Pi except LinuxCNC. I may turn on WIFI to update packages, or use email to transfer a file. But I plan to even turn off WIFI before I launch LinuxCNC.
I ran several tests to see which combination of settings offered the most optimized jitter. I ran two Glxgears for all tests as I though that was reasonable, and ran the tests for long periods of time unless they looked bad early on.
I thought that turning off all unused services would decrease Jitter. So I turned off 9 of the 23 services, such as CUPS, Bluetooth, etc. To my surprise this did not decrease jitter.
Screen blank increased jitter a bit, so I turned that off. It doesn't make much sense anyway on a CNC controller.
These are the settings I added to the line already in /boot/firmware/cmdline.txt:
skew_tick=1 kthread_cpus=0-2 irqaffinity=0-2 rcu_nocb_poll rcu_nocbs=3 nohz=on nohz_full=3 isolcpus=3
I tried a few others that some people recommended on various blogs. Nothing else I tried had any noticeable positive impact on jitter, and some noticeably slowed down the responsiveness of the Pi.
Turning off timer_migration did reduce jitter. What I read said that you could make this setting permanent by adding it to the boot command line, or setting it in either of two different system files. Oddly none of that worked. So I setup a cron job to disable it at boot, and that works.
crontab -e
@reboot sudo sysctl kernel.timer_migration=0
The other thing that helped reduce jitter was changing the scheduling policy to real-time and increasing the priority. I decided to create a shell script to launch latency-histogram, and eventually linuxcnc, which changes these things on the process.
#!/bin/bash
#
# Run with the SCHED_RR real-time policy at the highest priority level (99)
# Uses chrt to switch the process policy and priority immediately after launch.
#
# Gene Weber - January 2025
#
# "The difference between SCHED_FIFO and SCHED_RR is that among tasks with the same priority,
# SCHED_RR performs a round-robin with a certain timeslice; SCHED_FIFO, instead, needs the task
# to explicitly yield the processor." -Claudio
priority=99
# Truncate $1 (the command) to 15 characters starting at 0.
command=${1:0:15}
# Execute the command line provided to rrt as a background task.
`$@` &
# Get the process ID of the command.
PID=`pgrep $command`
# Change the real-time policy to SCHED_FIFO with a priority of $priority.
sudo chrt -r -p $priority $PID
I named it rrt (run real-time). So to launch latency-histogram it's simply:
rrt latency-histogram --nobase --sbins 1000
All spawned sub-processes inherit the policy and priority. So if linuxcnc is launched with rrt:
rrt linuxcnc
I don't know if this will work in the end, but I'm going to give it a try. Nothing ventured, nothing gained.
Implementing all of these, here is the jitter histogram. Good enough.
Attachments:
The following user(s) said Thank You: rodw, behai
Please Log in or Create an account to join the conversation.
- VincentValentine
- Offline
- New Member
-
Less
More
- Posts: 1
- Thank you received: 0
26 Jan 2025 00:43 - 26 Jan 2025 00:46 #319860
by VincentValentine
Replied by VincentValentine on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
Getting a Hunk #1-9 succeeded, and a few lines later (right after trace.c) a HUNK #1 failed during the patch.
install and kernel activation does seem to complete if it’s ignored.
install and kernel activation does seem to complete if it’s ignored.
Last edit: 26 Jan 2025 00:46 by VincentValentine.
Please Log in or Create an account to join the conversation.
- Cant do this anymore bye all
-
- Offline
- Platinum Member
-
Less
More
- Posts: 1200
- Thank you received: 425
26 Jan 2025 01:28 #319862
by Cant do this anymore bye all
Replied by Cant do this anymore bye all on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
One thing that might be worth of note, as development moves along, is to check the Makelfile in the top of the directory as minor revisions can change for the the rpi-linux kernel.
Or you can run
Or you can run
make kernelversion
Please Log in or Create an account to join the conversation.
- Cant do this anymore bye all
-
- Offline
- Platinum Member
-
Less
More
- Posts: 1200
- Thank you received: 425
26 Jan 2025 01:42 #319863
by Cant do this anymore bye all
Replied by Cant do this anymore bye all on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
I think it's just easier to isolate 2 cores, it really doesn't affect performance. And reading the docs, mainly pertaining to amd64, the general rule is to isolate cores on the same physical die, for reason beyond my pay grade.Rather than starting a new thread about jitter mitigation, I'm just going to add it here.
First, I'm keeping in mind that Peter Wallace said " The jitter is basically unimportant with a 7C81 unless its so bad you
get real time errors at the normal servo thread rate."
I'm also treating the Raspberry Pi + 7C81 as a dedicated controller, not a PC. By that I mean I'm not going to be doing anything on the Pi except LinuxCNC. I may turn on WIFI to update packages, or use email to transfer a file. But I plan to even turn off WIFI before I launch LinuxCNC.
I ran several tests to see which combination of settings offered the most optimized jitter. I ran two Glxgears for all tests as I though that was reasonable, and ran the tests for long periods of time unless they looked bad early on.
I thought that turning off all unused services would decrease Jitter. So I turned off 9 of the 23 services, such as CUPS, Bluetooth, etc. To my surprise this did not decrease jitter.
Screen blank increased jitter a bit, so I turned that off. It doesn't make much sense anyway on a CNC controller.
These are the settings I added to the line already in /boot/firmware/cmdline.txt:
[/code][/code][/code][/code][/code]skew_tick=1 kthread_cpus=0-2 irqaffinity=0-2 rcu_nocb_poll rcu_nocbs=3 nohz=on nohz_full=3 isolcpus=3 I tried a few others that some people recommended on various blogs. Nothing else I tried had any noticeable positive impact on jitter, and some noticeably slowed down the responsiveness of the Pi. Turning off timer_migration did reduce jitter. What I read said that you could make this setting permanent by adding it to the boot command line, or setting it in either of two different system files. Oddly none of that worked. So I setup a cron job to disable it at boot, and that works. [code]crontab -e Add the following line: [code]@reboot sudo sysctl kernel.timer_migration=0 The other thing that helped reduce jitter was changing the scheduling policy to real-time and increasing the priority. I decided to create a shell script to launch latency-histogram, and eventually linuxcnc, which changes these things on the process. [code]#!/bin/bash # # Run with the SCHED_RR real-time policy at the highest priority level (99) # Uses chrt to switch the process policy and priority immediately after launch. # # Gene Weber - January 2025 # # "The difference between SCHED_FIFO and SCHED_RR is that among tasks with the same priority, # SCHED_RR performs a round-robin with a certain timeslice; SCHED_FIFO, instead, needs the task # to explicitly yield the processor." -Claudio priority=99 # Truncate $1 (the command) to 15 characters starting at 0. command=${1:0:15} # Execute the command line provided to rrt as a background task. `$@` & # Get the process ID of the command. PID=`pgrep $command` # Change the real-time policy to SCHED_FIFO with a priority of $priority. sudo chrt -r -p $priority $PID I named it rrt (run real-time). So to launch latency-histogram it's simply: [code]rrt latency-histogram --nobase --sbins 1000 All spawned sub-processes inherit the policy and priority. So if linuxcnc is launched with rrt: [code]rrt linuxcnc all of the processes that are part of LinuxCNC have the policy of SCHED_RR and priority of 99. I used Round Robin scheduling to make sure no LinuxCNC process "starves" another. I don't know if this will work in the end, but I'm going to give it a try. Nothing ventured, nothing gained. Implementing all of these, here is the jitter histogram. Good enough. [attachment=67004]final-16Jan2025-3117.png[/attachment]
Please Log in or Create an account to join the conversation.
- behai
- Offline
- Senior Member
-
Less
More
- Posts: 56
- Thank you received: 17
11 Feb 2025 00:28 #321194
by behai
Replied by behai on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
Hi gene_weber,
Thank you for the info. Back in November, 2024, I did managed to build and install a PREEMPT_RT kernel to my Raspberry Pi 4B:
[
Linux picnc 6.6.59-rt45-v8-behai-rt-build+ #1 SMP PREEMPT_RT Sat Nov 2 10:20:46 AEDT 2024 aarch64 GNU/Linux
]
But I did not know how to make other configurations as you have done: I did not know we have different displays, etc.
I have also built LinuxCNC from source and installed it from the build: only last week, I have found out that I have done a simulated-realtime version of LinuxCNC. PnCConf reports:
[
"You are using a simulated-realtime version of LinuxCNC, so testing / tuning of hardware is unavailable."
]
I did not know we can install LinuxCNC from a prebuilt package to a Raspbian OS as you have done.
Might I have a question, please? You use -j6 in the command:
[
make -j6 Image.gz modules dtbs 2>&1 | tee make.log
]
On my Raspberry Pi 4B, nproc reports 4, I use -j4.
So is it true that later Pi 4B revisions have more cores? I bought mine back in middle 2023. I don't have Pi 5 yet.
Thank you and best regards,
...behai.
Thank you for the info. Back in November, 2024, I did managed to build and install a PREEMPT_RT kernel to my Raspberry Pi 4B:
[
Linux picnc 6.6.59-rt45-v8-behai-rt-build+ #1 SMP PREEMPT_RT Sat Nov 2 10:20:46 AEDT 2024 aarch64 GNU/Linux
]
But I did not know how to make other configurations as you have done: I did not know we have different displays, etc.
I have also built LinuxCNC from source and installed it from the build: only last week, I have found out that I have done a simulated-realtime version of LinuxCNC. PnCConf reports:
[
"You are using a simulated-realtime version of LinuxCNC, so testing / tuning of hardware is unavailable."
]
I did not know we can install LinuxCNC from a prebuilt package to a Raspbian OS as you have done.
Might I have a question, please? You use -j6 in the command:
[
make -j6 Image.gz modules dtbs 2>&1 | tee make.log
]
On my Raspberry Pi 4B, nproc reports 4, I use -j4.
So is it true that later Pi 4B revisions have more cores? I bought mine back in middle 2023. I don't have Pi 5 yet.
Thank you and best regards,
...behai.
Please Log in or Create an account to join the conversation.
- unknown
- Offline
- Platinum Member
-
Less
More
- Posts: 695
- Thank you received: 226
11 Feb 2025 01:33 #321204
by unknown
Replied by unknown on topic Raspberry Pi OS PREEMPT RT 6.13 Kernel Cookbook
No always 4 cores.
For some reason the RPi docs say to use -j6.
For some reason the RPi docs say to use -j6.
The following user(s) said Thank You: behai
Please Log in or Create an account to join the conversation.
Time to create page: 0.158 seconds