Bug 2321249 - Anaconda over VNC doesn't accept any input (bare metal with native video driver only)
Summary: Anaconda over VNC doesn't accept any input (bare metal with native video driv...
Keywords:
Status: CLOSED ERRATA
Alias: None
Product: Fedora
Classification: Fedora
Component: tigervnc
Version: 41
Hardware: Unspecified
OS: Linux
unspecified
high
Target Milestone: ---
Assignee: Jan Grulich
QA Contact: Fedora Extras Quality Assurance
URL:
Whiteboard: AcceptedBlocker
Depends On:
Blocks: F41FinalBlocker
TreeView+ depends on / blocked
 
Reported: 2024-10-23 09:29 UTC by Peter Boy
Modified: 2024-10-24 22:22 UTC (History)
11 users (show)

Fixed In Version:
Clone Of:
Environment:
Last Closed: 2024-10-24 22:22:37 UTC
Type: ---
Embargoed:


Attachments (Terms of Use)
Main screen (195.55 KB, image/png)
2024-10-23 10:13 UTC, Lukas Ruzicka
no flags Details
Installation (118.06 KB, image/png)
2024-10-23 10:14 UTC, Lukas Ruzicka
no flags Details
Journalctl logs from one of the affected machines (1.54 MB, text/plain)
2024-10-23 15:48 UTC, Lukas Ruzicka
no flags Details
anaconda.log (37.42 KB, text/plain)
2024-10-23 15:49 UTC, Kamil Páral
no flags Details
dbus.log (3.69 KB, text/plain)
2024-10-23 15:49 UTC, Kamil Páral
no flags Details
journal.txt (917.15 KB, text/plain)
2024-10-23 15:49 UTC, Kamil Páral
no flags Details
program.log (1.49 KB, text/plain)
2024-10-23 15:49 UTC, Kamil Páral
no flags Details
storage.log (103.94 KB, text/plain)
2024-10-23 15:49 UTC, Kamil Páral
no flags Details
syslog (747.95 KB, text/plain)
2024-10-23 15:49 UTC, Kamil Páral
no flags Details
vncserver.log (2.71 KB, text/plain)
2024-10-23 15:49 UTC, Kamil Páral
no flags Details


Links
System ID Private Priority Status Summary Last Updated
Github TigerVNC tigervnc issues 1857 0 None open Input does not work in Fedora VNC installer environment with accelerated video with tigervnc 1.14.0+ 2024-10-24 07:51:41 UTC

Description Peter Boy 2024-10-23 09:29:53 UTC
If you boot Fedora Server Edition with OEMDRV mode Anaconda does start the VNC Server, a client can connect and the Welcome screen shows up. But Anaconda then doesn't accept any keyboard input. So you can't perform an installation, the system  “hangs” and does not respond in any way. You can't even cancel the installation or reboot.

Reproducible: Always

Steps to Reproduce:
1. Prepare an OEMDRV USB stick according to Anaconda docs and boot the system.
2. After a while, Anaconda will display the VNC Info screen with the current IP number.
3. Connect to the server from your client, it desplays the well-known Welcome screen. 
4. Try to use keyboard of mouse to select a topic.The system doesn't reweact.
Actual Results:  
The VMC client is blocked, no keyboard or mouse input possible.

Expected Results:  
You should be able to select topics and adjust the installtion

The server shows 2 messages when a client tries to connecet:


anaconda 2588 GTK-WARNING (date time)   ../gtk../gtklist/store.c:v836 
         Unablle to connect from (hostname) to gckarray

  
anaconda 2588 GTK-WARNING (date time)... ../gtk/gtkwidget.c:6780 no accelerator (65470,0) installed in accelgroup for Anaconda-standaloneWindow

Comment 1 Fedora Blocker Bugs Application 2024-10-23 10:11:36 UTC
Proposed as a Blocker for 41-final by Fedora user pboy using the blocker tracking app because:

 A supported installation method fails (installer must run)

Comment 2 Lukas Ruzicka 2024-10-23 10:12:01 UTC
I have tried this using the VM setup, where I would install into a VM and would establish a VNC connection from the VM's host. I could not reproduce this bug. Anaconda was responsive over the VNC, just when I hit "Continue" on the welcome screen, I had to wait for about 20 seconds in which the system looked unresponsive, indeed, but then it went to the next screen and I could complete the installation successfully.

See the screenshot from the installation.

Comment 3 Lukas Ruzicka 2024-10-23 10:13:34 UTC
Created attachment 2053250 [details]
Main screen

Comment 4 Lukas Ruzicka 2024-10-23 10:14:07 UTC
Created attachment 2053251 [details]
Installation

Comment 5 Peter Boy 2024-10-23 10:29:47 UTC
You are on the wrong test! This one is about USB  = hardware, not VM. It may work in a VM, but it doesn't on hardware. I tested on two different devices. And, sorry, I'm not that dumb not to wait for a longer time. 

Please, repeat your test with hardware. And if you succeed, then let's explore the differences and identify probable conditions that trigger the failure.

Comment 6 Lukas Ruzicka 2024-10-23 13:56:04 UTC
(In reply to Peter Boy from comment #5)
> You are on the wrong test! This one is about USB  = hardware, not VM. It may
> work in a VM, but it doesn't on hardware. I tested on two different devices.
> And, sorry, I'm not that dumb not to wait for a longer time. 
> 
> Please, repeat your test with hardware. And if you succeed, then let's
> explore the differences and identify probable conditions that trigger the
> failure.

No need to be upset, Peter! And I do not think that this could not be tested on a virtual machine because from what you have been reporting, at least I understand it when reading your report, the issue is not that you cannot install from the USB stick, but that you cannot install over the VNC and I do not recall what difference it is when the VNC server runs in a virtual machine.

Also, I have tested both Server DVD and Server netinst from a USB stick on a real hardware today and did not have a single problem with it. I am not sure what OEMDRV mode is, so that might be the difference. What I did was to download the ISO image, burn it onto a USB stick, put it into the computer, restart, boot from it, install the system, check it boots.

Comment 7 Lukas Ruzicka 2024-10-23 15:15:00 UTC
Ok, so I found some real network devices and tried to do it the hardware way and indeed, the connection happens but it does not react to a mouse or a keyboard in like 5 cases out of 6. Once, I spotted a blinking cursor and I was able to select a language, but then it stopped responding to keys again. I could not install in any of the cases, not in TigerVNC nor Connections, so there is something weird about it. I am trying to fiddle with various connection options to see if that has any effect, but I have not been successful yet.

Comment 8 Kamil Páral 2024-10-23 15:41:58 UTC
I can confirm this problem with F41 RC 1.3 Server. In a VM, everything works fine, but when I run it on bare metal (no OEMDRV mode necessary, just following our test case [1]), it really accepts no input. I'll try to grab some logs.

[1] https://fedoraproject.org/wiki/QA:Testcase_Anaconda_User_Interface_VNC

Comment 9 Lukas Ruzicka 2024-10-23 15:48:45 UTC
Created attachment 2053300 [details]
Journalctl logs from one of the affected machines

Comment 10 Kamil Páral 2024-10-23 15:49:09 UTC
Created attachment 2053301 [details]
anaconda.log

Comment 11 Kamil Páral 2024-10-23 15:49:13 UTC
Created attachment 2053302 [details]
dbus.log

Comment 12 Kamil Páral 2024-10-23 15:49:16 UTC
Created attachment 2053303 [details]
journal.txt

Comment 13 Kamil Páral 2024-10-23 15:49:19 UTC
Created attachment 2053304 [details]
program.log

Comment 14 Kamil Páral 2024-10-23 15:49:22 UTC
Created attachment 2053305 [details]
storage.log

Comment 15 Kamil Páral 2024-10-23 15:49:26 UTC
Created attachment 2053306 [details]
syslog

Comment 16 Kamil Páral 2024-10-23 15:49:29 UTC
Created attachment 2053307 [details]
vncserver.log

Comment 17 Adam Williamson 2024-10-23 16:21:33 UTC
This may well be a tigervnc issue rather than an anaconda one, as I think all anaconda really does is start up tigervnc...maybe we can try just running a tigervnc server outside of the anaconda env and see if it hits the same issue?

Comment 18 Kamil Páral 2024-10-23 16:36:18 UTC
It's also a good idea to try booting anaconda with nomodeset. That might be the reason why vnc works in VMs.

Comment 19 Adam Williamson 2024-10-23 17:00:51 UTC
oh hey, that looks promising. I tried here once without nomodeset and hit the bug. tried once with nomodeset and it works. Will test both ways a few more times.

Comment 20 Adam Williamson 2024-10-23 17:18:52 UTC
5 tries with nomodeset inst.vnc , 5 passes (that is, I can click around happily on several panes for 30 seconds, I didn't run a full install)
3 tries with just inst.vnc , 3 fails

that seems pretty conclusive: this relates to the driver stack on the host. The host I'm testing on has an AMD adapter.

Comment 21 Adam Williamson 2024-10-23 18:02:04 UTC
Hmm. OTOH, I managed to get a tigervnc-server instance running on the same box with an installed Fedora 41 LXQt system, and I can interact with that no problem without needing nomodeset.

I installed tigervnc-server , followed the instructions in /usr/share/doc/tigervnc/HOWTO.md - edited /etc/tigervnc/vncserver.users and /etc/tigervnc/vncserver-config-defaults , set a VNC password for a user account - then booted to runlevel 3 and did systemctl start vncserver@:1 , connected in from the remote system, and it worked fine. I can click on stuff no problem.

I wonder if this is a gnome-kiosk/mutter/gtk + tigervnc issue? I will set up an installed system with GNOME and test that next (for the above test I just used the installed system I actually have on that box for regular use, which is LXQt).

Comment 22 Adam Williamson 2024-10-23 18:43:46 UTC
ugh, so, sad news:

1. This is new in F41. F40 works fine.
2. It doesn't reproduce on an installed F41 Workstation system. I enabled tigervnc much as in comment 21 - also had to install gnome-session-xsession, and set the session in vncserver-config-defaults to 'gnome-xorg' - and started it. Remoted in, and it works fine, I can control the desktop no problem. I can also run GTK 3 apps fine (tested that since anaconda is a GTK 3 app).

Comment 23 Kamil Páral 2024-10-23 20:11:20 UTC
(In reply to Adam Williamson from comment #20)
> that seems pretty conclusive: this relates to the driver stack on the host.
> The host I'm testing on has an AMD adapter.

I tested on an AMD GPU host, but Lukas tested on two systems, one with AMD GPU and one with Intel GPU. So this looks like a universal problem, not related to a single driver.

It's great that we have a workaround (using nomodeset), a slight disadvantage is that this approach also sets (at least it should set) nomodeset for the installed system, which means you have to remove it, if you don't specifically want it there.

Comment 24 Peter Boy 2024-10-23 20:25:42 UTC
> a slight disadvantage is that this approach also sets (at least it should set) nomodeset for the installed system, 

I'm not that familiar with the technical details, but is that parameter that important for Server? We have no GUI, just plain CLI (and mostly access the machine via ssh). Wouldn't we fine with just the BIOS drivers? But maybe, I miss something.

Comment 25 Adam Williamson 2024-10-23 20:35:32 UTC
It wouldn't matter for a typical server install, but there's no rule that says you can only install Server with VNC.

Still, it does seem fairly unusual to do a VNC install on a system you later intend to use local graphics on, I guess...why not just run the install locally in that case? Maybe I'm missing a justification somewhere though.

Comment 26 Scott Williams 2024-10-23 21:53:55 UTC
I've come across that scenario before.  In some shops, the ops team does the install and provision and then hands it off to another group of users, so the ops team might do VNC remotely using some BMC manager.  I have no idea how common a use case this is, but it's something I've seen done before.

Comment 27 Peter Boy 2024-10-23 21:59:32 UTC
> it does seem fairly unusual to do a VNC install on a system you later intend to use local graphics on

I once developed a routine to mass-reinstall Windows, OS/2 and Linux machines in teaching labs and other classes to ensure clean installations for new classes. But all Fedora desktops have live CDs as only installation method, so they are not capable of it. The only remote installable distributables are Server and Everything. So it is not a problem in Fedora reality.

Comment 28 Adam Williamson 2024-10-23 22:05:09 UTC
Peter: you can certainly deploy a desktop from the Everything netinst. Or the Server netinst, for that matter. I do it quite often.

Anyhoo, some more triage:

Fedora 41 Beta - BAD
Fedora 40 current build (from the latest F40 update tested in openQA) - BAD

so, this is caused by something that's been updated in F40. I'm starting to suspect tigervnc itself, which got a bump from 1.13 to 1.14 between Fedora 40's release and now. F40 on release day had tigervnc-1.13.1-12.fc40; currently it has tigervnc-1.14.0-4.fc40 . Notably, 1.14.1 packages were built today. I'll try building some images with newer and older tigervnc and see what happens.

Comment 29 Adam Williamson 2024-10-24 01:43:02 UTC
OK, so with a bit more testing, looks like it's definitely tigervnc 1.14.0 that caused this. I built two F40 images locally, one with all updated packages, one with all updated packages plus a build of tigervnc-1.13.1-14.fc40 with epoch bumped to 1. The all updated packages image shows the bug. The image with tigervnc downgraded to 1.13.1 works.

I couldn't do the same test with F41 easily because a big patch needs rebasing to build 1.13.1 for F41, but the test seems pretty strong proof. Unfortunately the required patch rebase makes a quick official downgrade of this tricky. I'll see if I can work on it tonight but I also need to pack for a trip...

We could bisect the bug between 1.13.1 and 1.14.0 but it's tiresome doing it with scratch installer image builds, it'd be great if someone could find a way to reproduce it outside of the installer.

Comment 30 Adam Williamson 2024-10-24 07:51:42 UTC
Reported upstream as https://github.com/TigerVNC/tigervnc/issues/1857 .

Comment 31 Fedora Update System 2024-10-24 11:47:42 UTC
FEDORA-2024-69a60846ec (anaconda-41.35-2.fc41) has been submitted as an update to Fedora 41.
https://bodhi.fedoraproject.org/updates/FEDORA-2024-69a60846ec

Comment 32 František Zatloukal 2024-10-24 21:17:44 UTC
Discussed during the 2024-10-24 Go/No-Go blocker review meeting: [1]

The decision to classify this bug as a AcceptedBlocker (Final) was made:

"VNC installations are required to work as per https://fedoraproject.org/wiki/QA:Testcase_Anaconda_User_Interface_VNC criterion. While we do have workaround for the issue by disabling the mode-setting, it's not enough to take the criterion as fulfilled."

[1] https://meetbot.fedoraproject.org/meeting_matrix_fedoraproject-org/2024-10-24/f41-final-go-no-go-meeting.2024-10-24-17.02.log.html

Comment 33 Fedora Update System 2024-10-24 22:16:52 UTC
FEDORA-2024-69a60846ec has been pushed to the Fedora 41 testing repository.
Soon you'll be able to install the update with the following command:
`sudo dnf upgrade --enablerepo=updates-testing --refresh --advisory=FEDORA-2024-69a60846ec`
You can provide feedback for this update here: https://bodhi.fedoraproject.org/updates/FEDORA-2024-69a60846ec

See also https://fedoraproject.org/wiki/QA:Updates_Testing for more information on how to test updates.

Comment 34 Fedora Update System 2024-10-24 22:22:37 UTC
FEDORA-2024-69a60846ec (anaconda-41.35-2.fc41) has been pushed to the Fedora 41 stable repository.
If problem still persists, please make note of it in this bug report.


Note You need to log in before you can comment on or make changes to this bug.