frankaemika/libfranka

Realtime Kernel build instructions not working on ubuntu 18.04 and higher

rickstaa opened this issue · 20 comments

Just a quick heads-up about the real-time kernel instructions found in your online documentation. These instructions do not seem to work anymore on ubuntu versions higher than 18.04 and kernel versions higher than 5.0. I was, however, able to build real-time kernel (v5.4.26) on ubuntu 18.04 using the steps below:

See the OLD steps

⚠️ UPDATE: The instructions below are not working anymore on my new system. For installing the real-time kernel on ubuntu 20.04 or higher see my new comment.

Ubuntu 18.04 (kernel 5.4.26) instructions

  1. Install the following necessary dependencies apt-get install build-essential bc curl ca-certificates fakeroot gnupg2 libssl-dev lsb-release libelf-dev bison flex liblz4-tool libncurses-dev libssl-dev (The liblz4-tool dependency is added here since it is not installed by default on ubuntu 18.04)
  2. Download the regular kernel and the patch from the Linux Kernel archive
  3. Verifying file integrity
  4. Unzip the Linux kernel tar -xvf Linux-5.4.26.tar
  5. Go into the kernel folder cd linux-5.4.26
  6. Apply the patch patch -p1 < ../patch-5.4.26-rt17.patch
  7. Run make menuconfig and change the Preemption Model to Fully Preemptible Kernel (RT) (PREEMPT_RT_FULL) (NEW) (see this stack question for more info)
  8. Disable debug info scripts/config --disable DEBUG_INFO (Not needed but recommended).
  9. Run make clean
  10. Make the bzImage make -j $(nproc) bzImage
  11. Make the modules make -j $(nproc) modules
  12. Install the modules make -j $(nproc) modules_install
  13. Install the kernel make -j $(nproc) install

I did not test your instructions for kernel versions lower than 5.0 or ubuntu versions lower than 18.04.

Why did you disable compression? What values did you use for zswap?

@museum-future Thanks for looking into the problem. I disabled the LZ4 compression since when I kept, it enabled I gave me an error during compilation. Below I added a more detailed debug report of the problems I experienced when trying to compile the kernel using the steps provided by the franka documentation.

RT kernel debug report

When trying to compile the rt kernel using the fakeroot make -j4 deb-pkg command that is given in the franka documentation I get the following error:

Makefile:613: include/config/auto.conf: No such file or directory
Makefile:659: include/config/auto.conf.cmd: No such file or directory
  HOSTCC  scripts/basic/fixdep
  HOSTCC  scripts/kconfig/conf.o
  HOSTCC  scripts/kconfig/confdata.o
  HOSTCC  scripts/kconfig/expr.o
  LEX     scripts/kconfig/lexer.lex.c
  YACC    scripts/kconfig/parser.tab.[ch]
  HOSTCC  scripts/kconfig/preprocess.o
  HOSTCC  scripts/kconfig/symbol.o
  HOSTCC  scripts/kconfig/lexer.lex.o
  HOSTCC  scripts/kconfig/parser.tab.o
  HOSTLD  scripts/kconfig/conf
scripts/kconfig/conf  --syncconfig Kconfig
  UPD     include/config/kernel.release
make clean
sh ./scripts/package/mkdebian
  TAR     linux-5.4.26-rt17.tar.gz
origversion=$(dpkg-parsechangelog -SVersion |sed 's/-[^-]*$//');\
        mv linux-5.4.26-rt17.tar.gz ../linux-5.4.26-rt17_${origversion}.orig.tar.gz
dpkg-buildpackage -r"fakeroot -u" -a$(cat debian/arch)  -i.git -us -uc
dpkg-buildpackage: warning: using a gain-root-command while being root
dpkg-buildpackage: info: source package linux-5.4.26-rt17
dpkg-buildpackage: info: source version 5.4.26-rt17-1
dpkg-buildpackage: info: source distribution bionic
dpkg-buildpackage: info: source changed by root <root@ricks-HP-ZBook-Studio-x360-G5-Ubutu18>
dpkg-buildpackage: info: host architecture amd64
 dpkg-source -i.git --before-build linux-5.4.26
 fakeroot -u debian/rules clean
fakeroot: FAKEROOTKEY set to 894722995
fakeroot: nested operation not yet supported
dpkg-buildpackage: error: fakeroot -u debian/rules clean subprocess returned exit status 1
scripts/Makefile.package:73: recipe for target 'deb-pkg' failed
make[1]: *** [deb-pkg] Error 1
Makefile:1425: recipe for target 'deb-pkg' failed
make: *** [deb-pkg] Error 2
[13:28:08] ricks@ricks-HP-ZBook-Studio-x360-G5-Ub

As I was not able to solve this problem I used the make -j $(nproc) bzImage command instead. While doing this when LZ4 compression is enabled I howver get the following error:

/bin/sh: 1: lz4c: not found
arch/x86/boot/compressed/Makefile:146: recipe for target 'arch/x86/boot/compressed/vmlinux.bin.lz4' failed
make[2]: *** [arch/x86/boot/compressed/vmlinux.bin.lz4] Error 127
make[2]: *** Deleting file 'arch/x86/boot/compressed/vmlinux.bin.lz4'
make[2]: *** Waiting for unfinished jobs....
arch/x86/boot/Makefile:112: recipe for target 'arch/x86/boot/compressed/vmlinux' failed
make[1]: *** [arch/x86/boot/compressed/vmlinux] Error 2
arch/x86/Makefile:284: recipe for target 'bzImage' failed
make: *** [bzImage] Error 2

An explanation about this issue can be found here. At the time of writing, I did, however not know what caused the problem as I had both the liblz4-1 and liblz4-dev packages installed. This problem, however, is solved by installing the liblz4-tool package. As a result, I can now compile the rt-kernel using the following (updated) steps:

Current compilation steps

  1. Install the following necessary dependencies apt-get install build-essential bc curl ca-certificates fakeroot gnupg2 libssl-dev lsb-release libelf-dev bison flex liblz4-tool libncurses-dev libssl-dev (The liblz4-tool dependency is added here since it is not installed by default on ubuntu 18.04).
  2. Download the regular kernel and the patch from the Linux Kernel archive.
  3. Verifying file integrity.
  4. Unzip the Linux kernel tar -xvf Linux-5.4.26.tar.
  5. Go into the kernel folder cd linux-5.4.26.
  6. Apply the patch patch -p1 < ../patch-5.4.26-rt17.patch.
  7. Run make menuconfig and change the Preemption Model to Fully Preemptible Kernel (RT) (PREEMPT_RT_FULL) (NEW) (see this stack question for more info).
  8. Disable debug info scripts/config --disable DEBUG_INFO (Not needed but recommended).
  9. Run make clean.
  10. Make the bzImage make -j $(nproc) bzImage.
  11. Make the modules make -j $(nproc) modules.
  12. Install the modules make -j $(nproc) modules_install.
  13. Install the kernel make -j $(nproc) install.

Config file

The config file I use when trying to compile the realtime kernel can be found in this gist.

@museum-future Just a heads up, this issue still exists under ubuntu 20.04 with the 5.9 kernels. For me, the solution I gave earlier does not work anymore. Another solution is found on https://stackoverflow.com/questions/51669724/install-rt-linux-patch-for-ubuntu. This solution, however, does not work on my system.

Closed to the discussion in one place. The new issue is frankaemika/franka_ros#101.

Ubuntu 20.04 real-time kernel build instructions (non-recommended)

I found out that the instructions I posted earlier do not work anymore on my system using ubuntu 20.04. Below you will therefore find my instructions for building the real-time kernel on ubuntu 20.04 and higher from the source. Please note that as pointed out by the comment below of @gavanderhoorn this is not recommended and is only to be used unless it can't be helped. For the recommended way, see my newer answer.

My system info

OS: Ubuntu 20.04
Default kernel: 5.8.0-53
PC: HP Zbook G5 Studio x360
RAM: 2x32 GB Samsung M471A4G43MB1-CTD geheugenmodule 32 GB DDR4 2666 MHz
GPU: Nvidia Quadro P1000
CPU: Intel(R) Core(TM) i7-8750H CPU @ 2.20GHz

Verified kernels and patches

OS Kernel Patch Build status Install status Problems Comment
Ubuntu 20.04 5.6.19 patch-5.6.19-rt12 For the system to boot, I needed to apply the additional steps below.
Ubuntu 20.04 5.4.26 patch-5.4.26-rt16 For the system to boot, I needed to apply the additional steps below.
Ubuntu 20.04 5.4.26 patch-5.9.1-rt20 For the system to boot, I needed to apply the additional steps below. Also, Bluetooth is disconnected at every boot.

Build and install steps (non-recommended way)

Show non-recommended way

The steps below are a combination of the steps described in the libfranka documentation and this blog post.

  1. Grab the kernel and patch from kernel.org. For the kernel, I recommend choosing the version closest to the one you currently use. For the patch, I recommend choosing the latest version that is available for that kernel. For my system at the time of writing this is kernel 5.6.19 and patch-5.6.19-rt12.patch.xz.

    See bash commands
    curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/v5.x/linux-5.6.19.tar.xz
    curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/v5.x/linux-5.6.19.tar.sign
    curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/5.6/patch-5.6.19-rt12.patch.xz
    curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/5.6/patch-5.6.19-rt12.patch.sign
  2. Decompress the kernel and patch.

    See bash commands
    xz -d linux-5.6.19.tar.xz
    xz -d patch-5.6.19-rt12.patch.xz
  3. Verify the kernel and patch.

    See bash commands

    For more info see the libfranka documentation.

    gpg2  --keyserver hkp://keys.gnupg.net --recv-keys 647F28654894E3BD457199BE38DBBDC86092693E
    gpg2  --keyserver hkp://keys.gnupg.net --recv-keys 57892E705233051337F6FDD105641F175712FA5B
    gpg2 --verify linux-5.6.19.tar.sign
    gpg2 --verify patch-5.6.19-rt12.patch.sign
  4. Untar the kernel.

    See bash commands
    tar xvf linux-5.6.19.tar
  5. Apply the patch to the kernel.

    See bash commands
    cd linux-5.6.19
    patch -p1 < ../patch-5.6.19-rt12.patch
  6. Configure kernel for RT

    See bash commands

    Use make oldconfig

    make oldconfig

    This opens a text-based configuration menu. When asked for the Preemption Model, choose the Fully Preemptible Kernel:

    Preemption Model
    1. No Forced Preemption (Server) (PREEMPT_NONE)
    2. Voluntary Kernel Preemption (Desktop) (PREEMPT_VOLUNTARY)
    3. Preemptible Kernel (Low-Latency Desktop) (PREEMPT)
    >4. Fully Preemptible Kernel (Real-Time) (PREEMPT_RT) (NEW)
    

    Keep all the other settings at their default.

    Use the new menuconfig tool

    Additionally, you can also use the make menuconfig tool. In this tool, you can find the PREEMPT_RT option under General setup ---> Preemption Model (Voluntary Kernel Preemption (Desktop)) --->. Might this change in the future, you can use the / key to search for the PREEMPT_RT option.

  7. Install the required compilers and other tools.

    See bash commands
    sudo apt-get install build-essential libncurses-dev bison flex libssl-dev libelf-dev
  8. Build the kernel.

    See bash commands
    make clean
    make -j $(nproc)
  9. Install the Linux kernel modules.

    See bash commands
    sudo make modules_install 
  10. Install the Linux kernel.

    See bash commands
    sudo make install 

NOTE: For the above steps to work, you need to have root access. If you don't have root access, you can install the fakeroot package and try adding the fakeroot command before the make commands.

Additional steps

There were several problems I encountered on my system that prevented the new kernel from booting.

Kernel gives black screen

After I tried to reboot the system in the new real-time kernel, the system got stuck at the Loading initial ramdisk... message. In my case, this was caused by the fact that Nvidia doesn't support the real-time kernels (see this forum post). As a result, it is tough to get the Nvidia-drivers to work on the real-time kernel on ubuntu. Consequently, since my main kernel uses the Nvidia-460 driver, I had to force the real-time kernel to use the nouveau driver. As explained in this post and this stackoverflow question, this can be done by adding

modprobe.blacklist=nvidia systemd.setenv=GPUMOD=nouveau rd.driver.blacklist=nvidia nouveau.modeset=1 nvidia.modeset=0

To your real-time kernel grub menu entry. Further, remove the nouveau blacklist statements that are placed by the Nvidia Debian in the /lib/modprobe.d/ folder and add the following kernel parameters to your regular kernel grub menu items:

modprobe.blacklist=nouveau systemd.setenv=GPUMOD=nvidia rd.driver.blacklist=nouveau nouveau.modeset=0 nvidia.modeset=1

The easiest way to do this is by installing the grub customizer package and follow the steps shown in the gif below.

change menu

After you changed the menu entry, you can reboot the system, and the real-time kernel should be able to boot. If that does not solve the problem, you can try adding nomodeset instead. If that also does not work, you might have to temporarily switch back to using the Nouveau drivers on your main system.

Kernel panic error

As explained by @mrRo8o7 in this StackOverflow question, the initrd image of some kernels is too big, which causes kernel panic to occur. This problem can be solved using:

# Strip unneeded symbols of object files
$ cd /lib/modules/5.4.5-rt3  # or your new kernel
$ sudo find . -name *.ko -exec strip --strip-unneeded {} +

# Change the compression format
$ sudo vi /etc/initramfs-tools/initramfs.conf
# Modify COMPRESS=lz4 to COMPRESS=xz (line 53)

COMPRESS=xz 

[:wq]

then update initramfs

sudo update-initramfs -u

After this is done, you have to update Grub using the following command:

sudo update-grub

Related issues and resources

Remove real-time kernel

See this StackOverflow question for how to remove a (manually) installed kernel.

make deb-pkg is the recommended way to build .debs for kernel images and headers on Debian (and by extension, Ubuntu). See Building a custom kernel from Debian kernel source in the Debian Kernel handbook.

Personally I wouldn't sudo make install .. anything on OS with a package manager, unless it can't be helped.

After patching the kernel and copying the old config to .config, I had to empty out CONFIG_SYSTEM_TRUSTED_KEYS, then make olddefconfig, then make menuconfig to configure the necessary options, then make clean and finally make deb-pkg (with -jN where N a large nr to not have to wait too long). That resulted in all the expected .debs.

I ran everything in a ubuntu:bionic container, perhaps that helped avoid running into issues with incompatible build environments on systems-in-use.

(I haven't deployed the kernels built this way yet, but seeing as it's the same process as always, I don't expect any difficulties. The target systems do not have nvidia GPUs, so thankfully I'll be spared that bit of trouble)

@gavanderhoorn Thanks a lot for helping me out again. I tested your steps, and with a tiny configuration change, I can now compile any of the real-time kernel patches in the kernel repository. I also see why it is the recommended way, it boots a lot faster than the real-time kernel, and it gives a warning that the Nvidia drivers are not supported for booting the real-time kernel. So I marked my steps above as non-recommended and added the new steps below.

Ubuntu 20.04 real-time kernel build instructions (recommended way)

After the comment @gavanderhoorn, I found the proper steps for building the real-time kernel using the deb-pkg package. These steps are very much in line with the franka documentation. Below, I marked the changed I had to make relative to the documentation to make it work no my system. Keep in mind that different steps might be needed on your system.

Copy your current kernel config instead of creating a new config

To have a successful build, I needed to copy the default kernel configuration into the patched kernel. I did this using the following commands:

cd linux-5.6.19
cp -v /boot/config-$(uname -r) .config

While doing this, you have to make sure that the kernel you are currently booted into is the same as the kernel you are trying to patch (for an excellent tool to install kernel version click here).

Use the make olddefconfig for setting up the config

Similar to the steps of @gavanderhoorn, I had to use the make olddefconfig command instead of the make oldconfig given in the documentation. This makes sure that the defaults are used. After this, I could use the make menuconfig command to set up the PREEMPT RT variable.

Disable the CONFIG_DEBUG_INFO_BTF option

On my system in the .config file, I had to disable the CONFIG_DEBUG_INFO_BTF option as otherwise, it would give me an error explaining that the dwarves package is not recent enough. If you need the debug information, you can also install version 1.17 of the dwarves package.

Run make clean before building the kernel

I had to execute the make clean command on my system before building the package on my system.

Remove fakeroot before the build command

On my system, I could not use the fakeroot package to build the kernel as it would give me a fakeroot: nested operation not yet supported error. This resulted in the following build command make deb-pkg -j $(nproc). As on my system, I have root access, so I do not need this package. For people that need to use this package, please see franka_ros/issues/101.

Install the kernel using the dpkg package

After all these changes, I could install the .deb package using the dpkg package.

Extra steps for Nvidia drivers

When you are using NVidia drivers on any of your other kernels, Nvidia doesn't offer support for these custom kernels (see this post), you have to switch back to nouveau drivers before you try to boot the real-time kernel. A guide to ease this process can be found here and in this stackoverflow post.

@rickstaa I tried your (OLD) instructions with the same Ubuntu version (18.04) and kernel version (5.4.26) and got the following error. Did you encounter any errors like this?

caris@machine:~/linux-5.4.26$ make -j $(nproc) modules_install
cp: cannot stat './modules.builtin.modinfo': No such file or directory
Makefile:1307: recipe for target '_modinst_' failed
make: *** [_modinst_] Error 1

@carismoses I can vaguely remember that I saw that issue. I however noticed that the issues that are encountered with the (OLD) method are dependent on your system and the settings set in make menuconfig. I would advise you to use #62 (comment) or if that doesn't work #62 (comment). If both these recipes don't work and the steps in the documentation also not work, you can also create a new issue.

I was actually able to resolve it by changing one of the config options based on this post.

scripts/config --set-str SYSTEM_TRUSTED_KEYS ""

@carismoses Great to hear you solved it, and thanks for sharing your solution.

Thank you all for solving this issue. We updated the documentation with the findings from you

Hello,
I am trying to set the real-time kernel. Unfortunately, I am getting errors when I try to connect to the UR5 robot externally. I think I might be missing something, and I couldn't recognize it.
I was able to use the setup guide and also followed some of the known issues. However, I wasn't successful.

I checked to see if the new kernel was active/installed, and it seems to be okay.
Screenshot from 2022-01-20 22-34-05

Here is the screenshot of the errors I am getting when I connect the UR5 robot.
Screenshot from 2022-01-20 22-10-58
I knew that there were multiple issues here.

  1. Real-time capabilities
  2. Calibration
  3. RTDE data pipeline

The first two issues were present before I installed the new rt kernel. The third issue came after I installed the new rt kernel. I have also generated a new calibration file; however, I am still getting the error. I thought fixing the real-time kernel issue would clear all problems. But it didn't.

I am happy to share more information if needed. Any help would be greatly appreciated. Thank you.

Hello @medashan,

you do know that libfranka is used for Panda robots not UR5s right? I suggest you open a ticket in their Github or, better yet, buy our robot ;)

Sorry, I didn't know that. Thanks for letting me know.

Hi @rickstaa ,

Thanks for your elaborate testing on this bit!

I am trying to install a real-time kernel with Ubuntu 2204. I tried to install the RT kernel following the document, however it failed in the 'make -j$(nproc) deb-pkg' process where I got some error similar to this one.

Specifically, I first tried to install the RT 6.2.1 kernel with my current 6.2.0-34-generic kernel running, as the document says we'd better pick the closest version, the full commands are:

 $   uname -a
 $   sudo apt-get install build-essential bc curl ca-certificates gnupg2 libssl-dev lsb-release libelf-dev bison flex dwarves zstd libncurses-dev
 $   mkdir rtk
 $   cd rtk/
 $   curl -SLO https://www.kernel.org/pub/linux/kernel/v6.x/linux-6.2.1.tar.xz
 $   curl -SLO https://www.kernel.org/pub/linux/kernel/v6.x/linux-6.2.1.tar.sign
 $   curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/6.2/patch-6.2-rt3.patch.xz
 $   curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/6.2/patch-6.2-rt3.patch.sign
 $   xz -d *.xz
 $   gpg2 --verify linux-*.tar.sign
 $   gpg2 --verify patch-*.patch.sign
 $   tar xf linux-*.tar
 $   cd linux-*/
 $   patch -p1 < ../patch-*.patch
 $   cp -v /boot/config-$(uname -r) .config
 $   make olddefconfig
 $   make menuconfig
 $   make -j$(nproc) deb-pkg

This failed after around 15 mins and showed something like:

...
  CC [M]  drivers/comedi/drivers/ni_labpc_common.o
  CC [M]  drivers/comedi/drivers/ni_labpc_isadma.o
  LD [M]  drivers/iio/pressure/st_pressure.o
  CC [M]  drivers/comedi/drivers/comedi_8255.o
  CC [M]  drivers/infiniband/hw/hfi1/debugfs.o
  CC [M]  drivers/comedi/drivers/8255.o
  CC [M]  drivers/comedi/drivers/amplc_dio200_common.o
  CC [M]  drivers/comedi/drivers/amplc_pc236_common.o
  CC [M]  drivers/comedi/drivers/das08.o
  LD [M]  drivers/comedi/drivers/ni_routing.o
  LD [M]  drivers/infiniband/hw/hfi1/hfi1.o
make[3]: *** [Makefile:2021: .] Error 2
make[2]: *** [debian/rules:7: build-arch] Error 2
dpkg-buildpackage: error: debian/rules binary subprocess returned exit status 2
make[1]: *** [scripts/Makefile.package:90: deb-pkg] Error 2
make: *** [Makefile:1665: deb-pkg] Error 2

Later, I also tried first installing the 6.2.1 kernel with a tool called Ukuu Mainline following here, and then rebooted and selected the 6.2.1 kernel (used "uname -r" to confirm it). After that, I ran exactly the same steps from the Franka document. And it still met the same error.

Could you please give me some suggestions on this bit?

Many thanks,
Bourne

Hi @rickstaa ,

Thanks for your elaborate testing on this bit!

I am trying to install a real-time kernel with Ubuntu 2204. I tried to install the RT kernel following the document, however it failed in the 'make -j$(nproc) deb-pkg' process where I got some error similar to this one.

Specifically, I first tried to install the RT 6.2.1 kernel with my current 6.2.0-34-generic kernel running, as the document says we'd better pick the closest version, the full commands are:

 $   uname -a
 $   sudo apt-get install build-essential bc curl ca-certificates gnupg2 libssl-dev lsb-release libelf-dev bison flex dwarves zstd libncurses-dev
 $   mkdir rtk
 $   cd rtk/
 $   curl -SLO https://www.kernel.org/pub/linux/kernel/v6.x/linux-6.2.1.tar.xz
 $   curl -SLO https://www.kernel.org/pub/linux/kernel/v6.x/linux-6.2.1.tar.sign
 $   curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/6.2/patch-6.2-rt3.patch.xz
 $   curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/6.2/patch-6.2-rt3.patch.sign
 $   xz -d *.xz
 $   gpg2 --verify linux-*.tar.sign
 $   gpg2 --verify patch-*.patch.sign
 $   tar xf linux-*.tar
 $   cd linux-*/
 $   patch -p1 < ../patch-*.patch
 $   cp -v /boot/config-$(uname -r) .config
 $   make olddefconfig
 $   make menuconfig
 $   make -j$(nproc) deb-pkg

This failed after around 15 mins and showed something like:

...
  CC [M]  drivers/comedi/drivers/ni_labpc_common.o
  CC [M]  drivers/comedi/drivers/ni_labpc_isadma.o
  LD [M]  drivers/iio/pressure/st_pressure.o
  CC [M]  drivers/comedi/drivers/comedi_8255.o
  CC [M]  drivers/infiniband/hw/hfi1/debugfs.o
  CC [M]  drivers/comedi/drivers/8255.o
  CC [M]  drivers/comedi/drivers/amplc_dio200_common.o
  CC [M]  drivers/comedi/drivers/amplc_pc236_common.o
  CC [M]  drivers/comedi/drivers/das08.o
  LD [M]  drivers/comedi/drivers/ni_routing.o
  LD [M]  drivers/infiniband/hw/hfi1/hfi1.o
make[3]: *** [Makefile:2021: .] Error 2
make[2]: *** [debian/rules:7: build-arch] Error 2
dpkg-buildpackage: error: debian/rules binary subprocess returned exit status 2
make[1]: *** [scripts/Makefile.package:90: deb-pkg] Error 2
make: *** [Makefile:1665: deb-pkg] Error 2

Later, I also tried first installing the 6.2.1 kernel with a tool called Ukuu Mainline following here, and then rebooted and selected the 6.2.1 kernel (used "uname -r" to confirm it). After that, I ran exactly the same steps from the Franka document. And it still met the same error.

Could you please give me some suggestions on this bit?

Many thanks, Bourne

By the way, when I tried to run the command 'make -j$(nproc) deb-pkg' again after the previous error showed up, this time it didn't do the build that long and stopped within 10 seconds with this error:

(franka) bourne@bourne:~/dev/franka/rtk/linux-6.2.1$ make -j$(nproc) deb-pkg
make clean
  CLEAN   arch/x86/lib
  CLEAN   crypto/asymmetric_keys
  CLEAN   arch/x86/crypto
  CLEAN   init
  CLEAN   arch/x86/kvm
  CLEAN   arch/x86/entry/vdso
  CLEAN   drivers/accessibility/speakup
  CLEAN   kernel/debug/kdb
  CLEAN   security/apparmor
  CLEAN   arch/x86/kernel/cpu
  CLEAN   net/bpfilter
  CLEAN   usr
  CLEAN   arch/x86/kernel
  CLEAN   lib/raid6
  CLEAN   arch/x86/purgatory
  CLEAN   arch/x86/realmode/rm
  CLEAN   security/selinux
  CLEAN   lib
  CLEAN   arch/x86/tools
  CLEAN   security/tomoyo
  CLEAN   kernel
  CLEAN   drivers/eisa
  CLEAN   drivers/firmware/efi/libstub
  CLEAN   net/wireless
  CLEAN   fs/unicode
  CLEAN   drivers/gpu/drm/radeon
  CLEAN   drivers/net/wan
  CLEAN   drivers/scsi/aic7xxx
  CLEAN   drivers/tty/vt
  CLEAN   drivers/scsi
  CLEAN   .
sh ./scripts/package/mkdebian
  TAR     linux-upstream.tar.gz
origversion=$(dpkg-parsechangelog -SVersion |sed 's/-[^-]*$//');\
	mv linux-upstream.tar.gz ../linux-upstream_${origversion}.orig.tar.gz
dpkg-buildpackage -r"fakeroot -u" -a$(cat debian/arch)  -i.git -us -uc
dpkg-buildpackage: info: source package linux-upstream
dpkg-buildpackage: info: source version 6.2.1-rt3-2
dpkg-buildpackage: info: source distribution jammy
dpkg-buildpackage: info: source changed by bourne <bourne@bourne>
dpkg-buildpackage: info: host architecture amd64
 dpkg-source -i.git --before-build .
 debian/rules clean
rm -rf debian/*tmp debian/files
make clean
 dpkg-source -i.git -b .
dpkg-source: info: using source format '1.0'
dpkg-source: warning: source directory 'linux-6.2.1' is not <sourcepackage>-<upstreamversion> 'linux-upstream-6.2.1-rt3'
dpkg-source: warning: .orig directory name linux-6.2.1.orig is not <package>-<upstreamversion> (wanted linux-upstream-6.2.1-rt3.orig)
dpkg-source: info: building linux-upstream using existing linux-upstream_6.2.1-rt3.orig.tar.gz
dpkg-source: info: building linux-upstream in linux-upstream_6.2.1-rt3-2.diff.gz
dpkg-source: error: cannot represent change to vmlinux-gdb.py:
dpkg-source: error:   new version is symlink to /home/bourne/dev/franka/rtk/linux-6.2.1/scripts/gdb/vmlinux-gdb.py
dpkg-source: error:   old version is nonexistent
dpkg-source: warning: ignoring deletion of file .scmversion
dpkg-source: warning: the diff modifies the following upstream files: 
 .clang-format
 .cocciconfig
 .config.old
 .get_maintainer.ignore
 .mailmap
 .rustfmt.toml
 .version
 CREDITS
 MAINTAINERS
 README
dpkg-source: info: use the '3.0 (quilt)' format to have separate and documented changes to upstream files, see dpkg-source(1)
dpkg-source: error: unrepresentable changes to source
dpkg-buildpackage: error: dpkg-source -i.git -b . subprocess returned exit status 1
make[1]: *** [scripts/Makefile.package:90: deb-pkg] Error 1
make: *** [Makefile:1665: deb-pkg] Error 2

Hi @rickstaa ,
Thanks for your elaborate testing on this bit!
I am trying to install a real-time kernel with Ubuntu 2204. I tried to install the RT kernel following the document, however it failed in the 'make -j$(nproc) deb-pkg' process where I got some error similar to this one.
Specifically, I first tried to install the RT 6.2.1 kernel with my current 6.2.0-34-generic kernel running, as the document says we'd better pick the closest version, the full commands are:

 $   uname -a
 $   sudo apt-get install build-essential bc curl ca-certificates gnupg2 libssl-dev lsb-release libelf-dev bison flex dwarves zstd libncurses-dev
 $   mkdir rtk
 $   cd rtk/
 $   curl -SLO https://www.kernel.org/pub/linux/kernel/v6.x/linux-6.2.1.tar.xz
 $   curl -SLO https://www.kernel.org/pub/linux/kernel/v6.x/linux-6.2.1.tar.sign
 $   curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/6.2/patch-6.2-rt3.patch.xz
 $   curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/6.2/patch-6.2-rt3.patch.sign
 $   xz -d *.xz
 $   gpg2 --verify linux-*.tar.sign
 $   gpg2 --verify patch-*.patch.sign
 $   tar xf linux-*.tar
 $   cd linux-*/
 $   patch -p1 < ../patch-*.patch
 $   cp -v /boot/config-$(uname -r) .config
 $   make olddefconfig
 $   make menuconfig
 $   make -j$(nproc) deb-pkg

This failed after around 15 mins and showed something like:

...
  CC [M]  drivers/comedi/drivers/ni_labpc_common.o
  CC [M]  drivers/comedi/drivers/ni_labpc_isadma.o
  LD [M]  drivers/iio/pressure/st_pressure.o
  CC [M]  drivers/comedi/drivers/comedi_8255.o
  CC [M]  drivers/infiniband/hw/hfi1/debugfs.o
  CC [M]  drivers/comedi/drivers/8255.o
  CC [M]  drivers/comedi/drivers/amplc_dio200_common.o
  CC [M]  drivers/comedi/drivers/amplc_pc236_common.o
  CC [M]  drivers/comedi/drivers/das08.o
  LD [M]  drivers/comedi/drivers/ni_routing.o
  LD [M]  drivers/infiniband/hw/hfi1/hfi1.o
make[3]: *** [Makefile:2021: .] Error 2
make[2]: *** [debian/rules:7: build-arch] Error 2
dpkg-buildpackage: error: debian/rules binary subprocess returned exit status 2
make[1]: *** [scripts/Makefile.package:90: deb-pkg] Error 2
make: *** [Makefile:1665: deb-pkg] Error 2

Later, I also tried first installing the 6.2.1 kernel with a tool called Ukuu Mainline following here, and then rebooted and selected the 6.2.1 kernel (used "uname -r" to confirm it). After that, I ran exactly the same steps from the Franka document. And it still met the same error.
Could you please give me some suggestions on this bit?
Many thanks, Bourne

By the way, when I tried to run the command 'make -j$(nproc) deb-pkg' again after the previous error showed up, this time it didn't do the build that long and stopped within 10 seconds with this error:

(franka) bourne@bourne:~/dev/franka/rtk/linux-6.2.1$ make -j$(nproc) deb-pkg
make clean
  CLEAN   arch/x86/lib
  CLEAN   crypto/asymmetric_keys
  CLEAN   arch/x86/crypto
  CLEAN   init
  CLEAN   arch/x86/kvm
  CLEAN   arch/x86/entry/vdso
  CLEAN   drivers/accessibility/speakup
  CLEAN   kernel/debug/kdb
  CLEAN   security/apparmor
  CLEAN   arch/x86/kernel/cpu
  CLEAN   net/bpfilter
  CLEAN   usr
  CLEAN   arch/x86/kernel
  CLEAN   lib/raid6
  CLEAN   arch/x86/purgatory
  CLEAN   arch/x86/realmode/rm
  CLEAN   security/selinux
  CLEAN   lib
  CLEAN   arch/x86/tools
  CLEAN   security/tomoyo
  CLEAN   kernel
  CLEAN   drivers/eisa
  CLEAN   drivers/firmware/efi/libstub
  CLEAN   net/wireless
  CLEAN   fs/unicode
  CLEAN   drivers/gpu/drm/radeon
  CLEAN   drivers/net/wan
  CLEAN   drivers/scsi/aic7xxx
  CLEAN   drivers/tty/vt
  CLEAN   drivers/scsi
  CLEAN   .
sh ./scripts/package/mkdebian
  TAR     linux-upstream.tar.gz
origversion=$(dpkg-parsechangelog -SVersion |sed 's/-[^-]*$//');\
	mv linux-upstream.tar.gz ../linux-upstream_${origversion}.orig.tar.gz
dpkg-buildpackage -r"fakeroot -u" -a$(cat debian/arch)  -i.git -us -uc
dpkg-buildpackage: info: source package linux-upstream
dpkg-buildpackage: info: source version 6.2.1-rt3-2
dpkg-buildpackage: info: source distribution jammy
dpkg-buildpackage: info: source changed by bourne <bourne@bourne>
dpkg-buildpackage: info: host architecture amd64
 dpkg-source -i.git --before-build .
 debian/rules clean
rm -rf debian/*tmp debian/files
make clean
 dpkg-source -i.git -b .
dpkg-source: info: using source format '1.0'
dpkg-source: warning: source directory 'linux-6.2.1' is not <sourcepackage>-<upstreamversion> 'linux-upstream-6.2.1-rt3'
dpkg-source: warning: .orig directory name linux-6.2.1.orig is not <package>-<upstreamversion> (wanted linux-upstream-6.2.1-rt3.orig)
dpkg-source: info: building linux-upstream using existing linux-upstream_6.2.1-rt3.orig.tar.gz
dpkg-source: info: building linux-upstream in linux-upstream_6.2.1-rt3-2.diff.gz
dpkg-source: error: cannot represent change to vmlinux-gdb.py:
dpkg-source: error:   new version is symlink to /home/bourne/dev/franka/rtk/linux-6.2.1/scripts/gdb/vmlinux-gdb.py
dpkg-source: error:   old version is nonexistent
dpkg-source: warning: ignoring deletion of file .scmversion
dpkg-source: warning: the diff modifies the following upstream files: 
 .clang-format
 .cocciconfig
 .config.old
 .get_maintainer.ignore
 .mailmap
 .rustfmt.toml
 .version
 CREDITS
 MAINTAINERS
 README
dpkg-source: info: use the '3.0 (quilt)' format to have separate and documented changes to upstream files, see dpkg-source(1)
dpkg-source: error: unrepresentable changes to source
dpkg-buildpackage: error: dpkg-source -i.git -b . subprocess returned exit status 1
make[1]: *** [scripts/Makefile.package:90: deb-pkg] Error 1
make: *** [Makefile:1665: deb-pkg] Error 2

I am able to install the RT kernel with Ubuntu 22.04 now thanks to my genius fellow. And here is the solution:

Follow all the lines posted here.

Before sudo make, you need to modify these lines in the .config file copied from /boot/config-xxxx-generic:

CONFIG_SYSTEM_TRUSTED_KEYS="debian/canonical-certs.pem"

Change this to this:

CONFIG_SYSTEM_TRUSTED_KEYS=""

And

CONFIG_SYSTEM_REVOCATION_KEYS="debian/canonical-revoked-certs.pem"

to

CONFIG_SYSTEM_REVOCATION_KEYS=""

(The latter key has been added to the default Canonical kernel configuration since some time.)

As we disable the keys, instead of make -j$(nproc) deb-pkg, we just used make -j$(nproc) omitting deb-pkg. Otherwise we would meet some errors related to the dpkgs-source.

FYI, my current kernel is 6.2.0-34-generic and the RT kernel I installed is 6.2.1-rt3. I tried kernel 5.15.96-rt61 which also worked. My experience is: when you do make -j$(nproc) deb-pkg, if there is any error prompt, it probably does not show the real error caused by debian package or configuration. Might be wrong with this bit.

Reference:

  1. https://www.acontis.com/en/building-a-real-time-linux-kernel-in-ubuntu-preemptrt.html
  2. https://askubuntu.com/questions/1329538/compiling-the-kernel-5-11-11
  3. My genius fellow.

Hi @rickstaa ,
Thanks for your elaborate testing on this bit!
I am trying to install a real-time kernel with Ubuntu 2204. I tried to install the RT kernel following the document, however it failed in the 'make -j$(nproc) deb-pkg' process where I got some error similar to this one.
Specifically, I first tried to install the RT 6.2.1 kernel with my current 6.2.0-34-generic kernel running, as the document says we'd better pick the closest version, the full commands are:

 $   uname -a
 $   sudo apt-get install build-essential bc curl ca-certificates gnupg2 libssl-dev lsb-release libelf-dev bison flex dwarves zstd libncurses-dev
 $   mkdir rtk
 $   cd rtk/
 $   curl -SLO https://www.kernel.org/pub/linux/kernel/v6.x/linux-6.2.1.tar.xz
 $   curl -SLO https://www.kernel.org/pub/linux/kernel/v6.x/linux-6.2.1.tar.sign
 $   curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/6.2/patch-6.2-rt3.patch.xz
 $   curl -SLO https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/6.2/patch-6.2-rt3.patch.sign
 $   xz -d *.xz
 $   gpg2 --verify linux-*.tar.sign
 $   gpg2 --verify patch-*.patch.sign
 $   tar xf linux-*.tar
 $   cd linux-*/
 $   patch -p1 < ../patch-*.patch
 $   cp -v /boot/config-$(uname -r) .config
 $   make olddefconfig
 $   make menuconfig
 $   make -j$(nproc) deb-pkg

This failed after around 15 mins and showed something like:

...
  CC [M]  drivers/comedi/drivers/ni_labpc_common.o
  CC [M]  drivers/comedi/drivers/ni_labpc_isadma.o
  LD [M]  drivers/iio/pressure/st_pressure.o
  CC [M]  drivers/comedi/drivers/comedi_8255.o
  CC [M]  drivers/infiniband/hw/hfi1/debugfs.o
  CC [M]  drivers/comedi/drivers/8255.o
  CC [M]  drivers/comedi/drivers/amplc_dio200_common.o
  CC [M]  drivers/comedi/drivers/amplc_pc236_common.o
  CC [M]  drivers/comedi/drivers/das08.o
  LD [M]  drivers/comedi/drivers/ni_routing.o
  LD [M]  drivers/infiniband/hw/hfi1/hfi1.o
make[3]: *** [Makefile:2021: .] Error 2
make[2]: *** [debian/rules:7: build-arch] Error 2
dpkg-buildpackage: error: debian/rules binary subprocess returned exit status 2
make[1]: *** [scripts/Makefile.package:90: deb-pkg] Error 2
make: *** [Makefile:1665: deb-pkg] Error 2

Later, I also tried first installing the 6.2.1 kernel with a tool called Ukuu Mainline following here, and then rebooted and selected the 6.2.1 kernel (used "uname -r" to confirm it). After that, I ran exactly the same steps from the Franka document. And it still met the same error.
Could you please give me some suggestions on this bit?
Many thanks, Bourne

By the way, when I tried to run the command 'make -j$(nproc) deb-pkg' again after the previous error showed up, this time it didn't do the build that long and stopped within 10 seconds with this error:

(franka) bourne@bourne:~/dev/franka/rtk/linux-6.2.1$ make -j$(nproc) deb-pkg
make clean
  CLEAN   arch/x86/lib
  CLEAN   crypto/asymmetric_keys
  CLEAN   arch/x86/crypto
  CLEAN   init
  CLEAN   arch/x86/kvm
  CLEAN   arch/x86/entry/vdso
  CLEAN   drivers/accessibility/speakup
  CLEAN   kernel/debug/kdb
  CLEAN   security/apparmor
  CLEAN   arch/x86/kernel/cpu
  CLEAN   net/bpfilter
  CLEAN   usr
  CLEAN   arch/x86/kernel
  CLEAN   lib/raid6
  CLEAN   arch/x86/purgatory
  CLEAN   arch/x86/realmode/rm
  CLEAN   security/selinux
  CLEAN   lib
  CLEAN   arch/x86/tools
  CLEAN   security/tomoyo
  CLEAN   kernel
  CLEAN   drivers/eisa
  CLEAN   drivers/firmware/efi/libstub
  CLEAN   net/wireless
  CLEAN   fs/unicode
  CLEAN   drivers/gpu/drm/radeon
  CLEAN   drivers/net/wan
  CLEAN   drivers/scsi/aic7xxx
  CLEAN   drivers/tty/vt
  CLEAN   drivers/scsi
  CLEAN   .
sh ./scripts/package/mkdebian
  TAR     linux-upstream.tar.gz
origversion=$(dpkg-parsechangelog -SVersion |sed 's/-[^-]*$//');\
	mv linux-upstream.tar.gz ../linux-upstream_${origversion}.orig.tar.gz
dpkg-buildpackage -r"fakeroot -u" -a$(cat debian/arch)  -i.git -us -uc
dpkg-buildpackage: info: source package linux-upstream
dpkg-buildpackage: info: source version 6.2.1-rt3-2
dpkg-buildpackage: info: source distribution jammy
dpkg-buildpackage: info: source changed by bourne <bourne@bourne>
dpkg-buildpackage: info: host architecture amd64
 dpkg-source -i.git --before-build .
 debian/rules clean
rm -rf debian/*tmp debian/files
make clean
 dpkg-source -i.git -b .
dpkg-source: info: using source format '1.0'
dpkg-source: warning: source directory 'linux-6.2.1' is not <sourcepackage>-<upstreamversion> 'linux-upstream-6.2.1-rt3'
dpkg-source: warning: .orig directory name linux-6.2.1.orig is not <package>-<upstreamversion> (wanted linux-upstream-6.2.1-rt3.orig)
dpkg-source: info: building linux-upstream using existing linux-upstream_6.2.1-rt3.orig.tar.gz
dpkg-source: info: building linux-upstream in linux-upstream_6.2.1-rt3-2.diff.gz
dpkg-source: error: cannot represent change to vmlinux-gdb.py:
dpkg-source: error:   new version is symlink to /home/bourne/dev/franka/rtk/linux-6.2.1/scripts/gdb/vmlinux-gdb.py
dpkg-source: error:   old version is nonexistent
dpkg-source: warning: ignoring deletion of file .scmversion
dpkg-source: warning: the diff modifies the following upstream files: 
 .clang-format
 .cocciconfig
 .config.old
 .get_maintainer.ignore
 .mailmap
 .rustfmt.toml
 .version
 CREDITS
 MAINTAINERS
 README
dpkg-source: info: use the '3.0 (quilt)' format to have separate and documented changes to upstream files, see dpkg-source(1)
dpkg-source: error: unrepresentable changes to source
dpkg-buildpackage: error: dpkg-source -i.git -b . subprocess returned exit status 1
make[1]: *** [scripts/Makefile.package:90: deb-pkg] Error 1
make: *** [Makefile:1665: deb-pkg] Error 2

I am able to install the RT kernel with Ubuntu 22.04 now thanks to my genius fellow. And here is the solution:

Follow all the lines posted here.

Before sudo make, you need to modify these lines in the .config file copied from /boot/config-xxxx-generic:

CONFIG_SYSTEM_TRUSTED_KEYS="debian/canonical-certs.pem"

Change this to this:

CONFIG_SYSTEM_TRUSTED_KEYS=""

And

CONFIG_SYSTEM_REVOCATION_KEYS="debian/canonical-revoked-certs.pem"

to

CONFIG_SYSTEM_REVOCATION_KEYS=""

(The latter key has been added to the default Canonical kernel configuration since some time.)

As we disable the keys, instead of make -j$(nproc) deb-pkg, we just used make -j$(nproc) omitting deb-pkg. Otherwise we would meet some errors related to the dpkgs-source.

FYI, my current kernel is 6.2.0-34-generic and the RT kernel I installed is 6.2.1-rt3. I tried kernel 5.15.96-rt61 which also worked. My experience is: when you do make -j$(nproc) deb-pkg, if there is any error prompt, it probably does not show the real error caused by debian package or configuration. Might be wrong with this bit.

Reference:

  1. https://www.acontis.com/en/building-a-real-time-linux-kernel-in-ubuntu-preemptrt.html
  2. https://askubuntu.com/questions/1329538/compiling-the-kernel-5-11-11
  3. My genius fellow.

It's good to learn that you cracked the code on your issue! Thanks for sharing the solution here so other users can use it in the future! 🌟

Hey @yijionglin,

I am facing similar issue but on Ubuntu 20.04 LTS. I am trying to install kernel 5.15.96 but I get this error. I've followed all the steps you (and @gavanderhoorn ) mentioned above but I still get this error. Please can you suggest anything?

make[2]: *** [debian/rules:7: build-arch] Error 2
dpkg-buildpackage: error: debian/rules binary subprocess returned exit status 2
make[1]: *** [scripts/Makefile.package:77: deb-pkg] Error 2
make: *** [Makefile:1611: deb-pkg] Error 2

It compiles till a certain moment when I also get this error:


MODPOST modules-only.symvers
  ZSTD22  arch/x86/boot/compressed/vmlinux.bin.zst
/bin/sh: 1: zstd: not found
make[2]: *** [arch/x86/boot/compressed/Makefile:143: arch/x86/boot/compressed/vmlinux.bin.zst] Error 127
make[2]: *** Deleting file 'arch/x86/boot/compressed/vmlinux.bin.zst'
make[2]: *** Waiting for unfinished jobs....
make[1]: *** [arch/x86/boot/Makefile:115: arch/x86/boot/compressed/vmlinux] Error 2
make: *** [arch/x86/Makefile:257: bzImage] Error 2
make: *** Waiting for unfinished jobs....

Thanks,
Adwait