<div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sat, Mar 16, 2019 at 12:33 PM Mauro Rossi <<a href="mailto:issor.oruam@gmail.com">issor.oruam@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi Stéphane,<br>
<br>
the good news is that Kerol Herbst patches are mitigating effectively<br>
the GPU lockup.<br>
it would really be a pity to loose and abandon nouveau driver in android-x86,<br>
while intel, radeon and amdgpu are working perfectly.<br>
<br>
The Android GUI reboots always the same way when bringing back main screen,<br>
with home button or using square menu button.<br>
<br>
I've collected log with drm.debug level 63<br>
to see what is happening prior to EGL-MAIN: DRI2: failed to create<br>
screen/ EGL_NOT_INITIALIZED<br>
<br>
Full log and tombstone in the attachment,<br>
could someone in nouveau team decipher the errors?<br></blockquote><div><br></div><div>That's a question more appropriate for the nouveau list, I am CCing the list.</div><div><br></div><div>Stéphane</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
In the logs there is also the DRM ioctl commands happening before the<br>
DRI screen error<br>
<br>
Mauro<br>
<br>
03-16 18:57:03.615 0 0 E : 00a0 2 base507c_ntfy_set<br>
03-16 18:57:03.615 0 0 E : 00000060<br>
03-16 18:57:03.615 0 0 E : f0000000<br>
03-16 18:57:03.615 0 0 E : 0084 1 base907c_image_set<br>
03-16 18:57:03.615 0 0 E : 00000010<br>
03-16 18:57:03.615 0 0 E : 00c0 1 base907c_image_set<br>
03-16 18:57:03.615 0 0 E : fb0000fe<br>
03-16 18:57:03.615 0 0 E : 0400 5 base907c_image_set<br>
03-16 18:57:03.615 0 0 E : 00010000<br>
03-16 18:57:03.615 0 0 E : 00000000<br>
03-16 18:57:03.615 0 0 E : 04000500<br>
03-16 18:57:03.615 0 0 E : 00005004<br>
03-16 18:57:03.615 0 0 E : 0000cf00<br>
03-16 18:57:03.615 0 0 E : 0080 1 base507c_update<br>
03-16 18:57:03.615 0 0 E : 00000000<br>
03-16 18:57:03.616 2729 4165 W EGL-MAIN: DRI2: failed to create dri screen<br>
03-16 18:57:03.616 2729 4165 W EGL-MAIN: DRI2: failed to create screen<br>
03-16 18:57:03.617 2729 4165 W libEGL : eglInitialize(0xad3ab800)<br>
failed (EGL_NOT_INITIALIZED)<br>
03-16 18:57:03.617 2729 4165 I system_server:<br>
android::hardware::configstore::V1_0::ISurfaceFlingerConfigs::hasWideColorDisplay<br>
retrieved: 0<br>
03-16 18:57:03.617 2729 4165 I OpenGLRenderer: Initialized EGL, version 1.4<br>
03-16 18:57:03.617 2729 4165 D OpenGLRenderer: Swap behavior 2<br>
03-16 18:57:03.617 2729 4165 F OpenGLRenderer: Failed to choose<br>
config, error = EGL_NOT_INITIALIZED<br>
--------- beginning of crash<br>
03-16 18:57:03.617 2729 4165 F libc : Fatal signal 6 (SIGABRT),<br>
code -6 in tid 4165 (RenderThread), pid 2729 (system_server)<br>
<br>
On Tue, Mar 5, 2019 at 8:55 AM Mauro Rossi <<a href="mailto:issor.oruam@gmail.com" target="_blank">issor.oruam@gmail.com</a>> wrote:<br>
><br>
> Hi,<br>
> one of the problems (the Play Store Crash) was resolved with following commit:<br>
> <a href="http://git.osdn.net/view?p=android-x86/frameworks-base.git;a=commit;h=d488a6c2bbedc06fc22942555d0157e7bf09f135" rel="noreferrer" target="_blank">http://git.osdn.net/view?p=android-x86/frameworks-base.git;a=commit;h=d488a6c2bbedc06fc22942555d0157e7bf09f135</a><br>
><br>
> Now the remaining one, affecting the dEQP-EGL multithreading tests and<br>
> RenderThread in general,<br>
> has been traced in the attached logs.<br>
><br>
> It seams a problem similar to "a second libEGL call failing" when<br>
> RenderThread is trying to create dri screen<br>
> which is killed by Android attempt to load EGL config which fails and<br>
> it is treated as Fatal.<br>
> We just need to find the root cause of failure.<br>
><br>
> In the logcat there is a clue of what is happening:<br>
><br>
> --------- beginning of crash<br>
> 03-04 20:50:56.762 1440 1440 E AndroidRuntime: FATAL EXCEPTION: main<br>
> 03-04 20:50:56.762 1440 1440 E AndroidRuntime: Process:<br>
> com.android.systemui, PID: 1440<br>
> 03-04 20:50:56.762 1440 1440 E AndroidRuntime:<br>
> java.lang.NullPointerException: Attempt to invoke virtual method<br>
> 'android.graphics.GraphicBuffer<br>
> android.graphics.Bitmap.createGraphicBufferHandle()' on a null object<br>
> reference<br>
> 03-04 20:50:56.762 1440 1440 E AndroidRuntime: at<br>
> com.android.systemui.recents.views.RecentsTransitionHelper.drawViewIntoGraphicBuffer(RecentsTransitionHelper.java:436)<br>
><br>
> Mauro<br>
><br>
> On Tue, Mar 5, 2019 at 1:29 AM Stéphane Marchesin <<a href="mailto:marcheu@chromium.org" target="_blank">marcheu@chromium.org</a>> wrote:<br>
> ><br>
> ><br>
> ><br>
> > On Sat, Mar 2, 2019 at 12:08 AM Mauro Rossi <<a href="mailto:issor.oruam@gmail.com" target="_blank">issor.oruam@gmail.com</a>> wrote:<br>
> >><br>
> >> Hi Stéphane,<br>
> >><br>
> >> On Fri, Mar 1, 2019 at 11:24 PM Stéphane Marchesin <<a href="mailto:marcheu@chromium.org" target="_blank">marcheu@chromium.org</a>> wrote:<br>
> >> ><br>
> >> ><br>
> >> ><br>
> >> > On Fri, Mar 1, 2019 at 4:30 AM Mauro Rossi <<a href="mailto:issor.oruam@gmail.com" target="_blank">issor.oruam@gmail.com</a>> wrote:<br>
> >> >><br>
> >> >> Hi Stéphane,<br>
> >> >><br>
> >> >> thanks for responding<br>
> >> >><br>
> >> >> On Thu, Feb 28, 2019 at 9:56 PM Stéphane Marchesin <<a href="mailto:marcheu@chromium.org" target="_blank">marcheu@chromium.org</a>> wrote:<br>
> >> >> ><br>
> >> >> ><br>
> >> >> ><br>
> >> >> > On Tue, Feb 19, 2019 at 6:54 PM Tomasz Figa <<a href="mailto:tfiga@chromium.org" target="_blank">tfiga@chromium.org</a>> wrote:<br>
> >> >> >><br>
> >> >> >> Hi Mauro,<br>
> >> >> >><br>
> >> >> >> Thanks for your query. I'm not very active in the graphics area<br>
> >> >> >> anymore, but let me add +Stéphane Marchesin , who should know the<br>
> >> >> >> best.<br>
> >> >> >><br>
> >> >> >> Best regards,<br>
> >> >> >> Tomasz<br>
> >> >> >><br>
> >> >> >> On Wed, Feb 20, 2019 at 3:00 AM Mauro Rossi <<a href="mailto:issor.oruam@gmail.com" target="_blank">issor.oruam@gmail.com</a>> wrote:<br>
> >> >> >> ><br>
> >> >> >> > Hi Tomasz,<br>
> >> >> >> ><br>
> >> >> >> > I wanted to ask some help, even just some information about how<br>
> >> >> >> > nouveau is working with chromeos minigbm stack, because we have big<br>
> >> >> >> > issues with drm_gralloc and gbm_gralloc.<br>
> >> >> >> ><br>
> >> >> >> > nouveau gallium driver does not support Multithreading and oreo-x86<br>
> >> >> >> > has introduced additional RenderThread scenarios which cause<br>
> >> >> >> > instability.<br>
> >> >> >> ><br>
> >> >> >> > dEQP-EGL multithreding tests are causing GUI restarts, even with<br>
> >> >> >> > latest Karol Herbst patches with per gl context mutex locking and per<br>
> >> >> >> > fence mutex locking,<br>
> >> >> >> > he said there is an additional race condition that may require another<br>
> >> >> >> > major rewrite,<br>
> >> >> >> > but he did not mention which additional race condition.<br>
> >> >> >> ><br>
> >> >> >> > I wanted to ask you just some info, in case you may have them, or<br>
> >> >> >> > suggestions on how to avoid the problem.<br>
> >> >> >> ><br>
> >> >> >> > 1) Are you aware of problems with chromeos with nouveau MT and how<br>
> >> >> >> > they were avoided?<br>
> >> >> >> > At the moment I can boot with minigbm, but the navigation bar and menu<br>
> >> >> >> > bar are trasparent and invisible, so I was not able to check if<br>
> >> >> >> > minigbm has same problems we have.<br>
> >> >> >> ><br>
> >> >> >> > 2) We are so stuck with nouveau support that I was thinking to explore<br>
> >> >> >> > another angle,<br>
> >> >> >> > is it possible to disable additional threads in android-x86 code base for Oreo?<br>
> >> >> >> > Do you have some colleagues that may provide indication on how to do it?<br>
> >> >> >> ><br>
> >> >> ><br>
> >> >> ><br>
> >> >> > Hi Mauro,<br>
> >> >> ><br>
> >> >> > We don't officially support nouveau on Chrome OS (there are no devices which use it). The nouveau minigbm driver was written to be able to develop Chrome for Chrome OS on top of a Linux workstation with an nvidia GPU. In particular, we have never started Android with that configuration.<br>
> >> >> ><br>
> >> >> > Can you give more details on issue 1, i.e. what is invisible? Last I looked Chrome was working. Are you certain this is related to threading?<br>
> >> >> ><br>
> >> >> > Stéphane<br>
> >> >><br>
> >> >> [minigbm issue]<br>
> >> >><br>
> >> >> The problem with minigbm was mentioned after trying to exploit minigbm<br>
> >> >> as it is in Chrome OS stack (which supports running Android<br>
> >> >> applications AFAIK)<br>
> >> >><br>
> >> >> The stock minigbm was not ready to boot in android-x86, lambdadroid<br>
> >> >> added dma fb support and I added some required formats (RGBA, RGBX,<br>
> >> >> RGB565)<br>
> >> >> to be able to boot:<br>
> >> >> <a href="https://github.com/maurossi/minigbm/commits/minigbm_fb" rel="noreferrer" target="_blank">https://github.com/maurossi/minigbm/commits/minigbm_fb</a><br>
> >> >><br>
> >> >> Using that version of minigbm with android-x86 (oreo-x86) I see is<br>
> >> >> that Android GUI top bar, bottom menu bar, icons and cursor are<br>
> >> >> invisible/not rendered,<br>
> >> >> even if blind interaction is possible.<br>
> >> >> Maybe I've done something wrong because the drm format selection in<br>
> >> >> minigbm is not as easy to underdestrand as drm_gralloc and gbm_gralloc<br>
> >> >> ones.<br>
> >> ><br>
> >> ><br>
> >> > Yeah as I said, we never ran any Android with the nouveau minigbm driver, not ARC++, even less Android, so I don't know.<br>
> >> ><br>
> >> >><br>
> >> >><br>
> >> >> The GUI transparency (or missing rendering) with minigbm does not seem<br>
> >> >> related to multiple threads using same GL context,<br>
> >> >> however the GPU lookups and failure of dEQP-EGL multithreading tests<br>
> >> >> happening also with drm_gralloc and gbm_gralloc are certainly related.<br>
> >> >><br>
> >> >> [MT issues]<br>
> >> >><br>
> >> >> Since it is already assessed and known that nouveau lacks MT support<br>
> >> >> as per other mesa drivers i965, radeon, amdgpu<br>
> >> >> and Karol Herbst submitted patches to mesa-dev to bring "per gl<br>
> >> >> context mutex" and "per fence mutex locking" in nouveau,<br>
> >> >> I tried to run CTS dEQP-EGL with mesa GLES/EGL built with those patches,<br>
> >> >> the result was that dEQP-EGL multithreading tests failed causing GUI<br>
> >> >> reboots or PC restarts.<br>
> >> >><br>
> >> ><br>
> >> > I am surprised by that; we have no problem with android on radeon which uses gallium which would have the same issues.<br>
> >><br>
> >> We have no problem with radeon too,<br>
> >> but for nouveau there is an history of GPU lockups with android-x86 as we speak,<br>
> >> Ilia Mirkin confirmed in several different bugzilla tickets that<br>
> >> nouveau does not react well to multiple threads workers on same gl<br>
> >> context.<br>
> ><br>
> ><br>
> ><br>
> > Hmm if you get GPU lockups, yes that's a different problem.<br>
> ><br>
> ><br>
> >><br>
> >><br>
> >> Infact with some prototypal mutex locking patches we had a mitigation<br>
> >> for android-x86 releases from lollipop-x86 to nougat-x86<br>
> >><br>
> >> Karol Hebst submitted patches to mesa-dev on last december for that<br>
> >> exact same problem,<br>
> >> the patches are not yet up-streamed, so technically the problem is still there.<br>
> >><br>
> >> The current Use Case is android-x86, but the first next GUI using<br>
> >> multiple threads will have problems too.<br>
> >><br>
> >> ><br>
> >> ><br>
> >> >> Having contacted Karol Herbst he told that there may be one additional<br>
> >> >> race condition, but he did not clarified which one.<br>
> >> >><br>
> >> >> What about launching dEQP-EGL on platform different from android, e.g.<br>
> >> >> EGL wayland is that possible to see if the tests also fail on Linux<br>
> >> >> platform?<br>
> >> ><br>
> >> ><br>
> >> > We use the surfaceless/null backend for deqp. We have upstreamed it, you should be able to use that also. Otherwise I have used the glx backend successfully as well on my desktop.<br>
> >><br>
> >> Could it be that in your scenario there is only one thread per gl<br>
> >> context at a time?<br>
> >><br>
> ><br>
> > In general, most of deqp is one GL context at a time, unless you run the parallel deqp stuff. So yes it would probably help. Similarly Chrome OS is running pretty much in a single GPU process, so we wouldn't see that problem either when running nouveau.<br>
> ><br>
> ><br>
> >><br>
> >> ><br>
> >> ><br>
> >> >><br>
> >> >> Are there similar tests in piglit?<br>
> >> ><br>
> >> ><br>
> >> > I'm not aware of any, but I stopped using piglit years ago.<br>
> >> ><br>
> >> >><br>
> >> >><br>
> >> >> [Other issue appeared with Android 8 Oreo hardware bitmaps]<br>
> >> >><br>
> >> >> System UI and Play Store crashes, are happening after successful<br>
> >> >> android-x86 boot with drm_gralloc and gbm_gralloc,<br>
> >> >> these crashes seem to be very much related to this path:<br>
> >> >> CreateHardwareBitmap -> CreateBitmap -> Null Pointer Exception.<br>
> >> >> CreateHardwareBitmap (introduced in Android Oreo),<br>
> >> ><br>
> >> ><br>
> >> > Seems like you are missing dri extensions?<br>
> >><br>
> >> Checking in the logcat the boot with nouveau has all extensions as per<br>
> >> other drivers,<br>
> >> but it has DRI_IMAGE twice, is that bad?<br>
> >><br>
> >> 02-02 10:35:37.176 2489 2489 D vndksupport: Loading<br>
> >> /vendor/lib/egl/libGLES_mesa.so from current namespace instead of<br>
> >> sphal namespace.<br>
> >> 02-02 10:35:37.188 2489 2489 D libEGL : loaded<br>
> >> /vendor/lib/egl/libGLES_mesa.so<br>
> >> 02-02 10:35:37.251 2489 2489 D vndksupport: Loading<br>
> >> /vendor/lib/hw/<a href="http://gralloc.gbm.so" rel="noreferrer" target="_blank">gralloc.gbm.so</a> from current namespace instead of sphal<br>
> >> namespace.<br>
> >> 02-02 10:35:37.253 2489 2489 I EGL-MAIN: found extension DRI_Core version 2<br>
> >> 02-02 10:35:37.253 2489 2489 I EGL-MAIN: found extension<br>
> >> DRI_IMAGE_DRIVER version 1<br>
> >> 02-02 10:35:37.253 2489 2489 I EGL-MAIN: found extension<br>
> >> DRI_ConfigOptions version 2<br>
> >> 02-02 10:35:37.257 2489 2489 I EGL-MAIN: found extension<br>
> >> DRI_TexBuffer version 2<br>
> >> 02-02 10:35:37.257 2489 2489 I EGL-MAIN: found extension DRI2_Flush version 4<br>
> >> 02-02 10:35:37.257 2489 2489 I EGL-MAIN: found extension DRI_IMAGE version 17<br>
> >> 02-02 10:35:37.257 2489 2489 I EGL-MAIN: found extension DRI_IMAGE version 17<br>
> >> 02-02 10:35:37.257 2489 2489 I EGL-MAIN: found extension<br>
> >> DRI_RENDERER_QUERY version 1<br>
> >> 02-02 10:35:37.257 2489 2489 I EGL-MAIN: found extension<br>
> >> DRI_CONFIG_QUERY version 1<br>
> >> 02-02 10:35:37.257 2489 2489 I EGL-MAIN: found extension DRI2_Fence version 2<br>
> >> 02-02 10:35:37.257 2489 2489 I EGL-MAIN: found extension<br>
> >> DRI2_Interop version 1<br>
> >> 02-02 10:35:37.257 2489 2489 I EGL-MAIN: found extension DRI_NoError version 1<br>
> >><br>
> ><br>
> > Can you put it in gdb and see where the NULL crash is? One can only intuit about what's going on otherwise.<br>
> ><br>
> > Stéphane<br>
> ><br>
> ><br>
> >><br>
> >> ><br>
> >> > Stéphane<br>
> >> ><br>
> >> ><br>
> >> >><br>
> >> >> uses only one copy<br>
> >> >> of bitmap instead of two, are there some restrictions in nouveau with<br>
> >> >> RGBA/RGBX, BGRA hardware bitmaps?<br>
> >> >><br>
> >> >> Thanks in advance for any info, suggestions<br>
> >> >> I am available and ready to support testing/verifications to see the<br>
> >> >> MT and HardwareBitmap issues solved.<br>
> >> >><br>
> >> >> Mauro<br>
> >> >><br>
> >> >><br>
> >> >><br>
> >> >> ><br>
> >> >> ><br>
> >> >> >><br>
> >> >> >> > Mauro<br>
</blockquote></div></div>