-
Notifications
You must be signed in to change notification settings - Fork 118
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
Can not boot after xpadneo installed #425
Comments
How did you install xpadneo? What's the screen output when the system fails to boot? |
Just the grey screen you get when you load Pop! OS, where you expect the use selection menu to appear, but after 5 seconds more it goes into ubuntu busybox. There is no text displayed on the screen, just a terminal of busybox. This was after I installed by Debian instructions. I stopped following guide after install.sh, so I might have missed something. |
This sounds like it's dropping you into an emergency shell, and it may happen because it cannot load a driver or device during boot. Maybe it tries to load xpadneo during initramfs phase but DKMS didn't incorporate it into the ram disk image. This is probably a distribution bug then, xpadneo isn't needed at that phase of boot. Could you run dmesg in busybox to look for any obvious errors? Does the system continue to boot if you press Ctrl+D? I do not know Pop! OS but it should be possible to boot in verbose mode so you actually see text logs instead of a graphical boot screen. That may help, too. Also, if systemd is already active at that stage, the output of Do you use dual boot? A quick googling shows that there might be problems in dual boot setups when rebuilding initramfs. Try if running |
I tried your fixes, and none have worked. I will use live boot to try and get access, if not I will have to reinstall. I also dual boot with windows 11, I have no recovery partition either. Legit 1 month before having to probably reinstall again. |
I have reinstalled my os. |
I wonder if this would happen again if you installed xpadneo now, or if there was some other problem lurking around already. |
I'll create a VM and see |
I could imagine that rebuilding initramfs with DKMS somehow failed because of missing dependencies. If that's the problem, we should find which deps are needed and document these. |
@kakra Author of #436 here, I'm not sure if this will be usable considering some of the stuff scroll so fast but here are recordings of |
Okay, I'm not familiar with secure boot but it looks like Pop! OS doesn't properly sign kernel and modules when installing via DKMS. Usually, DKMS is expected to have distribution hooks to properly sign installed modules. Could you try disabling secure boot if it is enabled in the BIOS? Also, when generating the initramfs, you can run Your video says it dropped to busybox because it timed out waiting for the rootfs. But did it really wait? Usually, it may wait several minutes for the rootfs. But this looks like it wasn't able to load the SATA chipset modules and thus immediately finished waiting for any more devices - which can be explained by module signing missing for ALL modules and drivers. I wonder a few things here: Why does Pop! OS put drivers for late devices into the initramfs at all? All you need there is chipset, GPU and file systems. But yeah, probably input devices, too, and xpadneo belongs to those. But actually you'd only need standard keyboard drivers - and all those should be built into the kernel so they become loaded no matter what. Why does DKMS not properly sign modules, or the other way around: Why does initramfs accept/put unsigned modules into initramfs? I think Pop! OS misses some important hook somewhere. We do not provide instructions to manually run the initramfs generator. Is there some document which recommends this? I'd like to setup a VM to reproduce this here because this is one of the worst experiences you could get by installing a third party driver: It must never result in an unbootable system. Either it should bail out in the first place during installation, or should still boot but refuse to load just this single driver. |
I think module signing is out of the question because Secure Boot is disabled on my machine and Pop!_OS practically requires you to disable Secure Boot as the USB environment straight up won't boot.
Do you mean when regenerating the initramfs image? I actually tried that on a whim, thinking that it might fix the issue but no dice (maybe it was built incorrectly?). It did skip directly to the rootfs timeout but that may have been either because of the fact that I also thought about checking the filesystem on the off chance that a unlucky coincidence happened and the fs had problems not because of xpadneo. But running fsck from a live environment showed the rootfs was healthy.
I have an NVME drive, not really important but may alter some stuff down the line.
Most likely due to the fact that ya boy has Secure Boot disabled. About the missing hook, I did find it strange that |
If anything, this just shows that you should have a seperate |
I have the same issue, A fix would be very helpful. |
Are you guys able to create a small VM image where this happens? |
Sure, I will work on that later |
Pop Os 22.04 here, experiencing the same issue after running |
With some aid of chatgpt I could fix the normal boot entry. I did the following. # To find the xpadneo module.
dkms status
# Then, removed the module, replace `hid-xpadneo/v0.9-172-gfd0cd48` with what you had in `dkms status`
sudo dkms remove hid-xpadneo/v0.9-172-gfd0cd48 --all
# Removed the files
sudo rm -rf /usr/src/hid-xpadneo-v0.9-172-gfd0cd48
# Did this thing :P
sudo update-initramfs -u -k all After these steps, I rebooted but the normal entry was still broken so I booted into sudo apt update && sudo apt upgrade -y And the next restart I could log in into my system normally. |
Is this still an issue? We may have one related issue #431. But I still think an OS should handle problems gracefully during first boot after an update, so I tend to say the distributions should generally fix this. |
Yep. Not reporter, but can confirm. Still an issue. I just encountered similar to the above thread sequence. Pop OS 22.04 |
This adds a new top-level `Makefile` for easy installation via package managers. Instead of directly building the DKMS module, this allows a package installer to just provide the source code and install the support files. Building of the actual module via DKMS is left to the package maintainer. To aid following packaging guidelines, two variables are provided: - `PREFIX`: Allows to install the package to a pre-install image which can be put in an archive for package deployment and file tracking. If this variable is provided, it will also skip deployment of the DKMS source tree. This is mainly due to limitations of DKMS handling prefixed installations properly. Package maintainers have to do this manually in a post-installation step. - `ETC_PREFIX`: Allows to install files to `/usr/lib` which would normally go to `/etc`. This is applied relative to `PREFIX`. TL;DR: `dkms add` won't be run if `PREFIX` is provided. Please read `docs/PACKAGING.md`. Maybe-fixes: atar-axis#405 Maybe-fixes: atar-axis#425 Maybe-fixes: atar-axis#431 Maybe-fixes: atar-axis#491 Signed-off-by: Kai Krakow <[email protected]>
This adds a new top-level `Makefile` for easy installation via package managers. Instead of directly building the DKMS module, this allows a package installer to just provide the source code and install the support files. Building of the actual module via DKMS is left to the package maintainer. To aid following packaging guidelines, two variables are provided: - `PREFIX`: Allows to install the package to a pre-install image which can be put in an archive for package deployment and file tracking. If this variable is provided, it will also skip deployment of the DKMS source tree. This is mainly due to limitations of DKMS handling prefixed installations properly. Package maintainers have to do this manually in a post-installation step. - `ETC_PREFIX`: Allows to install files to `/usr/lib` which would normally go to `/etc`. This is applied relative to `PREFIX`. TL;DR: `dkms add` won't be run if `PREFIX` is provided. Please read `docs/PACKAGING.md`. Maybe-fixes: atar-axis#405 Maybe-fixes: atar-axis#425 Maybe-fixes: atar-axis#431 Maybe-fixes: atar-axis#491 Signed-off-by: Kai Krakow <[email protected]>
This adds a new top-level `Makefile` for easy installation via package managers. Instead of directly building the DKMS module, this allows a package installer to just provide the source code and install the support files. Building of the actual module via DKMS is left to the package maintainer. To aid following packaging guidelines, two variables are provided: - `PREFIX`: Allows to install the package to a pre-install image which can be put in an archive for package deployment and file tracking. If this variable is provided, it will also skip deployment of the DKMS source tree. This is mainly due to limitations of DKMS handling prefixed installations properly. Package maintainers have to do this manually in a post-installation step. - `ETC_PREFIX`: Allows to install files to `/usr/lib` which would normally go to `/etc`. This is applied relative to `PREFIX`. TL;DR: `dkms add` won't be run if `PREFIX` is provided. Please read `docs/PACKAGING.md`. Maybe-fixes: atar-axis#405 Maybe-fixes: atar-axis#425 Maybe-fixes: atar-axis#431 Maybe-fixes: atar-axis#491 Signed-off-by: Kai Krakow <[email protected]>
Please test #517 |
This adds a new top-level `Makefile` for easy installation via package managers. Instead of directly building the DKMS module, this allows a package installer to just provide the source code and install the support files. Building of the actual module via DKMS is left to the package maintainer. To aid following packaging guidelines, two variables are provided: - `PREFIX`: Allows to install the package to a pre-install image which can be put in an archive for package deployment and file tracking. If this variable is provided, it will also skip deployment of the DKMS source tree. This is mainly due to limitations of DKMS handling prefixed installations properly. Package maintainers have to do this manually in a post-installation step. - `ETC_PREFIX`: Allows to install files to `/usr/lib` which would normally go to `/etc`. This is applied relative to `PREFIX`. TL;DR: `dkms add` won't be run if `PREFIX` is provided. Please read `docs/PACKAGING.md`. Maybe-fixes: atar-axis#405 Maybe-fixes: atar-axis#425 Maybe-fixes: atar-axis#431 Maybe-fixes: atar-axis#491 Signed-off-by: Kai Krakow <[email protected]>
This adds a new top-level `Makefile` for easy installation via package managers. Instead of directly building the DKMS module, this allows a package installer to just provide the source code and install the support files. Building of the actual module via DKMS is left to the package maintainer. To aid following packaging guidelines, two variables are provided: - `PREFIX`: Allows to install the package to a pre-install image which can be put in an archive for package deployment and file tracking. If this variable is provided, it will also skip deployment of the DKMS source tree. This is mainly due to limitations of DKMS handling prefixed installations properly. Package maintainers have to do this manually in a post-installation step. - `ETC_PREFIX`: Allows to install files to `/usr/lib` which would normally go to `/etc`. This is applied relative to `PREFIX`. TL;DR: `dkms add` won't be run if `PREFIX` is provided. Please read `docs/PACKAGING.md`. Maybe-fixes: atar-axis#405 Maybe-fixes: atar-axis#425 Maybe-fixes: atar-axis#431 Maybe-fixes: atar-axis#491 Signed-off-by: Kai Krakow <[email protected]>
This adds a new top-level `Makefile` for easy installation via package managers. Instead of directly building the DKMS module, this allows a package installer to just provide the source code and install the support files. Building of the actual module via DKMS is left to the package maintainer. To aid following packaging guidelines, two variables are provided: - `PREFIX`: Allows to install the package to a pre-install image which can be put in an archive for package deployment and file tracking. If this variable is provided, it will also skip deployment of the DKMS source tree. This is mainly due to limitations of DKMS handling prefixed installations properly. Package maintainers have to do this manually in a post-installation step. - `ETC_PREFIX`: Allows to install files to `/usr/lib` which would normally go to `/etc`. This is applied relative to `PREFIX`. TL;DR: `dkms add` won't be run if `PREFIX` is provided. Please read `docs/PACKAGING.md`. Maybe-fixes: atar-axis#405 Maybe-fixes: atar-axis#425 Maybe-fixes: atar-axis#431 Maybe-fixes: atar-axis#491 Signed-off-by: Kai Krakow <[email protected]>
This adds a new top-level `Makefile` for easy installation via package managers. Instead of directly building the DKMS module, this allows a package installer to just provide the source code and install the support files. Building of the actual module via DKMS is left to the package maintainer. To aid following packaging guidelines, two variables are provided: - `PREFIX`: Allows to install the package to a pre-install image which can be put in an archive for package deployment and file tracking. If this variable is provided, it will also skip deployment of the DKMS source tree. This is mainly due to limitations of DKMS handling prefixed installations properly. Package maintainers have to do this manually in a post-installation step. - `ETC_PREFIX`: Allows to install files to `/usr/lib` which would normally go to `/etc`. This is applied relative to `PREFIX`. TL;DR: `dkms add` won't be run if `PREFIX` is provided. Please read `docs/PACKAGING.md`. Maybe-fixes: atar-axis#405 Maybe-fixes: atar-axis#425 Maybe-fixes: atar-axis#431 Maybe-fixes: atar-axis#491 Signed-off-by: Kai Krakow <[email protected]>
This happened to me after the fix, i.e. I cloned the commit 8d20a23, after b418e9f. PopOS 22.04 LTS. |
Okay, so I could test with a PopOS 22.04 LTS image in a VM then. |
Version of xpadneo
0.9.5
Controller Model
Connection mode
Installed Software
Protocol Information
Please help us identify at which layer the problem can be found if you want
to report mapping errors or if the controller fails to be detected:
evtest
is showing issues (describe the issues below)BTN_NORTH
andBTN_WEST
are intentionally swappedjstest
is showing issues (describe the issues below)gamepad-tool
is showing issues (post console output below)Please describe how it is failing below in the next sections.
Severity / Impact
Describe the Bug
After installing, could connect, but after reboot I boot into busybox
Steps to Reproduce
Expected Behavior
A busybox terminal
Screenshots / GIFs / Videos
System Information
Pop! Os 23.04
# xxd -c20 -g1 /sys/module/hid_xpadneo/drivers/hid:xpadneo/0005:045E:*/report_descriptor | tee >(cksum)
Controller and Bluetooth Information
Additional Context
The text was updated successfully, but these errors were encountered: