-
Notifications
You must be signed in to change notification settings - Fork 332
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
omxplayer occasionally terminates incorrectly at the end of a track #124
Comments
Looks like this might be related to Issue #12 |
Since my first post I have been running Pi Presents, incorporating pexpect as the interface to omxplayer, for 40 hours using a loop of four tracks. This gave 52 failures of omxplayer in about 9600 track plays. After 40 hours I gave up because all failures of omxplayer had been successfully detected and dealt with. From analysis of the data I have detected only 2 failure conditions which appear slightly different to the ones I reported earlier. It could be my previous analysis was incorrect. ABORT - occured 41 times /usr/bin/omxplayer: line 56: 29984 Aborted LD_LIBRARY_PATH="$OMXPLAYER_LIBS${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}" and then pexpect detects an eof HANG1 - occured 11 times I have put the Pi Presents with the workarounds that I used for the test in |
Hi @KenT2 Thanks for your work on this. I've run into similar problems using pexpect and now run it all with subprocess. There are many things you lose in doing it this way I realize...and I still run a watchdog timer to kill omxplayer if it runs for longer than the duration of the video...but it works. |
Hi @andyjagoe I wasn't sure whether it was omxplayer, pexpect, or Pi Presents that was causing the problem so I wrote the little script to isolate omxplayer. (Assuming my script has not introduced other problems, my linux knowledge is very much at the trial and error stage.) The way I now do the interface in Pi Presents has a couple of very short timeouts for omxplayer not responding. This does not need the software to know the duration of the track. |
@KenT2 I ran your script with the 1 sec movie. I also see that omxplayer is randomly hanging, just like you described. The 1sec movie shows perfectly what @johnspackman runs into: sometimes the screen stays black and omxplayer doesn't stop at all. The number of runs to bump into the problem varies. I found in the omxplayer.log file the following lines.
I changed the logging so it shows which component has trouble setting its state, but the line just below the error told it already :-) The error is OMX_ErrorInsufficientResources. Whatever that may be... it is beyond my Openmax knowledge. Nevertheless, omxplayer starts running and sends (movie) data to the OMX (core) components. The stats output (-s option) shows the caching of the data, but also the stop of it; audio cache 'Ca:' isn't decreased anymore. Somehow/somewhere (audio buffering?) the clock gets actually started?!
I put a printf statement in every OMXClock function, but I'm missing the call to set/start the media time (=clock). I would expect the OMX components to catch up; the clock is ticking and the PTS where the OMX components are waiting for, passes by. Apparently they don't. By the way, my gpu_mem_512=256 (from /boot/config.txt). |
@jehutting |
@KenT2 Thanks. Will look at it. |
@jehutting has provided a fix which I have tested without any falures |
I'm seeing issues with omxplayer_0.3.5 What data can I collect to help you narrow down this issue? |
I've been running three test systems 24 hours a day and have had more success with the @jehutting release than recent builds. I'm not sure these problems are related to dbus...and I've started wondering if some of these problems are related to problems with the USB driver. Are the videos you're playing on a USB flash drive? And when these problems occur are you also heavily writing to the USB drive and/or heavily using WiFi via USB? I've started using jdb's fiq_fsm usb driver rewrite in branch=next and my systems have been much more stable ever since: http://www.raspberrypi.org/phpBB3/viewtopic.php?f=28&t=70437&sid=2fc7e5f390dfa969ab94c5cc0789772f |
I'm running v0.3.5 (Build date: Sun, 09 Mar 2014 18:17:45 +0000 Version : 9b0793f [master]) version and noticed a dramatic improvement over previous versions, but just checked the stats the player collects and it's started to creep back in that my watchdog timer will have to kill off omxplayer even though the video has actually ended. In fact, it seems to be getting more frequent! Here's my version history for this particular machine: My stats are below:
|
I've been playing the videos off the SD Card itself. |
re-opened as its become a live topic again. |
@KenT2 is this still an issue? If not, please close the issue. Thanks. |
Can you @KenT2 reply on Ruffio's request? |
Sorry missed the previous request, I have converted PI Presents to use dbus rather than pexpect so will close |
omxplayer -v gives:
Build date: Mon, 16 Dec 2013 22:06:42 +0100
Version : b34143c [master]
omxplayer occasionally terminates incorrectly at the end of a track. This occurs for the 4 videos tested and at random. Sometimes after tens of iterations sometimetimes after thousands.
Using the script below and also an instrumented version of Pi Presents (which uses noahs pexpect to interface with omxplayer) I have observed three different symptoms. All seem to occur with a timestamp that is near the end of a track:
a. TIMEOUT - The stats output produced by the -s option stops during a track so there is no have a nice day, the last line is often truncated. Following this the omxplayer and omxplayer.bin processes terminate naturally.
example of last line of output:
M:12348800 V: 1.53s 0k/ 4800k A: 1.12 6.14s/ 2.00s Cv: 0k Ca: 8k
M:12524561 V:
b. ABORT - omxplayer.bin appears to abort before outputting have a nice day. The abort is reported by omxplayer. Following this the omxplayer and omxplayer.bin processes terminate naturally.
examples of error report:$OMXPLAYER_BIN "$ @"
/usr/bin/omxplayer: line 56: 3756 Aborted LD_LIBRARY_PATH="$OMXPLAYER_LIBS${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}"
c. HANG - have a nice day is output, following this the omxplayer and omxplayer.bin processes do not terminate naturally. Seems to occur only on a short video (1sec.mp4)
The script used to demonstrate these is:
!/bin/sh
while :
do
omxplayer -s -g -olocal 5sec.mp4 1>>log.log 2>>error.log
if [ -s error.log ]
then
break
fi
done
just place it in an empty directory, put videos to be played in the same directory, make it executable and run it with ./omx.sh. Wait until videos stop playing then look at the logs for the last iteration.
I am currently testing a version of Pi Presents which has workarounds for the three symptoms.
I have uploaded a zip file to www.museumoftechnology.org.uk/ken/omxplayer1.zip
It contains the script, 2 very short test videos - 1sec.mp4 and 5sec.mp4,and some example runs.
The other two videos I have used xthresh.mp4 and suits-short.mkv can be obtained from https://github.com/KenT2/pipresents-next-examples/tree/master/pp_home/media
Tell me where to get an omxplayer.bin and I'll soak test any fixes.
The text was updated successfully, but these errors were encountered: