Програми Qt не працюють через libEGL


10

Я розробляю деякі (прості) додатки GUI для RPi2 в Qt5. Налаштування: Розробка коду виконується на ноутбуці Windows за допомогою Netbeans + Qt Designer і віддалено вбудовується в RPi, на якому працює Raspbian Jessie, з інструментами, що входять до нього (g ++ 4.9.2, Qt 5.3.2, пакет qt5-за замовчуванням), як описані тут . Цей параметр, як правило, працює чудово.

Однак навіть мінімальний приклад не працює, хоча будує нормально. Він не запускається і libEGL warning: DRI2: failed to authenticateз’являється, якщо програма запущена з терміналу.

Не можна Qt працювати на RPi? Інакше, будь ласка, допоможіть мені вирішити цю проблему.

EDIT1: Ось що я маю після виконання findкоманди, як Олексій Веснін запропонував:

/usr/lib/arm-linux-gnueabihf/libEGL.so
/usr/lib/arm-linux-gnueabihf/libEGL.so.1
/usr/lib/arm-linux-gnueabihf/libEGL.so.1.0.0
/usr/lib/chromium-browser/libs/libEGL.so
/usr/lib/chromium-browser/libs/libEGL.so.TOC
/opt/vc/lib/libEGL.so
/opt/vc/lib/libEGL_static.a


/usr/lib/arm-linux-gnueabihf/libGLESv2.so.2
/usr/lib/arm-linux-gnueabihf/libGLESv2.so.2.0.0
/usr/lib/arm-linux-gnueabihf/libGLESv2.so
/usr/lib/chromium-browser/libs/libGLESv2.so
/usr/lib/chromium-browser/libs/libGLESv2.so.TOC
/opt/vc/lib/libGLESv2_static.a
/opt/vc/lib/libGLESv2.so

EDIT2: Список з додатковою інформацією:

-rw-r--r-- 1 pi pi 171312 Nov 11 14:20 /usr/lib/arm-linux-gnueabihf/libEGL.so.1.0.0
-rwxr-xr-x 1 root root 107880 Nov  2 22:27 /usr/lib/chromium-browser/libs/libEGL.so
-rw-r--r-- 1 root root 14189 Nov  2 22:27 /usr/lib/chromium-browser/libs/libEGL.so.TOC
-rw-r--r-- 1 root root 202072 Dec 19 21:01 /opt/vc/lib/libEGL.so
-rw-r--r-- 1 root root 245356 Dec 19 21:19 /opt/vc/lib/libEGL_static.a



-rw-r--r-- 1 pi pi 29996 Jan 12  2016 /usr/lib/arm-linux-gnueabihf/libGLESv2.so.2.0.0
-rwxr-xr-x 1 root root 2632816 Nov  2 22:27 /usr/lib/chromium-browser/libs/libGLESv2.so
-rw-r--r-- 1 root root 29617 Nov  2 22:27 /usr/lib/chromium-browser/libs/libGLESv2.so.TOC
-rw-r--r-- 1 root root 100008 Dec 19 21:19 /opt/vc/lib/libGLESv2_static.a
-rw-r--r-- 1 root root 105768 Nov 25 17:35 /opt/vc/lib/libGLESv2.so

EDIT3:

linux-vdso.so.1 (0x7ecef000)
    /usr/lib/arm-linux-gnueabihf/libarmmem.so (0x76f53000)
    libQt5Widgets.so.5 => /usr/lib/arm-linux-gnueabihf/libQt5Widgets.so.5 (0x76a25000)
    libQt5Gui.so.5 => /usr/lib/arm-linux-gnueabihf/libQt5Gui.so.5 (0x76655000)
    libQt5Core.so.5 => /usr/lib/arm-linux-gnueabihf/libQt5Core.so.5 (0x761d0000)
    libGLESv2.so => /opt/vc/lib/libGLESv2.so (0x761ab000)
    libpthread.so.0 => /lib/arm-linux-gnueabihf/libpthread.so.0 (0x76183000)
    libstdc++.so.6 => /usr/lib/arm-linux-gnueabihf/libstdc++.so.6 (0x760a6000)
    libm.so.6 => /lib/arm-linux-gnueabihf/libm.so.6 (0x7602b000)
    libgcc_s.so.1 => /lib/arm-linux-gnueabihf/libgcc_s.so.1 (0x75ffe000)
    libc.so.6 => /lib/arm-linux-gnueabihf/libc.so.6 (0x75ebd000)
    libgobject-2.0.so.0 => /usr/lib/arm-linux-gnueabihf/libgobject-2.0.so.0 (0x75e63000)
    libglib-2.0.so.0 => /lib/arm-linux-gnueabihf/libglib-2.0.so.0 (0x75d5f000)
    libX11.so.6 => /usr/lib/arm-linux-gnueabihf/libX11.so.6 (0x75c49000)
    libGLESv2.so.2 => /usr/lib/arm-linux-gnueabihf/libGLESv2.so.2 (0x75c31000)
    /lib/ld-linux-armhf.so.3 (0x54b67000)
    libpng12.so.0 => /lib/arm-linux-gnueabihf/libpng12.so.0 (0x75c01000)
    libharfbuzz.so.0 => /usr/lib/arm-linux-gnueabihf/libharfbuzz.so.0 (0x75ba5000)
    libz.so.1 => /lib/arm-linux-gnueabihf/libz.so.1 (0x75b7d000)
    libicui18n.so.52 => /usr/lib/arm-linux-gnueabihf/libicui18n.so.52 (0x759bd000)
    libicuuc.so.52 => /usr/lib/arm-linux-gnueabihf/libicuuc.so.52 (0x75874000)
    libdl.so.2 => /lib/arm-linux-gnueabihf/libdl.so.2 (0x75861000)
    librt.so.1 => /lib/arm-linux-gnueabihf/librt.so.1 (0x7584a000)
    libEGL.so => /opt/vc/lib/libEGL.so (0x75810000)
    libbcm_host.so => /opt/vc/lib/libbcm_host.so (0x757ea000)
    libvchiq_arm.so => /opt/vc/lib/libvchiq_arm.so (0x757d4000)
    libvcos.so => /opt/vc/lib/libvcos.so (0x757ba000)
    libffi.so.6 => /usr/lib/arm-linux-gnueabihf/libffi.so.6 (0x757aa000)
    libpcre.so.3 => /lib/arm-linux-gnueabihf/libpcre.so.3 (0x75736000)
    libxcb.so.1 => /usr/lib/arm-linux-gnueabihf/libxcb.so.1 (0x75717000)
    libdrm.so.2 => /usr/lib/arm-linux-gnueabihf/libdrm.so.2 (0x756fa000)
    libglapi.so.0 => /usr/lib/arm-linux-gnueabihf/libglapi.so.0 (0x756c1000)
    libfreetype.so.6 => /usr/lib/arm-linux-gnueabihf/libfreetype.so.6 (0x75629000)
    libgraphite2.so.3 => /usr/lib/arm-linux-gnueabihf/libgraphite2.so.3 (0x755fb000)
    libicudata.so.52 => /usr/lib/arm-linux-gnueabihf/libicudata.so.52 (0x73f7e000)
    libXau.so.6 => /usr/lib/arm-linux-gnueabihf/libXau.so.6 (0x73f73000)
    libXdmcp.so.6 => /usr/lib/arm-linux-gnueabihf/libXdmcp.so.6 (0x73f67000)

Ви намагаєтесь запускати програму віддалено?
золотинки

ні, я запускаю це з RPi
Андрій Про

@goldilocks у випадку віддаленого запуску повідомлення про помилку було б іншим
Олексій Веснін

Відповіді:


7

Це звичайна проблема Linux та Unix, нічого не стосується Pi. Ось проблема: ваші губи повинні бути пов'язані. Зробіть sudo -sі станьте коренем для такої операції. І давайте це усунемо!

Спочатку знайдіть їх так:

# find / -name libEGL* -type f
# find / -name libGLESv2* -type f

і зробіть це посилання на повний шлях до таких файлів :

# ln -fs /path/to/lib/libEGL.so /usr/lib/arm-linux-gnueabihf/libEGL.so
# ln -fs /path/to/lib/libEGL.so /usr/lib/arm-linux-gnueabihf/libEGL.so.1
# ln -fs /path/to/lib/libGLESv2.so /usr/lib/arm-linux-gnueabihf/libGLESv2.so
# ln -fs /path/to/lib/libGLESv2.so /usr/lib/arm-linux-gnueabihf/libGLESv2.so.2

і дайте ОС знати, що ви зробили, і врахуйте це так:

# ldconfig

/path/to/libЧастина ви повинні замінити повний шлях , що findкоманди будуть показувати вам. А якщо працює від непривілейованого користувача - переконайтеся, що він знаходиться в videoгрупі - іноді ця стара частина налаштувань дозволу все-таки спливає. Як перевірити:

# getent group video | cut -d: -f3

якщо він нічого не дає - тоді це не так, але якщо він дає номер, то введіть своє ім'я користувача в groupsкоманді - приклад для користувача pi:

# groups pi

якщо він не відображає videoгрупу - додайте її як додаткову групу , а не як основну, наприклад:

# usermod -a -G video pi

це додасть користувача piдо групи, videoне порушуючи речі

ОНОВЛЕННЯ: додаткова команда перевірки, щоб дізнатися, які файли знайдено:

# find / -name libEGL* -type f -exec ls -la {} \;
# find / -name libGLESv2* -type f -exec ls -la {} \;

ОНОВЛЕННЯ №2: Спробуйте зробити це з root:

# ln -fs /opt/vc/lib/libEGL.so /usr/lib/arm-linux-gnueabihf/libEGL.so
# ln -fs /opt/vc/lib/libGLESv2.so /usr/lib/arm-linux-gnueabihf/libGLESv2.so
# ldconfig

ОНОВЛЕННЯ №3: побудова Qt5 з виправленнями з джерела.

  • перейдіть сюди , встановіть залежності через apt-get (пакунки -dev)
  • як роблять корінь apt-get build-dep qt5-default
  • як роблять корінь apt-get install libxcb-xinerama0-dev flex bison gperf libicu-dev libxslt-dev ruby libssl-dev libxcursor-dev libxcomposite-dev libxdamage-dev libxrandr-dev libdbus-1-dev libfontconfig1-dev libcap-dev libxtst-dev libpulse-dev libudev-dev libpci-dev libnss3-dev libasound2-dev libxss-dev libegl1-mesa-dev gperf bison libasound2-dev libgstreamer0.10-dev libgstreamer-plugins-base0.10-dev, після цьогоapt-get install '^libxcb.*-dev' libx11-xcb-dev libglu1-mesa-dev libxrender-dev libxi-dev

після цього зробіть це:

 # git clone https://code.qt.io/qt/qt5.git
 # cd qt5
 # git submodule update --init

після цього посилання ./configure --helpвивести для вашого випадку, і ми продовжимо

Остаточне оновлення: збірка джерела зробила трюк, проблема полягала у застарілому Qt у пакунках. Рядок конфігурації:

 # mkdir qt-build
 # cd qt-build
 # ../configure -opensource -static -confirm-license -release -nomake examples -openssl-runtime -prefix /usr

На створення програми Raspberry Pi пішло близько 40 годин та 6 + Gb місця для зберігання. Виправлена ​​проблема


Коментарі не для розширеного обговорення; ця розмова була переміщена до чату .
Стів Робільярд

1
близько 46 годин, якщо бути точнішим
Андрій Про

але перемога, нарешті, наша!
Олексій Веснін

1
Я хочу підкреслити це - але через 2 роки немає жодного приводу, щоб утримувачі пакунків досі не виправили це :(
UKMonkey

@UKMonkey не лише ця справа змусила мене створити дистрибутив Linux на власний смак - проблема все ще
Олексій Веснін

0

У моєму випадку це вирішило проблему

sudo ln -s /usr/lib/arm-linux-gnueabihf/libGLESv2.so.2 /usr/lib/arm-linux-gnueabihf/libGLESv2.so
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.