-
-
Notifications
You must be signed in to change notification settings - Fork 1.4k
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
Automatic Resize Display not working #4064
Comments
I'm having the same problem and found some additional information that may be useful for debugging. Guest OS has spice-vdagent & spice-vdagentd running, but when resizing the UTM window the spice-vdagentd log shows the following:
I quickly checked the spice-vdagentd source code, and this message is logged in spice-vdagentd.c on line 212 when the service receives a monitor configuration message with an unexpected message body size:
It seems as if the side that sends the monitor config message (UTM/QEMU) and the side that receives it (the spice-vdagentd inside the VM) are using a different protocol, possibly some mismatch in the SPICE version used to build UTM and the one in the VM? The spice-vdagent in Arch is version 0.22.1 released three months ago. I did try to find some clues in the UTM source code but it seems this code that sends this message is somewhere in a QEMU or SPICE dependency, and building all that myself seems complicated. UTM Version 3.2.4 (58) |
I would like to try to debug this myself, as auto-resizizing the desktop environment running inside the VM so I can set it fullscreen is an important feature for me. I've checked out the UTM code + the sys root and I can build and run the UTM GUI, but I need some help running a VM from Xcode with a debugger enabled. Right now when I try to start a VM I just get a 'Failed to connect to SPICE' and that's it. Are there any instructions available somewhere to explain how to work on the code, starting the GUI from Xcode with a debugger attached, any configuration required to be able to start a VM while running in the debugger, etc? |
@w0utert Are you sure the latest spice drivers for your OS doesn't resolve this? I had this issue but probably 3-4 months ago I updated spice tools in my windows VM and this issue was resolved. |
@pfremm i have running two systems with UTM.
With Debian the automatic resize from the Display is working fine. But with Kali not |
I'm using 0.22.1, which appears to be the latest version. My experience exactly matches @Drake0815: the auto-resizing did work with an earlier UTM version (Arch Gnome desktop) but not with the latest (different VM, also Arch but now with i3). It really looks as if in the latest release, a mismatch was introduced in the SPICE protocol versions on both sides (host and guest). In the mean time, I've configured i3 keybindings to resize the desktop manually using xrandr, which works. So there is no problem with the X session or the WM itself, just with the spice-vdagent that doesn't understand the monitor config messages it receives. |
Just adding my $.02 that, while I didn't have it working prior, auto resize is not working for me either. I have an Ubuntu 22.04 guest with KDE and spice-vdagent running per x-session and spice-vdagentd running, but no resizing is happening. Clipboard works, but no resize. Current spice-vdagent version is 0.22.1-1 as gotten from Ubuntu repo. |
Same issue here with Ubuntu 22.04 LTS guest. Any workaround? |
Same issue here with Ubuntu 20.04 LTS guest on MacOS. |
Same issue here with macOS host and EndeavourOS guest (Kernel |
I found a workaround for windows at least. Enable retina mode in the UTM vm display settings. Then in windows set the dpi to 175% |
Partial fix/workaround but need to add @reboot + command to crontab -e to run every time VM reboots or run command manually each time. Otherwise make and alias in bashrc or add something to startup.sh You may also need to change window scaling depending on what you're running. May need some finessing to get it the way you want it. Source: https://docs.getutm.app/guest-support/dynamic-resolution/ Resolution is not changing on Linux: There is a known bug on some distributions that prevents dynamic resolution from working. The following command will force the window manager to update the resolution: $ xrandr --output Virtual-1 --auto |
I found the xrandr command above to work on Debian ARM with XFCE, but not consistently. For Arch ARM with KDE (Plasma), xrandr command was not required. However, in order for SPICE clipboard and display resize to work in KDE, I needed to edit the spice-vdagent XDG autostart file (comment out the X-GNOME line): systemd/systemd#18791 |
Hit the same issue after upgrading Debian 11 to testing (spice-vdagent version is upgraded to 0.22) |
The xrandr workaround is working for me (Macbook Pro M1, Manjaro, KDE 5.27, UTM 4.2.5) Also, I had to execute it only once and the effect persisted between VM restarts without any cron or startup script. I had to comment out the X-GNOME line from the desktop file of the Spice agent to make it work at all (but that is a general issue, not related to resizing) |
For Ubuntu install spice-vdagent:
The first one is a daemon which should be started autmatically.
|
I've done a workaround which may help people: https://gist.github.com/whi-tw/30878179fffd9b994cc978beb894bd9b
#!/usr/bin/env bash
journalctl -fu spice-vdagentd -g 'invalid message size for VDAgentMonitorsConfig' -n0 |\
while read line; do
echo "window changed, resizing"
xrandr --output Virtual-1 --auto
done
[Unit]
Description=Watch for SPICE errors and resize display
[Service]
Type=simple
Restart=always
RestartSec=1
Environment=DISPLAY=:0
ExecStart=/opt/utm-resolution-fix/watch-and-fix.sh
[Install]
WantedBy=default.target Yep, it's super grubby, but is barely using any resources, starts on boot and automatically does the resizing when necessary |
Thanks. |
Agreed, although I'm facing this problem on Parrot, so it may be a 'not our problem' response |
While using
On M2 Max
the observations about autoscaling for vanilla installations are
|
Same problem hope a fix it drive me crazy |
Debian 12 arm has the same issues on M1 Max on OS Sonoma |
Fedora 38 arm do not have the issue (if it can help to track down the culprit) |
@rsmogura did you ever find anything on launchpad? |
I’m not sure this really is an Ubuntu problem and not an UTM problem, I’ve been using QEMU for virtualizing Ubuntu 22.04 before on a Linux host, and never experienced this kind of resizing problem when using for example the virt-manager graphics console or VNC to connect to the VM. And as mentioned before, I had the same problem on Arch i3, but only after upgrading UTM (this was long ago, around the date this ticket was filed) |
I don't know if virt-manager uses SPICE but VNC definitely isn't SPICE so idk if it's comparable. I haven't tried Wayland but it sounds like there's some compatibility issues with spice-vdagent |
I mean the graphics console built into virt-manager which can be configured to use either SPICE or VNC. I think the way it works is when you configure it as VNC is that QEMU just grabs the framebuffer from the virtualized video driver and runs a VNC server on the host that the graphics console then uses. You don’t need to run any server inside the guest itself for this to work, it even works for a DOS VM for example. For a Linux desktop guest, when you resize the graphics console window virt-manager communicates with the spice-vdagent in the guest to tell it to resize the desktop, so same idea as UTM. I’m not an expert though so maybe I’m misunderstanding. Anyway, it was not working as expected on Arch i3 either, while it used to work for the same VM before the UTM update |
In my VM this script will run xrandr multiple times each time if I ever restart the service. I think has something to do with how grep option (-g) of journalctl works. I tweaked it a little bit by using actual grep command so it will work regardless of restarts: #!/usr/bin/env bash
journalctl -fu spice-vdagentd -n0 | grep --line-buffered "invalid message size for VDAgentMonitorsConfig" |\
while read line; do
echo "window changed, resizing"
xrandr --output Virtual-1 --auto
# Set display scale to 2.0
# /usr/bin/python3 /opt/utm-resolution-fix/set-scale.py
done But actually, on my machine, the auto-resizing works fine in terms of resolution, but the scale setting will not persist during the resize - ubuntu will always default to 1x scale on a lower resolution. I modified the code from this answer on askubuntu (https://askubuntu.com/a/1267328) to create a script to set the scale automatically upon resizing. Uncomment the line /opt/utm-resolution-fix/set-scale.py#!/usr/bin/python3
# Note: use system python3, not /usr/bin/env, because whichever python3 is on
# $PATH may not have dbus, but the system python3 does.
"""Toggle display scaling between 100% and 200%.
Based on https://gist.github.com/strycore/ca11203fd63cafcac76d4b04235d8759
For data structure definitions, see
https://gitlab.gnome.org/GNOME/mutter/blob/master/src/org.gnome.Mutter.DisplayConfig.xml
"""
import dbus
namespace = "org.gnome.Mutter.DisplayConfig"
dbus_path = "/org/gnome/Mutter/DisplayConfig"
session_bus = dbus.SessionBus()
obj = session_bus.get_object(namespace, dbus_path)
interface = dbus.Interface(obj, dbus_interface=namespace)
current_state = interface.GetCurrentState()
serial = current_state[0]
connected_monitors = current_state[1]
logical_monitors = current_state[2]
# Multiple monitors are more complicated. For now, since I only use one monitor
# in Ubuntu, everything is hard-coded so that only info about the first monitor
# is used, and only it will be connected after running the script.
#
# If someday updating this script: a logical monitor may appear on mutiple
# connected monitors due to mirroring.
connector = connected_monitors[0][0][0]
current_mode = None
# ApplyMonitorsConfig() needs (connector name, mode ID) for each connected
# monitor of a logical monitor, but GetCurrentState() only returns the
# connector name for each connected monitor of a logical monitor. So iterate
# through the globally connected monitors to find the mode ID.
for mode in connected_monitors[0][1]:
if mode[6].get("is-current", False):
current_mode = mode[0]
updated_connected_monitors = [[connector, current_mode, {}]]
x, y, scale, transform, primary, monitors, props = logical_monitors[0]
if scale == 2.0: exit()
scale = 2.0
monitor_config = [[x, y, scale, transform, primary, updated_connected_monitors]]
# Change the 1 to a 2 if you want a "Revert Settings / Keep Changes" dialog
interface.ApplyMonitorsConfig(serial, 1, monitor_config, {})
print('Set scale to 2.0') |
Hi, just adding a more elegant way of making dynamic resolution. YOU MUST have installed : sudo apt install spice-vdagent
sudo systemctl start spice-vdagent
sudo systemctl enable spice-vdagent Here is my config files for the udev rule : sudo cat /etc/udev/rules.d/10-resize.rules
ACTION=="change",KERNEL=="card0", SUBSYSTEM=="drm", RUN+="/usr/local/bin/resize" Now the script it trigger : sudo cat /usr/local/bin/resize
#! /bin/sh
PATH=/usr/bin
desktopuser=$(/bin/ps -ef | /bin/grep -oP '^\w+ (?=.*vdagent( |$))') || exit 0
export DISPLAY=:0
export XAUTHORITY=$(eval echo "~$desktopuser")/.Xauthority
xrandr --output "$(xrandr | awk '{if($0 ~/ connected/){print $1}}')" --auto
The script take account of the possibility that the monitor is not named I can confirm that's not an issue from UTM because i apply similar workaround for almost every Kali install i do. And it is also a bug that have been signaled for years without any real fix. |
Personally on fedora simply update do the trick since they updated the package who introduced to problem but thanks. |
This worked perfectly for me. |
No luck for me - Kali 2024.3 ARM on Apple M4 |
RE my previous comment, I started from scratch with installing Kali and chose KDE as the desktop environment (and unchecked XFCE.) I installed spice-vdagent and resizing works completely fine out of the box (xrandr workaround not needed.) This leads me to believe this is more of an XFCE (or perhaps a XORG vs. Wayland) issue than anything to do with UTM or even Kali. |
I have Upgrade my UTM Version from 3.1.5 to 3.2.4
Since the Upgrade I have the Problem that the automatically reside from the Display not working.
Spice Toll is installed
UTM Version 3.2.4
OS Version 12.3.1
Apple MacBook 14" M1 Pro
The text was updated successfully, but these errors were encountered: