patches and low-level development discussion
 help / color / mirror / code / Atom feed
From: Demi Marie Obenour <demiobenour@gmail.com>
To: Alyssa Ross <hi@alyssa.is>,
	Spectrum OS Development <devel@spectrum-os.org>
Subject: Re: "make run-qemu" gets Wayland protocol error
Date: Sun, 20 Jul 2025 04:22:48 -0400	[thread overview]
Message-ID: <ff77f1ab-4c8a-4f97-a748-f2ae497a5f2a@gmail.com> (raw)
In-Reply-To: <87a54zjms4.fsf@alyssa.is>


[-- Attachment #1.1.1: Type: text/plain, Size: 2891 bytes --]

On 7/20/25 04:20, Alyssa Ross wrote:
> Alyssa Ross <hi@alyssa.is> writes:
> 
>> Demi Marie Obenour <demiobenour@gmail.com> writes:
>>
>>> On 7/20/25 03:55, Alyssa Ross wrote:
>>>> Demi Marie Obenour <demiobenour@gmail.com> writes:
>>>>
>>>>> If I run `make run-qemu` under a Wayland compositor (tested with both
>>>>> Sway and Weston), I get a Wayland protocol error ("invalid object 0")
>>>>> and QEMU exits.  It appears that there is a problem with
>>>>> wayland-proxy-virtwl.  I get the following error from foot:
>>>>>
>>>>> warn: main.c:437: 'C' is not a UTF-8 locale, falling back to 'C.UTF-8'
>>>>> warn: config.c:3520: no configuration found, using defaults
>>>>> Fontconfig warning: no <cachedir> elements found. Check configuration.
>>>>> Fontconfig warning: adding <cachedir>/var/cache/fontconfig</cachedir>
>>>>> Fontconfig warning: adding <cachedir prefix="xdg">fontconfig</cachedir>
>>>>>  err: wayland.c:1714: no compositor
>>>>>  err: wayland.c:2248: failed to flush wayland socket: Connection reset by peer
>>>>>
>>>>> And the following from wayland-proxy-virtwl:
>>>>>
>>>>> 2025-07-20 02:14:48.638    wl-proxy [WARNING]: Error handling client: Invalid_argument("invalid bounds in Cstruct.LE.get_uint32 [0,0](4096) off=0 len=4")
>>>>
>>>> This is partially fixed with <https://github.com/NixOS/nixpkgs/pull/419860>,
>>>> which is more recent than Spectrum's pinned Nixpkgs.  I expect to
>>>> update that in the next few days, but until then, you can apply it on
>>>> top of the Nixpkgs revision in lib/nixpkgs.default.nix, and then pass
>>>> --arg config '{pkgsFun = import /path/to/nixpkgs;}' to any Spectrum
>>>> Nix command.
>>>>
>>>> With that change, I'm able to run foot fine in QEMU.  gnome-text-editor
>>>> runs but prints errors and looks weird, and Firefox doesn't even start.
>>>> crosvm built from the same tag as rutabaga_gfx used by QEMU works fine,
>>>> so I think it must be a QEMU bug.  I spent some time yesterday trying to
>>>> debug it, but didn't get anywhere so far.  If I can't figure it out soon
>>>> I'll open an upstream bug report.
>>>
>>> That's a good idea.  Would it be possible to use vhost-user as a
>>> workaround?  That would use crosvm's implementation instead.
>>
>> No.  crosvm and QEMU have different ideas of what vhost-user-gpu.
>> QEMU expects to provide all the graphical stuff itself, using the
>> vhost-user-gpu protocol[1], whereas the crosvm one has the backend do
>> almost everything (like every other vhost-user device — also much better
>> for sandboxing).
>>
>> [1]: https://www.qemu.org/docs/master/interop/vhost-user-gpu.html#vhost-user-gpu-protocol
> 
> Possibly the best way to test this would be to use crosvm, which also
> supports virtio-sound.

I thought the only implemented backends were CrAS and Android.
-- 
Sincerely,
Demi Marie Obenour (she/her/hers)

[-- Attachment #1.1.2: OpenPGP public key --]
[-- Type: application/pgp-keys, Size: 7253 bytes --]

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 833 bytes --]

  reply	other threads:[~2025-07-20  8:22 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-07-20  2:23 "make run-qemu" gets Wayland protocol error Demi Marie Obenour
2025-07-20  7:55 ` Alyssa Ross
2025-07-20  8:02   ` Demi Marie Obenour
2025-07-20  8:20     ` Alyssa Ross
2025-07-20  8:20       ` Alyssa Ross
2025-07-20  8:22         ` Demi Marie Obenour [this message]
2025-07-20  8:33           ` Alyssa Ross
2025-07-20  9:25             ` Demi Marie Obenour
2025-07-20 14:38               ` Alyssa Ross

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=ff77f1ab-4c8a-4f97-a748-f2ae497a5f2a@gmail.com \
    --to=demiobenour@gmail.com \
    --cc=devel@spectrum-os.org \
    --cc=hi@alyssa.is \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://spectrum-os.org/git/crosvm
	https://spectrum-os.org/git/doc
	https://spectrum-os.org/git/mktuntap
	https://spectrum-os.org/git/nixpkgs
	https://spectrum-os.org/git/spectrum
	https://spectrum-os.org/git/ucspi-vsock
	https://spectrum-os.org/git/www

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).