-
Notifications
You must be signed in to change notification settings - Fork 6k
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
Live Smooth Streaming: Offset to sample data was negative. #1152
Comments
Would I be correct in thinking this is a sporadic failure, rather than something that happens all of the time? |
unfortunately it's happening with all the live streams in the app. Is there a public sample of live smooth streaming I can test to see if it works? |
There's a public sample built into the demo app that you can try (and it works as far as I know). |
I couldn't find the live smooth streaming sample in the demo app, only the "Super Speed" sample which is not live. The weird thing is that on a very old Exoplayer version, the same stream plays with no such error. |
Ah, I didn't spot the live part of your comment. There's an Azure live stream provided by Microsoft, that works fine for me:
I also have some private test streams that work fine. Please could you provide a link to an affected stream? |
NB - I just updated the link in the response above, so copy it again if you tried within the last minute! |
Thanks, the sample you sent plays, but with the stream I have to use it fails this check from extractor/FragmentedMp4Extractor.java at line 695:
In my case bytesToSkip is always -61, and it throws the error. |
That suggests malformed media. There's nothing we can do to assist unless you can provide a test stream. |
Since I'm not allowed to publish the live stream url, could you please send me a PM ( [email protected] )? |
Please provide the stream to |
I think the |
That's quite unfortunate. Given that the same streams are playing on Smart TVs, STBs and an old version of the Exoplayer, an incompatibility with the new Exoplayer is not going to be enough for the content provider to work on the streams. |
If I've diagnosed this correctly, the only reason the streams worked previously is because we were completely ignoring the data offset. It's likely that some other platforms do this too, but it's essentially incorrect and causes parsing failures for legitimate streams that contain non-sample data at the beginning of their mdat boxes. As a local workaround, it appears you can simply comment out the block of code where the failure occurs. |
Commenting that block the video plays, I wasn't sure of what other side effects it might bring. I will let the content provider know about the issue. |
We've seen this issue reported three times now, so it's obviously not an isolated problem. Do you think anything bad will happen to non-SmoothStreaming playback cases if I do this? I suspect not, but if you feel strongly I can easily add a FLAG_WORKAROUND_X flag for it, and enable it for SmoothStreaming only. #2292 #2101 #1152 ------------- Created by MOE: https://github.com/google/moe MOE_MIGRATED_REVID=143583714
We've seen this issue reported three times now, so it's obviously not an isolated problem. Do you think anything bad will happen to non-SmoothStreaming playback cases if I do this? I suspect not, but if you feel strongly I can easily add a FLAG_WORKAROUND_X flag for it, and enable it for SmoothStreaming only. #2292 #2101 #1152 ------------- Created by MOE: https://github.com/google/moe MOE_MIGRATED_REVID=143583714
Attempting to play a Live Smooth Streaming video with ExoPlayer r1.5.3 on an Android 4.4.2 STB, I am getting the following error:
com.google.android.exoplayer.ExoPlaybackException: com.google.android.exoplayer.ParserException: Offset to sample data was negative.
The text was updated successfully, but these errors were encountered: