-
Notifications
You must be signed in to change notification settings - Fork 460
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 DAI DASH streaming freezing with multi periods and no closed caption Ad. #1863
Comments
We believe this bug was introduced in 1.4.0 when removing "IsDecodeOnly" commits: Particularly, it seems this is the bug, in CeaDecoder.java, line 88, in queueInputBuffer(): there seems should be a check for ceaInputBuffer.timeUs != C.TIME_END_OF_SOURCE when discarding the ceaInputBuffer. |
any update? |
I think I was able to repro the issue using the media links provided over email. I then added a single log line and went to retry, and now the content is consistently 503ing. Could you please check to make sure the content is still accessible? |
The content seems to be working again now. I've tried with the following code in if (ceaInputBuffer.timeUs != C.TIME_END_OF_SOURCE
&& outputStartTimeUs != C.TIME_UNSET
&& ceaInputBuffer.timeUs < outputStartTimeUs) {
// We can start decoding anywhere in CEA formats, so discarding on the input side is fine.
releaseInputBuffer(ceaInputBuffer);
} else { Thanks for reporting! I'll work on getting this fix reviewed internally and merged. I've also noticed that the subtitles in your content are mixed up/garbled on |
The behaviour was changed in 1.4.0 with 0f42dd4, so that the buffer timestamp is compared to `outputStartTimeUs` when deciding whether to discard a "decode only" buffer before decoding (instead of the deprecated/removed `isDecodeOnly` property). This breaks when the buffer timestamp is `TIME_END_OF_SOURCE` (which is `Long.MIN_VALUE`), because `TIME_END_OF_SOURCE < outputStartTimeUs` is always true, so the end-of-stream buffer is never passed to the decoder and on to `TextRenderer` where it is used to [set `inputStreamEnded = true`](https://github.com/androidx/media/blob/40f187e4b47c445af5049a5a49ee4633ce4c1a76/libraries/exoplayer/src/main/java/androidx/media3/exoplayer/text/TextRenderer.java#L434-L436) and so playback hangs. #cherrypick Issue: #1863 PiperOrigin-RevId: 695767247
The fix for the I also investigated the garbled captions. The problem is due to your MP4 container marking every video sample as a keyframe, meaning that we flush our reordering queue of CEA-608 samples here on every sample (which means it can't re-order anything): media/libraries/extractor/src/main/java/androidx/media3/extractor/mp4/FragmentedMp4Extractor.java Lines 1650 to 1652 in 19b38c8
This MP4 metadata is inconsistent with the H.264 bytes contained in each sample (not every H.264 sample is a keyframe). If I change the This seems to be an issue with your content muxing, rather than with ExoPlayer's logic - I suggest you report it to whoever is producing your content. |
@icbaker |
The content in Issue: #1863 has every sample incorrectly marked as a sync sample in the MP4 metadata, which results in flushing the re-ordering queue on every sample, so nothing gets re-ordered, so the subtitles are garbled. There are currently two "uses" for this call on every keyframe: 1. It offers a safety valve if we don't read a `maxNumReorderSamples` value from the video. Without this, the queue will just keep growing and end up swallowing all subtitle data (similar to the bug fixed by 39c7349). 2. When we do read (or infer) a `maxNumReorderSamples` it means we can emit samples from the queue slightly earlier - but this is pretty marginal, given i think the max possible value for `maxNumReorderSamples` is 16, so the most benefit we would get is 16 frames (~0.53s at 30fps) - in most cases we will have more than 0.5s of buffer ahead of the playback position, so the subtitles will still get shown at the right time with no problem. (1) is resolved in this change by setting the queue size to zero (no reordering) if we don't have a value for `maxNumReorderSamples`. (2) has minimal impact, so we just accept it. We may be able to inspect the NAL unit to determine IDR vs non-IDR instead - we will consider this as a follow-up change, but given the minimal impact of (2) we may not pursue this. #cherrypick PiperOrigin-RevId: 696583702
We discussed as a team and decided the benefit of relying on the MP4 sync sample metadata for flushing is marginal, and the result of poor behaviour on malformed media like this is quite catastrophic - so we decided to remove the assumption that MP4 sync sample metadata is correct for this use-case (re-ordering SEI CEA-608 samples) - see the change linked above. |
The behaviour was changed in 1.4.0 with 0f42dd4, so that the buffer timestamp is compared to `outputStartTimeUs` when deciding whether to discard a "decode only" buffer before decoding (instead of the deprecated/removed `isDecodeOnly` property). This breaks when the buffer timestamp is `TIME_END_OF_SOURCE` (which is `Long.MIN_VALUE`), because `TIME_END_OF_SOURCE < outputStartTimeUs` is always true, so the end-of-stream buffer is never passed to the decoder and on to `TextRenderer` where it is used to [set `inputStreamEnded = true`](https://github.com/androidx/media/blob/40f187e4b47c445af5049a5a49ee4633ce4c1a76/libraries/exoplayer/src/main/java/androidx/media3/exoplayer/text/TextRenderer.java#L434-L436) and so playback hangs. Issue: #1863 PiperOrigin-RevId: 695767247 (cherry picked from commit 19b38c8)
The content in Issue: #1863 has every sample incorrectly marked as a sync sample in the MP4 metadata, which results in flushing the re-ordering queue on every sample, so nothing gets re-ordered, so the subtitles are garbled. There are currently two "uses" for this call on every keyframe: 1. It offers a safety valve if we don't read a `maxNumReorderSamples` value from the video. Without this, the queue will just keep growing and end up swallowing all subtitle data (similar to the bug fixed by 39c7349). 2. When we do read (or infer) a `maxNumReorderSamples` it means we can emit samples from the queue slightly earlier - but this is pretty marginal, given i think the max possible value for `maxNumReorderSamples` is 16, so the most benefit we would get is 16 frames (~0.53s at 30fps) - in most cases we will have more than 0.5s of buffer ahead of the playback position, so the subtitles will still get shown at the right time with no problem. (1) is resolved in this change by setting the queue size to zero (no reordering) if we don't have a value for `maxNumReorderSamples`. (2) has minimal impact, so we just accept it. We may be able to inspect the NAL unit to determine IDR vs non-IDR instead - we will consider this as a follow-up change, but given the minimal impact of (2) we may not pursue this. PiperOrigin-RevId: 696583702 (cherry picked from commit e6448f3)
The content in Issue: #1863 has every sample incorrectly marked as a sync sample in the MP4 metadata, which results in flushing the re-ordering queue on every sample, so nothing gets re-ordered, so the subtitles are garbled. There are currently two "uses" for this call on every keyframe: 1. It offers a safety valve if we don't read a `maxNumReorderSamples` value from the video. Without this, the queue will just keep growing and end up swallowing all subtitle data (similar to the bug fixed by 39c7349). 2. When we do read (or infer) a `maxNumReorderSamples` it means we can emit samples from the queue slightly earlier - but this is pretty marginal, given i think the max possible value for `maxNumReorderSamples` is 16, so the most benefit we would get is 16 frames (~0.53s at 30fps) - in most cases we will have more than 0.5s of buffer ahead of the playback position, so the subtitles will still get shown at the right time with no problem. (1) is resolved in this change by setting the queue size to zero (no reordering) if we don't have a value for `maxNumReorderSamples`. (2) has minimal impact, so we just accept it. We may be able to inspect the NAL unit to determine IDR vs non-IDR instead - we will consider this as a follow-up change, but given the minimal impact of (2) we may not pursue this. PiperOrigin-RevId: 696583702 (cherry picked from commit e6448f3)
The behaviour was changed in 1.4.0 with 0f42dd4, so that the buffer timestamp is compared to `outputStartTimeUs` when deciding whether to discard a "decode only" buffer before decoding (instead of the deprecated/removed `isDecodeOnly` property). This breaks when the buffer timestamp is `TIME_END_OF_SOURCE` (which is `Long.MIN_VALUE`), because `TIME_END_OF_SOURCE < outputStartTimeUs` is always true, so the end-of-stream buffer is never passed to the decoder and on to `TextRenderer` where it is used to [set `inputStreamEnded = true`](https://github.com/androidx/media/blob/40f187e4b47c445af5049a5a49ee4633ce4c1a76/libraries/exoplayer/src/main/java/androidx/media3/exoplayer/text/TextRenderer.java#L434-L436) and so playback hangs. Issue: #1863 PiperOrigin-RevId: 695767247 (cherry picked from commit 19b38c8)
The content in Issue: #1863 has every sample incorrectly marked as a sync sample in the MP4 metadata, which results in flushing the re-ordering queue on every sample, so nothing gets re-ordered, so the subtitles are garbled. There are currently two "uses" for this call on every keyframe: 1. It offers a safety valve if we don't read a `maxNumReorderSamples` value from the video. Without this, the queue will just keep growing and end up swallowing all subtitle data (similar to the bug fixed by 39c7349). 2. When we do read (or infer) a `maxNumReorderSamples` it means we can emit samples from the queue slightly earlier - but this is pretty marginal, given i think the max possible value for `maxNumReorderSamples` is 16, so the most benefit we would get is 16 frames (~0.53s at 30fps) - in most cases we will have more than 0.5s of buffer ahead of the playback position, so the subtitles will still get shown at the right time with no problem. (1) is resolved in this change by setting the queue size to zero (no reordering) if we don't have a value for `maxNumReorderSamples`. (2) has minimal impact, so we just accept it. We may be able to inspect the NAL unit to determine IDR vs non-IDR instead - we will consider this as a follow-up change, but given the minimal impact of (2) we may not pursue this. PiperOrigin-RevId: 696583702 (cherry picked from commit e6448f3)
Version
Media3 1.4.0 and beyond.
More version details
Issue doesn't happen in 1.3.1. and before
Devices that reproduce the issue
issue can be reproduced on all Android devices we tested: amazon FireTV stick 4K, for example.
Devices that do not reproduce the issue
No response
Reproducible in the demo app?
Yes
Reproduction steps
Expected result
Stream should play without issue
Actual result
streaming will be freezing in a couple of minutes.
Media
will send content in email.
Bug Report
adb bugreport
to android-media-github@google.com after filing this issue.The text was updated successfully, but these errors were encountered: