<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<!--[if !mso]><style>v\:* {behavior:url(#default#VML);}
o\:* {behavior:url(#default#VML);}
w\:* {behavior:url(#default#VML);}
.shape {behavior:url(#default#VML);}
</style><![endif]--><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoPlainText, li.MsoPlainText, div.MsoPlainText
        {mso-style-priority:99;
        mso-style-link:"Plain Text Char";
        margin:0cm;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
span.PlainTextChar
        {mso-style-name:"Plain Text Char";
        mso-style-priority:99;
        mso-style-link:"Plain Text";
        font-family:"Calibri",sans-serif;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:70.85pt 2.0cm 70.85pt 2.0cm;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="FI" link="#0563C1" vlink="#954F72" style="word-wrap:break-word">
<div class="WordSection1">
<p class="MsoPlainText">Hi,<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><span lang="EN-US">Ok, this might be the reason…<br>
<br>
<i>Your Qt app segfaults in the stand-alone RDP Weston instance case. We have no idea why that would be, when weston-smoke works.
<b>If it is because the app requires hardware accelerated OpenGL (or you use a proprietary EGL implementation), then it might still work with the DRM-backend.</b> This is because the RDP-backend does not yet support hardware accelerated OpenGL or Vulkan apps.
 Normally apps will just fall back to Mesa's software renderer, but maybe your app needs something extra or maybe you are not using Mesa as your EGL etc.<o:p></o:p></i></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">------------------------------------------------------------------------------------<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">Testing weston-simple-egl with RDP and HDMI-display<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">------------------------------------------------------------------------------------<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">"Force driving" weston-simple-egl to RDP-weston session: (WAYLAND_DISPLAY=wayland-1)<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">Command:<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><i><span lang="EN-US">WAYLAND_DISPLAY=wayland-1 weston-simple-egl<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">has EGL_EXT_buffer_age and EGL_EXT_swap_buffers_with_damage<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">Segmentation fault<o:p></o:p></span></i></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">Logging:<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><i><span lang="EN-US">root@sm2s-imx8mp:~# journalctl -f<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">-- Journal begins at Mon 2023-01-16 09:50:23 CET. --<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">Jan 16 11:47:32 sm2s-imx8mp audit[1569]: ANOM_ABEND auid=0 uid=0 gid=0 ses=5 pid=1569 comm="weston-simple-e" exe="/usr/bin/weston-simple-egl" sig=11 res=1<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">Jan 16 11:47:32 sm2s-imx8mp kernel: audit: type=1701 audit(1673866052.888:25): auid=0 uid=0 gid=0 ses=5 pid=1569 comm="weston-simple-e" exe="/usr/bin/weston-simple-egl" sig=11 res=1<o:p></o:p></span></i></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">Result:<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">Doesn't work.<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">And similar error appears, when I’m trying to drive “Qt” application on RDP-weston:<o:p></o:p></span></p>
<p class="MsoPlainText"><i><span lang="EN-US"><o:p> </o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">Jan 16 13:51:55 sm2s-imx8mp audit[2027]: ANOM_ABEND auid=0 uid=0 gid=0 ses=5 pid=2027 comm="QSGRenderThread" exe="/opt/cpx/cpx" sig=11 res=1<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">Jan 16 13:51:55 sm2s-imx8mp kernel: audit: type=1701 audit(1673873515.594:33): auid=0 uid=0 gid=0 ses=5 pid=2027 comm="QSGRenderThread" exe="/opt/cpx/cpx" sig=11 res=1<o:p></o:p></span></i></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">------------------------------------------------------------------------------------<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">------------------------------------------------------------------------------------<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">"Force driving" weston-simple-egl to a HDMI display (WAYLAND_DISPLAY=wayland-0)<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">Command:<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><i><span lang="EN-US">WAYLAND_DISPLAY=wayland-0 weston-simple-egl<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US"><o:p> </o:p></span></i></p>
<p class="MsoPlainText"><span lang="EN-US">Logging:<o:p></o:p></span></p>
<p class="MsoPlainText"><i><span lang="EN-US"><o:p> </o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">root@sm2s-imx8mp:/opt/cpx# WAYLAND_DISPLAY=wayland-0 weston-simple-egl<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">has EGL_EXT_buffer_age and EGL_EXT_swap_buffers_with_damage<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">304 frames in 5 seconds: 60.799999 fps<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">302 frames in 5 seconds: 60.400002 fps<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">302 frames in 5 seconds: 60.400002 fps<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i><span lang="EN-US">302 frames in 5 seconds: 60.400002 fps<o:p></o:p></span></i></p>
<p class="MsoPlainText"><i>302 frames in 5 seconds: 60.400002 fps<o:p></o:p></i></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">Result:<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US">Works fine, animation runs smoothly.<o:p></o:p></span></p>
<p class="MsoPlainText"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoPlainText"><img width="508" height="309" style="width:5.2916in;height:3.2166in" id="Picture_x0020_1" src="cid:image001.png@01D929AF.41CA1A80"><o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><span lang="EN-US">------------------------------------------------------------------------------------<o:p></o:p></span></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">BR,<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">-Matti<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><span lang="EN-US" style="mso-fareast-language:FI">-----Original Message-----<br>
From: Pekka Paalanen <ppaalanen@gmail.com> <br>
Sent: maanantai 16. tammikuuta 2023 11.40<br>
To: Matti Ristimäki <Matti.Ristimaki@planmeca.com><br>
Cc: Marius Vlad <marius.vlad@collabora.com>; wayland-devel@lists.freedesktop.org<br>
Subject: Re: Wayland/weston, Qt and RDP connection...</span></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">On Sat, 14 Jan 2023 11:58:37 +0200<o:p></o:p></p>
<p class="MsoPlainText">Marius Vlad <<a href="mailto:marius.vlad@collabora.com"><span style="color:windowtext;text-decoration:none">marius.vlad@collabora.com</span></a>> wrote:<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">> On Fri, Jan 13, 2023 at 08:07:07PM +0000, Matti Ristimäki wrote:<o:p></o:p></p>
<p class="MsoPlainText">> > Hi,<o:p></o:p></p>
<p class="MsoPlainText">> Hi,<o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > Thanks for the reply!<o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > Jep, this might be the reason...<o:p></o:p></p>
<p class="MsoPlainText">> >   <o:p></o:p></p>
<p class="MsoPlainText">> > > --modules=systemd-notify.so --modules=screen.share.so<o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > This might be a long shot but it is screen-share.so (hyphen).<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">Hi,<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">this typo would stop Weston from starting, and Weston would clearly say in its log why. The Weston log output is always important to look at. If the compositor doesn't start, also applications will fail to start with "Failed to create
 wl_display" or other such error.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">If you use Weston's --log option, check the file since Weston won't print its log to the standard output. I might recommend to not use --log, and let the systemd service unit forward the stdout and stderr into the journal instead (which
 it does by default).<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">> Jan 13 08:20:06 sm2s-imx8mp cpx.sh[769]: EGL: Warning: No default
<o:p></o:p></p>
<p class="MsoPlainText">> display support on wayland<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">That means that the application is not checking whether connecting to a Wayland compositor worked or not. This is an application bug, but it is just secondary fallout from the primary failure. Quite likely the application will also crash
 (segfault).<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">The reason is that EGL_DEFAULT_DISPLAY is equal to NULL, so I infer that the application code does not verify that the wl_display is not NULL before using it.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">EGL_DEFAULT_DISPLAY cannot work with Wayland by design.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">> > We did try the RDP-weston -session this way too...<o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > 1.<o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > Running RDP-weston -session manually via terminal and after that forcing weston-smoke to the RDP-weston -session.<o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > First weston rdp-backend command via terminal. Notice, that here the
<o:p></o:p></p>
<p class="MsoPlainText">> > "--modules=screen-share.so" is written correctly: (And after that
<o:p></o:p></p>
<p class="MsoPlainText">> > WAYLAND_DISPLAY=wayland-0 is running...)<o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > <o:p></o:p></p>
<p class="MsoPlainText">> > weston --backend=rdp-backend.so --modules=screen-share.so
<o:p></o:p></p>
<p class="MsoPlainText">> > --rdp-tls-cert=/data/etc/ssh/tls.crt <o:p></o:p></p>
<p class="MsoPlainText">> > --rdp-tls-key=/data/etc/ssh/tls.key<o:p></o:p></p>
<p class="MsoPlainText">> Just noticed, you already start weston with the RDP backend *and* with
<o:p></o:p></p>
<p class="MsoPlainText">> the screen-share module. Is that on purpose?<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">I suspect that is not intended. Having both rdp-backend and screen-share in the same Weston instance has no use.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">> The screen-share module starts a weston instance with the RDP backend
<o:p></o:p></p>
<p class="MsoPlainText">> (assuming you have start-on-startup in the ini file) which you connect
<o:p></o:p></p>
<p class="MsoPlainText">> to.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> So for instance, if you have the following in your ini file:<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> [core]<o:p></o:p></p>
<p class="MsoPlainText">> modules=screen-share.so<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> [screen-share]<o:p></o:p></p>
<p class="MsoPlainText">> command=/path/to/weston --backend=rdp-backend.so <o:p></o:p></p>
<p class="MsoPlainText">> --shell=fullscreen-shell.so --no-clients-resize <o:p></o:p></p>
<p class="MsoPlainText">> --rdp-tls-key=rdp/tls.key --rdp-tls-cert=rdp/tls.crt --no-config
<o:p></o:p></p>
<p class="MsoPlainText">> start-on-startup=true<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> Then you run it like:<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> $ /path/to/weston --config /path/to/weston.ini<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> It would automatically start *another* weston instance on the machine
<o:p></o:p></p>
<p class="MsoPlainText">> to connect to. Weston then chooses up, its own a back-end to use
<o:p></o:p></p>
<p class="MsoPlainText">> locally (for instance the DRM back-end), but also creates another
<o:p></o:p></p>
<p class="MsoPlainText">> weston instance with the RDP back-end (which is being done by the screen-share module).<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">This is the right idea.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">One shall never start the "second" Weston if screen sharing is desired, only the screen-share plugin in the "first" Weston can do that.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">> So, when the second RDP instance is started by screen-share.so it
<o:p></o:p></p>
<p class="MsoPlainText">> won't really do anything as it won't be able to do a socket bind
<o:p></o:p></p>
<p class="MsoPlainText">> (being an already RDP server instance on that port).<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> Do you have a display/an output on that local device, or is it without
<o:p></o:p></p>
<p class="MsoPlainText">> any outputs graphic devices?<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> Can you provide a full weston log when this happens?<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">That would be interesting.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">Matti, it could be beneficial to build the set-up in steps:<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">1. No screen-share, no Qt app. Just Weston with its local backend (DRM<o:p></o:p></p>
<p class="MsoPlainText">   quite likely) and a demo app, e.g. weston-simple-egl (shows a<o:p></o:p></p>
<p class="MsoPlainText">   spinning triangle in OpenGL ES 2).<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">2. Add screen-share, but no Qt app. Make sure both local and RDP<o:p></o:p></p>
<p class="MsoPlainText">   outputs look good with a demo app.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">3. Add the Qt app.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">If you stop at the first point where you encounter problems, it is easier to ask and answer.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">You have already shown that a stand-alone (non-screen-sharing) RDP Weston instance works fine with your weston-smoke experiment.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">Your Qt app segfaults in the stand-alone RDP Weston instance case. We have no idea why that would be, when weston-smoke works. If it is because the app requires hardware accelerated OpenGL (or you use a proprietary EGL implementation),
 then it might still work with the DRM-backend. This is because the RDP-backend does not yet support hardware accelerated OpenGL or Vulkan apps. Normally apps will just fall back to Mesa's software renderer, but maybe your app needs something extra or maybe
 you are not using Mesa as your EGL etc.<o:p></o:p></p>
<p class="MsoPlainText">implementation.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">A full Weston log would answer many questions.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">Proprietary graphics driver stacks tend to be hard to work with, because obviously we cannot fix them, and they often work only in very narrow circumstances. Some vendors even patch Weston, so it would be good to understand if you are
 using an upstream Weston or something with downstream patches.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">Thanks,<o:p></o:p></p>
<p class="MsoPlainText">pq<o:p></o:p></p>
</div>
This e-mail may contain confidential or privileged information and is intended solely for the person to whom it is addressed. If you have received this e-mail in error, please notify the sender immediately and destroy this e-mail. Any unauthorized copying,
 disclosure or distribution of the material in this e-mail is strictly forbidden. We will not be liable for direct, indirect, special or consequential damages arising from the alteration of this e-mail, or as a result of any virus being passed on or as of transmission
 of this e-mail in general.
</body>
</html>