EGL_NOT_INITIALIZED (EGLError) on RaspberryPi
Opened this issue · 17 comments
Following instructions in blitzberry.md
I am stuck with the following error:
$ blitzloop --mpv-ao=alsa --no-audioengine
Loading song DB...
Done.
Display mode: 1920x1080
Traceback (most recent call last):
File "/usr/bin/blitzloop", line 33, in <module>
sys.exit(load_entry_point('blitzloop==0.1', 'console_scripts', 'blitzloop')())
File "/usr/lib/python3.8/site-packages/blitzloop/main.py", line 59, in entry
display = graphics.Display(opts.width, opts.height, opts.fullscreen)
File "/usr/lib/python3.8/site-packages/blitzloop/graphics.py", line 33, in Display
_display = rpi.Display(*args, **kwargs)
File "/usr/lib/python3.8/site-packages/blitzloop/backend/rpi.py", line 102, in __init__
egl.eglInitialize(self.disp, None, None)
File "/usr/lib/python3.8/site-packages/OpenGL/platform/baseplatform.py", line 415, in __call__
return self( *args, **named )
File "/usr/lib/python3.8/site-packages/OpenGL/error.py", line 230, in glCheckError
raise self._errorClass(
OpenGL.raw.EGL._errors.EGLError: EGLError(
err = EGL_NOT_INITIALIZED,
baseOperation = eglInitialize,
cArguments = (
<OpenGL._opaque.EGLDisplay_pointer object at 0x6b922148>,
None,
None,
),
result = 0
)
and have no idea how to proceed. Raspberry is a 3B+ model.
This is without X, running on the text terminal?
Can you check your libEGL.so.* in the library path, and that /opt/vc/lib/libEGL.so
exists? Maybe add a print(name)
at the top of find_library
. I get the feeling that the wrong EGL library is being loaded.
Can you use mpv --vo=rpi
to play back videos with mpv normally?
Running from text terminal. libEGL
exists:
[alarm@alarmpi blitzloop]$ ls -l /opt/vc/lib/libEGL.so
-rw-r--r-- 1 root root 202072 Oct 16 18:14 /opt/vc/lib/libEGL.so
[alarm@alarmpi blitzloop]$ md5sum /opt/vc/lib/libEGL.so
31494c335a11c07beceb259b48efe3e6 /opt/vc/lib/libEGL.so
Setting LD_LIBRARY_PATH
to /opt/vc/lib
prior to running blitzloop
yields the same error.
Looks like find_library(name)
is not being called at all (as print
was not invoked and intentional typo I made did not raise exception either).
rpi
output is not recognized by mpv
:
[alarm@alarmpi ~]$ mpv --vo=rpi video.mp4
(+) Video --vid=1 (*) (h264 1280x720 25.000fps)
(+) Audio --aid=1 (*) (aac 2ch 48000Hz)
[vo] Video output rpi not found!
Error opening/initializing the selected video_out (--vo) device.
Video: no video
Exiting... (Errors when loading file)
[alarm@alarmpi ~]$ pacman -Q mpv
mpv 1:0.32.0-4
[alarm@alarmpi ~]$ mpv -vo help
The legacy option syntax ('-vo value') is deprecated and dangerous.
Please use '--vo=value'.
Available video outputs:
libmpv render API for libmpv
gpu Shader-based GPU Renderer
vdpau VDPAU with X11
wlshm Wayland SHM video output
xv X11/Xv
vaapi VA API with X11
x11 X11 (slow, old crap)
null Null video output
image Write video frames to image files
tct true-color terminals
caca libcaca
drm Direct Rendering Manager
Shortly after sending this I realized I did not have mpv-rpi
installed (only mpv
which conflicts with it). Sadly the compilation of its dependency - ffmpeg-mmal is keeping me from building it :-(
Yeah, ffmpeg-mmal is a pain in the ass to build.
The thing is, as far as I know you need that to get the video decode acceleration... So it's pretty much a requirement. BlitzLoop on the Rpi3 is already barely holding on on that CPU, without video decode accel it'll be a mess.
It's possible that installing those pulls in some dependency that fixes BlitzLoop too...
I believe it might be possible to use BlitzLoop with the drm (fkms) codepath on rPi, and iff you can get video decode accel that would be fine probably, but I'm not holding my breath...
Ok, I managed to build both ffmpeg-mmal
and mpv-rpi
after all. Now I am getting different error:
[alarm@alarmpi ~]$ mpv --vo=rpi video.mp4
(+) Video --vid=1 (*) (h264 1280x720 25.000fps)
(+) Audio --aid=1 (*) (aac 2ch 48000Hz)
[vo/rpi] Could not get DISPMANX objects.
Error opening/initializing the selected video_out (--vo) device.
Video: no video
Exiting... (Errors when loading file)
At least it's clearly not a BlitzLoop problem... I wonder if something changed in Arch Linux ARM somewhere along the way, or something else is different about your setup...
After reading mpv-player/mpv#7314 I decided to try compile an older version of mpv
(0.29.1) and it finally worked:
[alarm@alarmpi ~]$ mpv -fs --vo=rpi video.mp4
Playing: video.mp4
(+) Video --vid=1 (*) (h264 1280x720 25.000fps)
(+) Audio --aid=1 (*) (aac 2ch 48000Hz)
Using hardware decoding (mmal).
AO: [alsa] 48000Hz stereo 2ch float
VO: [rpi] 1280x720 mmal
Video plays smoothly. Sadly the error reported by blitzloop
did not go away.
Interesting. I'll take a look, but I'm quite busy right now and might not get to doing a full repro on a rPi in quite a while...
If you want: to speed things up I can make an image of the SD card (contains nothing but a fresh Arch Linux + blitzloop
) and publish it somewhere.
That might help, but I still probably won't get to it for a few weeks... I'm catching up on quick GitHub things but I'm a bit too swamped for a proper hardware device debugging session right now :(
Ok, putting my RPi on a shelf then. Feel free to ping me once you have some free cycles and I'll send it to you.
@jose1711 can you try building mpv-0.33.1 with this PR I sent to mpv? mpv-player/mpv#9097
@cyph84 Please allow the following questions:
- do I still need to build
ffmpeg-mmal
prior to recompilation instead of using regularffmpeg
and havempv
detect it during configuration? - is
mpv
supposed to recognize--vo=rpi
?
Following https://forums.raspberrypi.com/viewtopic.php?t=270226#p1692111 I was able to make it work finally. Extra steps taken in addition to what's mentioned in https://github.com/marcan/blitzloop/blob/master/docs/blitzberry.md:
- Install
ffmpeg-mmal
from AUR - Download
PKGBUILD
ofmpv-git
from AUR and make the following modifications:
source=('git+https://github.com/cyph84/mpv#branch=fix-rpi-library-order'
..
--enable-libmpv-shared --enable-rpi \
- Build and install
mpv-git
. As a resultmpv -vo help
should listrpi - Raspberry Pi (MMAL)
among supported outputs. - Create symbolic links in
/opt/vc/lib
:
cd /opt/vc/lib
sudo ln -s libbrcmEGL.so libEGL.so.1
sudo ln -s libbrcmGLESv2.so libGLESv2.so.2
- Populate
/boot/config.txt
:
dtparam=audio=on
gpu_mem=384
initramfs initramfs-linux.img followkernel
- Edit
/home/alarm/startblitz.sh
:
#!/bin/sh
export LD_LIBRARY_PATH=/opt/vc/lib
cd "$(dirname "$0")"
amixer cset numid=3 2
python -u /usr/bin/blitzloop --port=80 --no-audioengine --mpv-ao=alsa
This makes blitzloop
work on an updated Arch Linux. What I left untested is microphone and jackd
config.
@cyph84 Please allow the following questions:
* do I still need to build `ffmpeg-mmal` prior to recompilation instead of using regular `ffmpeg` and have `mpv` detect it during configuration?
You can build against regular ffmpeg, but you need ffmpeg-mmal installed to use --hwdec=mmal
* is `mpv` supposed to recognize `--vo=rpi`?
I think its best you explicitly specify the vo
Btw compiling latest mpv-git
still results in [vo/rpi] Could not get DISPMANX objects.
so mpv-player/mpv#9097 is indeed required.