Question

J'ai compilé Qt 5.1.1 de manière croisée pour une carte Nitrogen6x alimentée par i.MX6 et exécutant Debian 7 (wheezy).

J'ai configuré Qt avec le -egl Le paramètre et eglfs ont été répertoriés comme backend QPA dans la sortie de configuration.

Cependant, si j'essaie d'exécuter un petit exemple d'application avec le -platform eglfs paramètre, je rencontre cette erreur :

stdin: is not a tty
[     1] HAL user version 4.6.9 build 6622 Aug 15 2013 13:22:40
[     2] HAL kernel version 4.6.9 build 1210
QML debugging is enabled. Only use this in a safe environment.
bash: line 1:  3673 Segmentation fault      DISPLAY=:0.0 /opt/Test/bin/Test -platform eglfs
Remote application finished with exit code 139.

OpenGL ES2 et EGL sont installés sur la carte et se trouvent dans /usr/lib et /usr/include.Malheureusement, je n'ai pas trouvé de documentation appropriée pour eglfs, j'espère donc que quelqu'un ici en aura fait l'expérience.

Voici le résultat du backtrace :

    run Test-platform eglfs
Starting program: /opt/Test/bin/Test Test -platform eglfs
[Thread debugging using libthread_db enabled]
Using host libthread_db library "/lib/arm-linux-gnueabihf/libthread_db.so.1".
[     1] HAL user version 4.6.9 build 6622 Aug 15 2013 13:31:17
[     2] HAL kernel version 4.6.9 build 1210
QML debugging is enabled. Only use this in a safe environment.
[New Thread 0x2c6b7460 (LWP 4057)]

Program received signal SIGSEGV, Segmentation fault.
0x2bab6f48 in gcoHAL_QueryChipCount () from /usr/lib/libGAL.so
(gdb) backrace full
Undefined command: "backrace".  Try "help".
(gdb) backrace full[1@t
#0  0x2bab6f48 in gcoHAL_QueryChipCount () from /usr/lib/libGAL.so
No symbol table info available.
#1  0x2ba7ccbc in veglGetThreadData () from /usr/lib/libEGL.so.1
No symbol table info available.
#2  0x2ba74cd0 in eglBindAPI () from /usr/lib/libEGL.so.1
No symbol table info available.
#3  0x2be41934 in ?? () from /usr/local/Qt-Debian/plugins/platforms/libqeglfs.so
No symbol table info available.
#4  0x2be41934 in ?? () from /usr/local/Qt-Debian/plugins/platforms/libqeglfs.so
No symbol table info available.
Backtrace stopped: previous frame identical to this frame (corrupt stack?)
(gdb) info registers
r0             0x1  1
r1             0x23e54  147028
r2             0x738    1848
r3             0x0  0
r4             0x2bb67d84   733379972
r5             0x23e18  146968
r6             0x2e70c  190220
r7             0x2b430198   725811608
r8             0x7efff9e8   2130704872
r9             0x8  8
r10            0x2b0725c4   721888708
r11            0x7efffae0   2130705120
r12            0x2bab6f1c   732655388
sp             0x7efff8f0   0x7efff8f0
lr             0x2ba7ccbc   732417212
pc             0x2bab6f48   0x2bab6f48 <gcoHAL_QueryChipCount+44>
cpsr           0x80000010   -2147483632
(gdb) x/16i $pc
=> 0x2bab6f48 <gcoHAL_QueryChipCount+44>:   ldr r3, [r3, #12]
   0x2bab6f4c <gcoHAL_QueryChipCount+48>:   sub r2, r3, #1
   0x2bab6f50 <gcoHAL_QueryChipCount+52>:   cmp r2, #2
   0x2bab6f54 <gcoHAL_QueryChipCount+56>:   bhi 0x2bab6f70 <gcoHAL_QueryChipCount+84>
   0x2bab6f58 <gcoHAL_QueryChipCount+60>:   ldr r2, [r4]
   0x2bab6f5c <gcoHAL_QueryChipCount+64>:   mov r0, #0
   0x2bab6f60 <gcoHAL_QueryChipCount+68>:   str r3, [r1]
   0x2bab6f64 <gcoHAL_QueryChipCount+72>:   add r3, r2, #1
   0x2bab6f68 <gcoHAL_QueryChipCount+76>:   str r3, [r4]
   0x2bab6f6c <gcoHAL_QueryChipCount+80>:   pop {r4, pc}
   0x2bab6f70 <gcoHAL_QueryChipCount+84>:   mvn r0, #8
   0x2bab6f74 <gcoHAL_QueryChipCount+88>:   bl  0x2baad5fc
   0x2bab6f78 <gcoHAL_QueryChipCount+92>:   ldr r3, [r4]
   0x2bab6f7c <gcoHAL_QueryChipCount+96>:   mvn r0, #8
   0x2bab6f80 <gcoHAL_QueryChipCount+100>:  add r3, r3, #1
   0x2bab6f84 <gcoHAL_QueryChipCount+104>:  str r3, [r4]
(gdb) thread apply all backtrace

Thread 2 (Thread 0x2c6b7460 (LWP 4057)):
#0  0x2b52ef96 in ?? () from /lib/arm-linux-gnueabihf/libc.so.6
#1  0x2b568634 in _IO_file_close () from /lib/arm-linux-gnueabihf/libc.so.6
#2  0x2b568ffe in _IO_file_close_it () from /lib/arm-linux-gnueabihf/libc.so.6
#3  0x2b56113a in fclose () from /lib/arm-linux-gnueabihf/libc.so.6
#4  0x2bea8d00 in udev_new () from /lib/arm-linux-gnueabihf/libudev.so.0
#5  0x2be7d2e4 in ?? () from /usr/local/Qt-Debian/plugins/platforms/libqeglfs.so
#6  0x2be7d2e4 in ?? () from /usr/local/Qt-Debian/plugins/platforms/libqeglfs.so
Backtrace stopped: previous frame identical to this frame (corrupt stack?)

Thread 1 (Thread 0x2bcb9220 (LWP 4056)):
#0  0x2bab6f48 in gcoHAL_QueryChipCount () from /usr/lib/libGAL.so
#1  0x2ba7ccbc in veglGetThreadData () from /usr/lib/libEGL.so.1
#2  0x2ba74cd0 in eglBindAPI () from /usr/lib/libEGL.so.1
#3  0x2be41934 in ?? () from /usr/local/Qt-Debian/plugins/platforms/libqeglfs.so
#4  0x2be41934 in ?? () from /usr/local/Qt-Debian/plugins/platforms/libqeglfs.so
Backtrace stopped: previous frame identical to this frame (corrupt stack?)
(gdb) quit

Comment pourrais-je corriger cette erreur ?

Était-ce utile?

La solution 2

J'ai résolu ce problème en passant à Yocto et en accédant ainsi aux versions les plus récentes des composants essentiels.Si vous développez pour un processeur i.MX, je vous recommande fortement de jeter un œil à https://github.com/Freescale/fsl-community-bsp-platform

Il est très important de supprimer "x11" des distributions par défaut et "wayland" de poky.conf car cela vous entraînera des erreurs.

Construire Qt5 sur une telle configuration fonctionne bien.

Autres conseils

J'ai exactement le même crash sur un MarSBoard exécutant une application egl fb sur une image Yocto créée avec des recettes de https://github.com/silmerusse/meta-robomind.J'ai dû copier les éléments liés à EGL/OpenGL depuis http://repository.timesys.com/buildsources/g/gpu-viv-bin-mx6q/.Dans mon cas, galcore.ko est intégré.

Modifier:Vérifiez que vous disposez de /dev/galcore et que ses autorisations sont crw.rw.rw.(sinon sudo chmod 666 /dev/galcore).Si vous n'avez pas /dev/galcore, essayez insmod /lib/modules/..../kernel/drivers/mxc/gpu-viv/galcore.ko.Ces étapes ont résolu le crash pour moi sur une image Ubuntu.Sur l'image Yocto le pilote galcore est intégré, et semble être là mais j'ai toujours le crash.

Modifier:Le crash de l'image Yocto était dû à une mauvaise version des librairies EGL/GAL.so.Apparemment, le pilote galcore intégré au noyau a la version 4.6.9.6622.Il nécessite les bibliothèques de gpu-viv-bin-mx6q-3.0.35-4.1.0.En utilisant ces bibliothèques et en les copiant manuellement dans /usr/lib, mon application fb fonctionne correctement, en utilisant le matériel OpenGLES 2.0 et le décodage matériel d'une vidéo h264.

J'ai eu une erreur de segmentation similaire lorsque j'ai oublié de charger le module galcore.Voici la trace :

#0  0x766062b0 in gcoHAL_QueryChipCount (Hal=Hal@entry=0x0, Count=Count@entry=0x16494)
    at gc_hal_user_query.c:1726
#1  0x766da244 in veglGetThreadData () at gc_egl.c:137
#2  0x766d3210 in eglfGetDisplay (display_id=0x16c08) at gc_egl_init.c:464
#3  eglGetDisplay (DisplayID=0x16c08) at gc_egl_init.c:565

Qt 5.3.2, noyau 3.10.17, Galcore version 4.6.9.9754

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top