Skip to content
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

Fix for crash on seek #1469

Open
wants to merge 5 commits into
base: master
Choose a base branch
from
Open

Fix for crash on seek #1469

wants to merge 5 commits into from

Conversation

jpc0
Copy link
Contributor

@jpc0 jpc0 commented Mar 19, 2023

Partial fix for #1451 and #1460

It is ugly but it does fix the crashing for the time being, however the audio thread keeps running as well as the main ffmpeg_producer thread.

I'm not familiar with boost::thread or boost::exception so maybe someone know how kill the other two threads when this thread throws. There may be an architectural issue here that needs to be resolved.

@jpc0
Copy link
Contributor Author

jpc0 commented Mar 19, 2023

Second commit seems to allow the other two threads to cleanly end. Still not sure if this is the correct solution. I also suspect this case will never happen

catch (ffmpeg::ffmpeg_error_t& ex) {
                if (auto errn = boost::get_error_info<ffmpeg_errn_info>(ex)) {
                    if (*errn == AVERROR_EXIT) {
                        return;
                    }
                }
                CASPAR_LOG_CURRENT_EXCEPTION();

@jpc0
Copy link
Contributor Author

jpc0 commented Mar 20, 2023

Thinking about this code a bit more, if feels like it is pointless to keep in, also move the eof=true into the catch.

Let me know if this should be squashed into 1 commit.

catch (ffmpeg::ffmpeg_error_t& ex) {
            if (auto errn = boost::get_error_info<ffmpeg_errn_info>(ex)) {
                if (*errn == AVERROR_EXIT) {
                    return;
                }
            }
            CASPAR_LOG_CURRENT_EXCEPTION();
```

@jpc0
Copy link
Contributor Author

jpc0 commented Mar 20, 2023

Looking at #1460 again...

This would prevent the crash but would also end the video playback. Adding a new try catch in the loop would prevent that, the question is whether audio sync would then go out.

V3.3 doesn't crash but won't play this file.

@jpc0
Copy link
Contributor Author

jpc0 commented Mar 21, 2023

#1444 is also solved by this.

Would be great for @ronag to give some feedback here. #1444 #1451 #1460 are all related to the changes in commit b657428.

Before that commit there was a single thread where any exception would kill the pipeline and be caught at the .run call here. commit b657428 Now spawns 2 additional worker threads, one for video and another for audio and I'm not entirely sure how to stop one of the workers if the other throws other than setting the eof flag.

For the seek issue we would want play to continue theoretically however for partial files we would want the threads to stop processing more data.

With the try catch in the loop the video thread will stop but audio continues until a natural EOF is reached if ever, this could just end up stuck in a loop infinitely. But if we catch outside the loop seeking doesn't work.

If we want to just error on a file that is broken and not attempt to recover then breaking outside the loop is fine.

I feel likely 5033b57 is the way to go here

@jpc0
Copy link
Contributor Author

jpc0 commented Mar 21, 2023

Should we be catching catch (ffmpeg::ffmpeg_error_t& ex) { here instead of all since we really only are looking for the ffmpeg errors?

@Bohoaush
Copy link

Hi @jpc0 thank you for looking into this.
Few days ago I tried commit 8a4befd (which now isn't in commit history) and it worked well for me.
Yesterday i built from commit 712b006 (currently last one) and it stays on last "good" frame, but continuing according to info command. This is definitely better than crashing, but I think continuing playback is better behavior. If incomplete files are a concern, I don't think they are more common than damaged files, but I might be wrong.
I have hundreds of old non-damaged files that would crash current master of CasparCG server if seeking and at least one file that crashes it during normal playback, because it has damaged macro block.

@jpc0
Copy link
Contributor Author

jpc0 commented Mar 23, 2023

Hi @jpc0 thank you for looking into this.

Few days ago I tried commit 8a4befd (which now isn't in commit history) and it worked well for me.

Yesterday i built from commit 712b006 (currently last one) and it stays on last "good" frame, but continuing according to info command. This is definitely better than crashing, but I think continuing playback is better behavior. If incomplete files are a concern, I don't think they are more common than damaged files, but I might be wrong.

I have hundreds of old non-damaged files that would crash current master of CasparCG server if seeking and at least one file that crashes it during normal playback, because it has damaged macro block.

https://github.com/CasparCG/server/commit/4f37f1be63704d24c69a3f87842f7be7c33086d0

Should be what you are looking for.

I rewrote history when my fix for VS2022 got pulled.

I left the two in history here though because I need maintainers to know which direction to go in.

The issue with continueing on error is that the loop hangs indefinitely. So will likely need to pull some deeper errors out of FFMPEG and catch two seperate errors.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants