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

Various kernel/hwe issues supporting Surface/Asus devices #2051

Open
castrojo opened this issue Dec 15, 2024 · 28 comments
Open

Various kernel/hwe issues supporting Surface/Asus devices #2051

castrojo opened this issue Dec 15, 2024 · 28 comments

Comments

@castrojo
Copy link
Member

castrojo commented Dec 15, 2024

Tracker issue for Asus and Surface. The main issue is no one on the team has any of these devices. We've been making these since like F37 and they're still mostly unmaintained. Since there's no real plan for any of these patches to go upstream we need to reevaluate our ability to provide these.

We tried to see if we could reuse Bazzite's kernel (which carries these patches) but those don't seem to work either. m2 is looking at re-enabling asus and surface for now so we have F41 back and working and see if we can limp along for the rest of the cycle.

Then we'd like to just drop support for asus and surface from bluefin for F42 and on, and then if someone wants to make builds on these it'll at least be a much easier dnf swap than what we had setup in the past.

@daegalus
Copy link

A dnf swap is fine as long as we don't have so many extra packages depending on the kernel packages. I tried a kernel swap and there was a bunch of surface and tools depending on stuff, even though it was an Asus laptop .

So if it is easier, a kernel swap would work for most.

I would also consider maintaining a set of Asus images. I just had no clue there was even a need for maintainers.

Also why not rely on upstream kernels for support of these hardware's. Maintain the pieces that bluefin covers, but rely on the testing and communities of the kernels for compatibility.

Is there a reason you need to maintain those yourselves?

I am just still not seeing where the pain points are of maintain Asus and Surface builds

@castrojo
Copy link
Member Author

Also why not rely on upstream kernels for support of these hardware's.

The upstream kernel doesn't carry the patches for asus/surface. What we've done in the past is build images that swap in the asus-linux or surface-linux kernels. We were hoping that bazzite's kernel (which carries those patches), would give us one kernel to support both, but that hasn't been working.

@daegalus
Copy link

daegalus commented Dec 15, 2024

Also why not rely on upstream kernels for support of these hardware's.

The upstream kernel doesn't carry the patches for asus/surface. What we've done in the past is build images that swap in the asus-linux or surface-linux kernels. We were hoping that bazzite's kernel (which carries those patches), would give us one kernel to support both, but that hasn't been working.

Sorry, I misspoke. I did mean the Asus/Surface kernels as "upstream" as for these images the upstream would be the respectively asus-kernel or linux-surface projects. I had a surface in the past, and now an Asus, so I am familiar with both projects, and the few extra packages that are needed outside the kernel. Like the touchscreen daemon for surface and the rogctl and asusctl for asus.

But again, outside of maintaining the images with the normal bluefin stuff, why does the burden of maintaining the kernels/supporting them lie on this project? The Asus and Surface communities have their own discords, githubs, and support articles. Asus Kernel even has an outdated silverblue guide, which still is mostly relevant: https://asus-linux.org/guides/fedora-silverblue-guide/

If people open tickets or issues related to the kernels, just pass them onto the respective communities for those communities to help debug/fix. ANd only support the UBlue/Bluefin/Bazzite specific stuff.

[Edit] Again, I will read up on how to make custom images, and I can at minimum try to make Asus images and try to maintain them. Most of it will be copy and paste from what you guys already did.

@castrojo
Copy link
Member Author

maintaining the images with the normal bluefin stuff, why does the burden of maintaining the kernels/supporting them lie on this project?

This is what we're discussing. It increases the amount of images we have to build and support and it's not something we're interested in doing considering the time that we have available. Similarly punting all of our issues to those projects isn't exactly something we're interested in either.

@daegalus
Copy link

ok, that is fair. I will see what I can do to make an Asus build going. Ill report back if I have any success.

@castrojo
Copy link
Member Author

Happy to help get them going if someone makes a repo, it'd be grabbing this: https://github.com/ublue-os/image-template

And then doing a dnf kernel swap, which is relatively new (you probably want to avoid the rpm-ostree replace stuff as it's on the way out).

@daegalus
Copy link

Happy to help get them going if someone makes a repo, it'd be grabbing this: https://github.com/ublue-os/image-template

And then doing a dnf kernel swap, which is relatively new (you probably want to avoid the rpm-ostree replace stuff as it's on the way out).

Do you have a link or reference to the dnf kernel swap method? I am only familiar with the rpm-ostree replace method

@tulilirockz
Copy link
Collaborator

Do you have a link or reference to the dnf kernel swap method? I am only familiar with the rpm-ostree replace method

It should be quite similar to what you would do on Fedora Workstation to install it, but on the containerfile:

FROM quay.io/fedora-ostree-desktops/silverblue:41

RUN dnf5 config-manager addrepo --from-repofile=https://pkg.surfacelinux.com/fedora/linux-surface.repo
RUN dnf5 -y remove kernel* && \
    rm -r /root # not necessary on ublue-os/main derived images
RUN dnf5 -y install --allowerasing kernel-surface iptsd libwacom-surface

This seems to build just fine, but I haven't tested it. You should be able to replace the base image with whatever one you want to use (Bazzite, Bluefin, Aurora [...])

@daegalus
Copy link

Do you have a link or reference to the dnf kernel swap method? I am only familiar with the rpm-ostree replace method

It should be quite similar to what you would do on Fedora Workstation to install it, but on the containerfile:

FROM quay.io/fedora-ostree-desktops/silverblue:41

RUN dnf5 config-manager addrepo --from-repofile=https://pkg.surfacelinux.com/fedora/linux-surface.repo
RUN dnf5 -y remove kernel* && \
    rm -r /root # not necessary on ublue-os/main derived images
RUN dnf5 -y install --allowerasing kernel-surface iptsd libwacom-surface

This seems to build just fine, but I haven't tested it. You should be able to replace the base image with whatever one you want to use (Bazzite, Bluefin, Aurora [...])

Awesome, thx. I'll probably get something up and running soon (like tomorrow soon).

@daegalus
Copy link

Ok, I have made some progress. I just started a build that I think might succeed. It is missing a few things that got removed was part of kernel removal, but then fail when trying to add them (v4l2loopback, kmods for controllers, etc).

But for now I think I can get a functioning image. I will be rebasing to it when I get it all working.

https://github.com/daegalus/redfin (I may or may not have to rename it, cause I don't want issue with Redfin the real estate company. Maybe Rosefin or Rockfin [since it sounds close to ROG], or something come up with something unique.)

@tulilirockz
Copy link
Collaborator

Ok, I have made some progress. I just started a build that I think might succeed. It is missing a few things that got removed was part of kernel removal, but then fail when trying to add them (v4l2loopback, kmods for controllers, etc).

But for now I think I can get a functioning image. I will be rebasing to it when I get it all working.

https://github.com/daegalus/redfin (I may or may not have to rename it, cause I don't want issue with Redfin the real estate company. Maybe Rosefin or Rockfin [since it sounds close to ROG], or something come up with something unique.)

You can remove the kernel packages w/o removing anything else by using this instead:

RUN for pkg in kernel kernel-core kernel-modules kernel-modules-core ; do rpm --erase $pkg --nodeps ; done

@daegalus
Copy link

Ok, I had some successful builds. I rebased onto the image and it wouldn't boot. Just nothing after selecting it in the menu.

Now I am thinking that I replaced the kernel, but do I need to rerun something with dracut? Or rebuild the initramfs? Because I don't think it's the Nvidia drivers. I just get a failed boot, no kernel messages.

@drf-jpg
Copy link

drf-jpg commented Dec 21, 2024

@tulilirockz I'm not sure that you're able to use DNF5 to update kernels at this time. From: https://fedoraproject.org/wiki/Changes/DNFAndBootcInImageModeFedora#Current_status.

DNF5 when installed on a image-based/ostree system can be used to install RPMs if the system is unlocked, it also works on most container builds, one major exception at the moment are kernel installations and kernel updates. DNF is not part of image variants at the moment, however CoreOS is exploring adding it via: coreos/fedora-coreos-tracker#1687

@tulilirockz
Copy link
Collaborator

tulilirockz commented Dec 21, 2024

@tulilirockz I'm not sure that you're able to use DNF5 to update kernels at this time. From: https://fedoraproject.org/wiki/Changes/DNFAndBootcInImageModeFedora#Current_status.

DNF5 when installed on a image-based/ostree system can be used to install RPMs if the system is unlocked, it also works on most container builds, one major exception at the moment are kernel installations and kernel updates. DNF is not part of image variants at the moment, however CoreOS is exploring adding it via: coreos/fedora-coreos-tracker#1687

Ive done it multiple times, you can do it, even if it is unsupported LOL. At build time it should be entirely fine

@daegalus
Copy link

Regardless, the swap works, but it never boots the kernel.

So something in the swap is causing it to not rebuild initramfs.

I tried running. dracut --regenerate-all -f and rpm-ostree initramfs --enable. Both through an error about ostree. Dracut just said it's an ostree

rpm-ostreee complains about not being booted by ostree.

Haven't figured out the issue.

@drf-jpg
Copy link

drf-jpg commented Dec 21, 2024

I've been trying to take advantage of this myself for #2066 in drf-jpg/bluefin-mainline#1 but I get a kernel panic immediately after boot. Seems to be a problem with the initramfs.

I put details in that PR about updating kernels, but I'm not having too great a time with it. Perhaps it will help you, though?

@thmichel
Copy link

Is there any chance we get the Surface kernel (or one that supports the Surface devices) back? My laptop is rather useless since the latest updates as they removed support for keyboard/mouse. Or any way to overlay the Surface kernel?

I really like ublue and would rather not move away from it. But without Surface support I seem to have no choice.

@EyeCantCU
Copy link
Member

@thmichel which Surface do you have? The latest kernel in HWE should work

@EyeCantCU
Copy link
Member

This is probably related if you have something more recent: linux-surface/linux-surface#1645

We carry all patches in the Linux Surface tree so I'd imagine it's broken there on 6.12 as well

@thmichel
Copy link

thmichel commented Jan 2, 2025

This is probably related if you have something more recent: linux-surface/linux-surface#1645

We carry all patches in the Linux Surface tree so I'd imagine it's broken there on 6.12 as well

I have a Surface Laptop Studio so probably not a "more recent" model. Checked dmesg and found the exact error mentioned in that link. So it's not a ublue issue at all but some problem with the upstream kernel. Thank you for pointing me to that thread!

@EyeCantCU
Copy link
Member

@thmichel would you mind giving the Bazzite Surface images we have up in testing a try?:

ghcr.io/ublue-os/bazzite-gnome-surface:testing

Pushed up a few changes over there that should help. Just keep in mind to rebase to stable after the image leaves testing

There are plans to drop HWE Bluefin images. You should be able to rebase from your Bluefin install. Alternatively, the latest install media works if you use Ventoy and boot in GRUB 2 mode (but don't forget to rebase the image after installation)

@thmichel
Copy link

thmichel commented Jan 3, 2025

@EyeCantCU : Rebased to the bazzite image with no luck - still no keyboard or touchpad. If you need any log files, just let me know.

@EyeCantCU
Copy link
Member

Rebased to the bazzite image with no luck - still no keyboard or touchpad. If you need any log files, just let me know.

A dmesg dump would be helpful. I have a Pro 7+ with the same image running right now and everything works so debugging on my end will be challenging otherwise

@thmichel
Copy link

thmichel commented Jan 6, 2025

Find the dmesg attached. dmesg.txt
Looking at the thread you mentioned above it seems multiple devices are affected.

@thmichel
Copy link

thmichel commented Jan 7, 2025

It seems in there is a solution (or workaround) for this here. Essentially it seems the surface aggregator module must be loaded after the pinctrl_tigerlake.
I verified this on my bazzite install by removing all surface modules, reloading the pinctrl_tigerlake module and reloading the surface modules. Once done, keyboard and touchpad started working again. So we should add the pinctrl_tigerlake module as a dependency for surface_aggregator module somehow. Issue is I don't have a clue how to do that :-)

Edit: I moved pinctrl_tigerlake to the top in the file /etc/modules-load.d/ublue-surface.conf, rebased to bluefin-hwe-nvidia:latest and got keyboard and mouse back.

@pixelthea
Copy link

pixelthea commented Jan 8, 2025

Regardless, the swap works, but it never boots the kernel.

So something in the swap is causing it to not rebuild initramfs.

I tried running. dracut --regenerate-all -f and rpm-ostree initramfs --enable. Both through an error about ostree. Dracut just said it's an ostree

rpm-ostreee complains about not being booted by ostree.

Haven't figured out the issue.

Any breakthroughs on this? I've also been having issues and it seems to lie with how the rpm post transaction scripts attempt to deploy the kernel. If you do it in a live system and check the journal, there's a number of failures because the fedora kernel-core rpm is not expecting to be thrown into a silverblue fork, I assume.

I'd like to know what the bazzite team did to integrate the linux-surface patches. If they're doing a swap too, they must be building the surface patched fedora kernel with modifications.

Edit: At a glance, it seems Bazzite definitely layers in the libwacom, camera, iptsd, etc packages in their containerfile, but they aren't using a patched kernel as far as I can tell.

I use a SP7+ with the bluefin-dx-hwe:gts which is based on the surface-kernel still and everything works wonderfully until I switch to latest and get the bazzite kernel. Then I still have all of the peripheral support, but a lot of internal hardware like the power_supply is missing. More than willing to maintain my own custom ublue image for it going forward though.

@daegalus
Copy link

daegalus commented Jan 8, 2025

Yes, I had to take a different approach. I had to pull the prebuilt akmods and kernels from the ublue caches and use those.

They had stuff for Asus and Surface still building.

Screenshot_20250108-204455.png

Ive had working builds for a bit now. They boot and everything.

But I stopped because I found that my laptop is fully supported with the official kernels now. There was just a bug/conflict with amd_pmf and legion_laptop kernel modules. Once I blacklisted them, everything worked. So I'm back to the official ublue images.

But my repo has a working kernel swap example and the method can be used for surface too, just need to adjust the cache images you pull.

Before that, I got the kernel booting, but I was missing modules like kvmfr and a few others that were expected for the dx images. I could have figured it out, but then I was offered s simpler source.

My build.sh has a functioning initramfs update. So it will work as long as you gather all the right modules for whatever build you are doing.

@EyeCantCU
Copy link
Member

Thanks for the investigation all! I've opened a PR to Bluefin here fixing load order: #2123

And I've done the same in the testing branch for Bazzite. Builds should land over there in a while. Would be great to get confirmation from you all on whether or not this addresses the problems you all have

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

No branches or pull requests

7 participants