Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

kernel-install: integration #5135

Draft
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

jmarrero
Copy link
Member

@jmarrero jmarrero commented Oct 22, 2024

incorporates #5097
closes: #4726

This will pair with: https://gitlab.com/fedora/bootc/base-images/-/merge_requests/62 which makes the integration work.

This builds and works on the following Containerfile.

Need to figure out how to properly deal with the commented out code still.

FROM $image
RUN curl -O -L -k https://kojipkgs.fedoraproject.org//packages/kernel/6.12.0/0.rc1.20241005git27cc6fdf7201.22.fc42/x86_64/kernel-6.12.0-0.rc1.20241005git27cc6fdf7201.22.fc42.x86_64.rpm && \
 curl -O -L -k https://kojipkgs.fedoraproject.org//packages/kernel/6.12.0/0.rc1.20241005git27cc6fdf7201.22.fc42/x86_64/kernel-core-6.12.0-0.rc1.20241005git27cc6fdf7201.22.fc42.x86_64.rpm && \
 curl -O -L -k https://kojipkgs.fedoraproject.org//packages/kernel/6.12.0/0.rc1.20241005git27cc6fdf7201.22.fc42/x86_64/kernel-modules-6.12.0-0.rc1.20241005git27cc6fdf7201.22.fc42.x86_64.rpm && \
 curl -O -L -k https://kojipkgs.fedoraproject.org//packages/kernel/6.12.0/0.rc1.20241005git27cc6fdf7201.22.fc42/x86_64/kernel-modules-core-6.12.0-0.rc1.20241005git27cc6fdf7201.22.fc42.x86_64.rpm && \
 curl -O -L -k https://kojipkgs.fedoraproject.org//packages/kernel/6.12.0/0.rc1.20241005git27cc6fdf7201.22.fc42/x86_64/kernel-modules-extra-6.12.0-0.rc1.20241005git27cc6fdf7201.22.fc42.x86_64.rpm

ADD target/debug/rpm-ostree /usr/bin/rpm-ostree
RUN dnf install -y /kernel*

Copy link

openshift-ci bot commented Oct 22, 2024

Skipping CI for Draft Pull Request.
If you want CI signal for your change, please convert it to an actual PR.
You can still manually trigger a test run with /test all

@jmarrero jmarrero changed the title Override replace kernel kernel-install: integration Oct 22, 2024
Copy link
Member

@cgwalters cgwalters left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for working on this!

rust/src/kernel_install.rs Outdated Show resolved Hide resolved
rust/src/kernel_install.rs Outdated Show resolved Hide resolved
rust/src/kernel_install.rs Outdated Show resolved Hide resolved
rust/src/kernel_install.rs Outdated Show resolved Hide resolved
rust/src/kernel_install.rs Outdated Show resolved Hide resolved
rust/src/main.rs Outdated Show resolved Hide resolved
rust/src/core.rs Outdated Show resolved Hide resolved
rust/src/core.rs Outdated Show resolved Hide resolved
@jmarrero jmarrero force-pushed the override-replace-kernel branch 2 times, most recently from 74d2f7e to 04dcac2 Compare October 25, 2024 12:57
@jmarrero
Copy link
Member Author

todo here:

  • make sure fips works
  • make sure that layering on a booted environment still works

@cgwalters
Copy link
Member

Joseph and I were looking at #4950 - I'd forgotten about that change when looking at this one.

This is all quite messy because we need to handle 2 different cases with the updated rpm-ostree (i.e. after this PR).

  • Existing base images (e.g. fcos, fedora-bootc) without the change to add integration with kernel-install; rpm-ostree override replace kernel* must continue to work
  • Base images that do have it enabled (and it's only in this case that dnf upgrade kernel will work, what we're trying to fix here)

In the first case, we must just go into our existing kernel handling and not assume the real kernel-install works. In the second, we could do two different things:

  • Detect that the base image has layout=ostree and don't wrap kernel-install
  • Or just use our own integration

I would lean to unconditionally doing the first...we shouldn't try to have it two different ways in the second. Basically let's test stuff well, and then pull the trigger on the base image side and always go through the real kernel-install.

cgwalters and others added 2 commits December 20, 2024 10:53
We also correctly parse the arguments passed on kernel-install.
@jmarrero jmarrero force-pushed the override-replace-kernel branch from 3a4f740 to 52ec043 Compare December 20, 2024 17:32
@jmarrero jmarrero force-pushed the override-replace-kernel branch from 52ec043 to ca3d005 Compare December 20, 2024 17:37
@jmarrero
Copy link
Member Author

jmarrero commented Dec 20, 2024

+ rpm-ostree override replace 'https://koji.fedoraproject.org/koji/buildinfo?buildID=2571615'
Downloading https://kojipkgs.fedoraproject.org/packages/kernel/6.11.4/301.fc41/x86_64/kernel-6.11.4-301.fc41.x86_64.rpm...done
Downloading https://kojipkgs.fedoraproject.org/packages/kernel/6.11.4/301.fc41/x86_64/kernel-modules-core-6.11.4-301.fc41.x86_64.rpm...done
Downloading https://kojipkgs.fedoraproject.org/packages/kernel/6.11.4/301.fc41/x86_64/kernel-core-6.11.4-301.fc41.x86_64.rpm...done
Downloading https://kojipkgs.fedoraproject.org/packages/kernel/6.11.4/301.fc41/x86_64/kernel-modules-6.11.4-301.fc41.x86_64.rpm...done
Enabled rpm-md repositories: libtest updates fedora-cisco-openh264 fedora updates-archive
Importing rpm-md...done
rpm-md repo 'libtest' (cached); generated: 2024-12-20T17:38:23Z solvables: 32
rpm-md repo 'updates' (cached); generated: 2024-12-20T13:31:04Z solvables: 14309
rpm-md repo 'fedora-cisco-openh264' (cached); generated: 2024-03-11T19:22:31Z solvables: 3
rpm-md repo 'fedora' (cached); generated: 2024-10-24T13:55:59Z solvables: 76624
rpm-md repo 'updates-archive' (cached); generated: 2024-12-20T13:56:56Z solvables: 178[81](https://github.com/coreos/rpm-ostree/actions/runs/12435892073/job/34722979374?pr=5135#step:8:82)
Resolving dependencies...done
Installing 4 packages:
  kernel-6.11.4-301.fc41.x86_64 (@commandline)
  kernel-core-6.11.4-301.fc41.x86_64 (@commandline)
  kernel-modules-6.11.4-301.fc41.x[86](https://github.com/coreos/rpm-ostree/actions/runs/12435892073/job/34722979374?pr=5135#step:8:87)_64 (@commandline)
  kernel-modules-core-6.11.4-301.fc41.x86_64 (@commandline)
Downgrading: kernel-modules-core;6.11.4-301.fc41;x86_64;local
Downgrading: kernel-core;6.11.4-301.fc41;x86_64;local
Downgrading: kernel-modules;6.11.4-301.fc41;x86_64;local
Downgrading: kernel;6.11.4-301.fc41;x86_64;local
Cleanup: kernel;6.12.4-200.fc41;x86_64;installed
Cleanup: kernel-modules;6.12.4-200.fc41;x86_64;installed
Cleanup: kernel-modules-core;6.12.4-200.fc41;x86_64;installed
Cleanup: kernel-core;6.12.4-200.fc41;x86_64;installed
grub2-probe: error: failed to get canonical path of `overlay'.
No path or device is specified.
Usage: grub2-probe [OPTION...] [OPTION]... [PATH|DEVICE]
Try 'grub2-probe --help' or 'grub2-probe --usage' for more information.
dracut[E]: No '/dev/log' or 'logger' included for syslog logging
dracut-install: ERROR: installing '/root'
dracut[E]: FAILED: /usr/lib/dracut/dracut-install -D /var/tmp/dracut.PaxRZT/initramfs -f /root
+ test -f /usr/lib/modules/6.11.4-301.fc41.x86_64/initramfs.img
Error: Process completed with exit code 1.

It looks like I need to add a conditional to the scripts module too.

@cgwalters
Copy link
Member

That output looks like we're missing the hostonly=no for dracut, i.e. part of the generic dracut configs.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Integrate with kernel-install.d
2 participants